summaryrefslogtreecommitdiff
path: root/plugin.video.embycon/resources/lib/server_sessions.py
blob: feb9efde2bd0d450e4af95bf34e3eb6e6b395960 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64

import json
import sys
import xbmcgui
import xbmcplugin

from downloadutils import DownloadUtils
from simple_logging import SimpleLogging

log = SimpleLogging(__name__)

def showServerSessions():
    log.debug("showServerSessions Called")

    handle = int(sys.argv[1])
    downloadUtils = DownloadUtils()
    url = "{server}/emby/Sessions"
    result_data = downloadUtils.downloadUrl(url)
    results = json.loads(result_data)

    if results is None:
        return

    list_items = []
    for session in results:
        device_name = session.get("DeviceName", "na")
        user_name = session.get("UserName", "na")
        client_name = session.get("Client", "na")

        session_info = device_name + " - " + user_name + " - " + client_name

        # playstate
        percenatge_played = 0
        play_state = session.get("PlayState", None)
        if play_state is not None:
            runtime = 0
            media_id = play_state.get("MediaSourceId", None)
            log.debug("Media ID: {0}", media_id)
            if media_id is not None:
                url = "{server}/emby/Users/{userid}/Items/" + media_id + "?format=json"
                jsonData = downloadUtils.downloadUrl(url)
                media_info = json.loads(jsonData)
                log.debug("Media Info: {0}", media_info)
                runtime = media_info.get("RunTimeTicks", 0)
                log.debug("Media Runtime: {0}", runtime)

            position_ticks = play_state.get("PositionTicks", 0)
            log.debug("Media PositionTicks: {0}", position_ticks)
            if position_ticks > 0 and runtime > 0:
                percenatge_played = (position_ticks / float(runtime)) * 100.0
                percenatge_played = int(percenatge_played)

        now_playing = session.get("NowPlayingItem", None)
        log.debug("NOW_PLAYING: {0}", now_playing)
        if now_playing is not None:
            session_info += " (" + now_playing.get("Name", "na") + " " + str(percenatge_played) + "%)"

        log.debug("session_info: {0}", session_info)
        list_item = xbmcgui.ListItem(label=session_info)
        item_tuple = ("", list_item, False)
        list_items.append(item_tuple)

    xbmcplugin.addDirectoryItems(handle, list_items)
    xbmcplugin.endOfDirectory(handle, cacheToDisc=False)