home
products
contribute
download
documentation
forum
Home
Forums
New posts
Search forums
What's new
New posts
All posts
Latest activity
Members
Registered members
Current visitors
Donate
Log in
Register
What's new
Search
Search
Search titles only
By:
New posts
Search forums
Search titles only
By:
Menu
Log in
Register
Navigation
Install the app
Install
More options
Contact us
Close Menu
Forums
MediaPortal 1
WebService and Mobile Access
Popular Plugins
MPExtended
json/getschedules startime and endtime
Contact us
RSS
JavaScript is disabled. For a better experience, please enable JavaScript in your browser before proceeding.
You are using an out of date browser. It may not display this or other websites correctly.
You should upgrade or use an
alternative browser
.
Reply to thread
Message
<blockquote data-quote="rasmu" data-source="post: 1110229" data-attributes="member: 150544"><p>Here is the final script :</p><p>[code]</p><p># -*- coding: utf-8 -*-</p><p></p><p>import urllib2, base64, sys, json, logging</p><p>from wakeonlan import wol</p><p>from datetime import datetime, date, time</p><p></p><p>#MPExtended credentials</p><p>username = ''</p><p>password = ''</p><p></p><p>result = ''</p><p>online = False</p><p>startrecord = False</p><p>records = None</p><p>num_records = 0</p><p></p><p>datenow = datetime.now()</p><p>file_recordings = 'recordings.txt'</p><p>file_log = 'log.txt'</p><p></p><p></p><p># Create logger</p><p>logging.basicConfig(level=logging.INFO,</p><p> format='%(asctime)s %(levelname)s %(message)s',</p><p> filename=file_log,</p><p> filemode='a')</p><p></p><p></p><p># Try to get the recordings from Mediaportal</p><p>try:</p><p> # Computer is powered on</p><p> request = urllib2.Request("http://192.168.0.32:4322/MPExtended/TVAccessService/json/GetSchedules")</p><p> base64string = base64.encodestring('%s:%s' % (username, password)).replace('\n', '')</p><p> request.add_header("Authorization", "Basic %s" % base64string) </p><p> result = urllib2.urlopen(request, timeout=2) </p><p> </p><p> f = open(file_recordings, 'w')</p><p> f.write(result.read())</p><p> f.close()</p><p></p><p> logging.info("Populate recordings from Mediaportal done")</p><p> online = True</p><p> </p><p>except Exception, e:</p><p> # computer is away</p><p> logging.info("Can't connect to computer : " + str(e))</p><p> </p><p></p><p># Try to get the recordings from file</p><p>try:</p><p> f = open(file_recordings, 'r')</p><p> records = json.loads(f.read())</p><p> f.close()</p><p> num_records = len(records)</p><p> if num_records > 0:</p><p> logging.info(str(num_records) + " recordings found from local file")</p><p> else:</p><p> logging.info("No recording were from local file")</p><p> </p><p>except Exception, e:</p><p> logging.info("Can't find recording from local file : " + str(e))</p><p></p><p></p><p># We found recordings and computer is off</p><p>if num_records > 0:</p><p> if online == False:</p><p> for record in records:</p><p> starttime = datetime.fromtimestamp(int(record['StartTime'][6:-7])/1000.0) </p><p> endtime = datetime.fromtimestamp(int(record['EndTime'][6:-7])/1000.0)</p><p></p><p> diff = starttime - datenow</p><p> mindiff = divmod(diff.days * 86400 + diff.seconds, 60)[0]</p><p></p><p> # We power on computer if the recording starts in between 1 and 5 minutes</p><p> if mindiff >= 1 and mindiff <= 5:</p><p> startrecord = True</p><p> logging.info("We can power on computer, the recording " + record['Title'] + " " + str(starttime) + "->" + str(endtime) + " will start soon")</p><p> break</p><p> else:</p><p> logging.info("This recording " + record['Title'] + " " + str(starttime) + "->" + str(endtime) + " won't start soon")</p><p></p><p> # We power on computer</p><p> if startrecord == True: </p><p> wol.send_magic_packet('ec.a8.6b.ff.1b.33')</p><p> logging.info("Powering computer...")</p><p> else:</p><p> logging.info("We found recordings, computer is off but no need to power on")</p><p> else:</p><p> logging.info("We found recordings but computer is already on")</p><p>else:</p><p> logging.info("We didn't find recording")</p><p></p><p>logging.info("End of program\n")</p><p></p><p>[/code]</p></blockquote><p></p>
[QUOTE="rasmu, post: 1110229, member: 150544"] Here is the final script : [code] # -*- coding: utf-8 -*- import urllib2, base64, sys, json, logging from wakeonlan import wol from datetime import datetime, date, time #MPExtended credentials username = '' password = '' result = '' online = False startrecord = False records = None num_records = 0 datenow = datetime.now() file_recordings = 'recordings.txt' file_log = 'log.txt' # Create logger logging.basicConfig(level=logging.INFO, format='%(asctime)s %(levelname)s %(message)s', filename=file_log, filemode='a') # Try to get the recordings from Mediaportal try: # Computer is powered on request = urllib2.Request("http://192.168.0.32:4322/MPExtended/TVAccessService/json/GetSchedules") base64string = base64.encodestring('%s:%s' % (username, password)).replace('\n', '') request.add_header("Authorization", "Basic %s" % base64string) result = urllib2.urlopen(request, timeout=2) f = open(file_recordings, 'w') f.write(result.read()) f.close() logging.info("Populate recordings from Mediaportal done") online = True except Exception, e: # computer is away logging.info("Can't connect to computer : " + str(e)) # Try to get the recordings from file try: f = open(file_recordings, 'r') records = json.loads(f.read()) f.close() num_records = len(records) if num_records > 0: logging.info(str(num_records) + " recordings found from local file") else: logging.info("No recording were from local file") except Exception, e: logging.info("Can't find recording from local file : " + str(e)) # We found recordings and computer is off if num_records > 0: if online == False: for record in records: starttime = datetime.fromtimestamp(int(record['StartTime'][6:-7])/1000.0) endtime = datetime.fromtimestamp(int(record['EndTime'][6:-7])/1000.0) diff = starttime - datenow mindiff = divmod(diff.days * 86400 + diff.seconds, 60)[0] # We power on computer if the recording starts in between 1 and 5 minutes if mindiff >= 1 and mindiff <= 5: startrecord = True logging.info("We can power on computer, the recording " + record['Title'] + " " + str(starttime) + "->" + str(endtime) + " will start soon") break else: logging.info("This recording " + record['Title'] + " " + str(starttime) + "->" + str(endtime) + " won't start soon") # We power on computer if startrecord == True: wol.send_magic_packet('ec.a8.6b.ff.1b.33') logging.info("Powering computer...") else: logging.info("We found recordings, computer is off but no need to power on") else: logging.info("We found recordings but computer is already on") else: logging.info("We didn't find recording") logging.info("End of program\n") [/code] [/QUOTE]
Insert quotes…
Verification
Post reply
Forums
MediaPortal 1
WebService and Mobile Access
Popular Plugins
MPExtended
json/getschedules startime and endtime
Contact us
RSS
Top
Bottom