diff options
author | Indrajith K L | 2021-06-09 00:43:29 +0530 |
---|---|---|
committer | Indrajith K L | 2021-06-09 00:43:29 +0530 |
commit | b2f9a3a474e9e761c382bad64e9f006adc7d607b (patch) | |
tree | aeb846f784970713cc59af63647d26ccac6429dd /plugin.retrowave.indrajith/addon.py | |
download | retrowave-music-player-kodi-b2f9a3a474e9e761c382bad64e9f006adc7d607b.tar.gz retrowave-music-player-kodi-b2f9a3a474e9e761c382bad64e9f006adc7d607b.tar.bz2 retrowave-music-player-kodi-b2f9a3a474e9e761c382bad64e9f006adc7d607b.zip |
Initial Commit
* Working Media Player
* Adds Album Art
TODO: Adds Pagination
Diffstat (limited to 'plugin.retrowave.indrajith/addon.py')
-rw-r--r-- | plugin.retrowave.indrajith/addon.py | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/plugin.retrowave.indrajith/addon.py b/plugin.retrowave.indrajith/addon.py new file mode 100644 index 0000000..ea0f558 --- /dev/null +++ b/plugin.retrowave.indrajith/addon.py @@ -0,0 +1,57 @@ +import os +import sys +import urllib +import xbmcaddon +import xbmc +import xbmcgui +import xbmcplugin +import requests +from urllib.parse import parse_qs, urlencode + + +def build_url(query): + base_url = sys.argv[0] + dialog = xbmcgui.Dialog() + dialog.notification('RetroWave Player', 'Base Url: '+base_url, xbmcgui.NOTIFICATION_INFO, 5000) + return base_url + '?' + urlencode(query) + + +def getMusicList(): + song_list = [] + URL = "http://retrowave.ru/api/v1/tracks" + PARAMS = {'cursor': 1, 'limit': 3} + r = requests.get(url=URL, params=PARAMS) + data = r.json() + for song in data['body']['tracks']: + li = xbmcgui.ListItem(label=song['title']) + li.setArt({'thumb': 'http://retrowave.ru/' + song['artworkUrl'], 'fanart': 'http://retrowave.ru/' + song['artworkUrl']}) + url = build_url({'mode': 'stream', 'url': 'http://retrowave.ru' + song['streamUrl'], 'title': song['title'], 'artwork': 'http://retrowave.ru/' + song['artworkUrl']}) + song_list.append((url, li, False)) + + xbmcplugin.addDirectoryItems(addon_handle, song_list, len(song_list)) + xbmcplugin.setContent(addon_handle, 'songs') + xbmcplugin.endOfDirectory(addon_handle) + +def play_song(url,title, artwork): + play_item = xbmcgui.ListItem(path=url,label=title) + play_item.setArt({'thumb': artwork, 'fanart': artwork}) + + dialog = xbmcgui.Dialog() + # dialog.notification('RetroWave Player', 'Mode: '+url, xbmcgui.NOTIFICATION_INFO, 5000) + # xbmcplugin.setResolvedUrl(addon_handle, True, listitem=play_item) + xbmc.Player().play(item=url, listitem=play_item) + +def main(): + args = parse_qs(sys.argv[2][1:]) + mode = args.get('mode', None) + + if mode is None: + getMusicList() + elif mode[0] == 'stream': + dialog = xbmcgui.Dialog() + dialog.notification('RetroWave Player', 'Mode: '+args['title'][0], xbmcgui.NOTIFICATION_INFO, 5000) + play_song(args['url'][0], args['title'][0], args['artwork'][0]) + +if __name__ == '__main__': + addon_handle = int(sys.argv[1]) + main() |