Compare commits

..

2 Commits

7 changed files with 82 additions and 18 deletions

View File

@ -1,5 +1,6 @@
import src.fw_artists import src.fw_artists
from src.fw_api import get_artists, get_tracks, get_albums, get_audio_file from src.fw_api import get_artists, get_tracks, get_albums, get_audio_file
from src.fw_libraries import libraries
from src.settings import get_config from src.settings import get_config
from src.mpv_control import player, player_menu, track_url_to_uuid from src.mpv_control import player, player_menu, track_url_to_uuid
from pyfzf.pyfzf import FzfPrompt from pyfzf.pyfzf import FzfPrompt
@ -9,13 +10,13 @@ fzf = FzfPrompt()
@logger.catch @logger.catch
def list_albums(albums=None, pg=None, search=None, artist=None, include_channels=None, refresh=False): def list_albums(albums=None, pg=None, search=None, artist=None, library=None, include_channels=None, refresh=False):
show_artist_name_in_albums = get_config('show_artist_name_in_albums') show_artist_name_in_albums = get_config('show_artist_name_in_albums')
albums_next = None albums_next = None
albums_prev = None albums_prev = None
play_artist_albums = False play_artist_albums = False
if not albums: if not albums:
albums = get_albums(q=search, artist=artist, albums = get_albums(q=search, artist=artist, library=library,
include_channels=include_channels, refresh=refresh, pg=pg) include_channels=include_channels, refresh=refresh, pg=pg)
albums_next = albums.get('next') albums_next = albums.get('next')
albums_prev = albums.get('previous') albums_prev = albums.get('previous')
@ -25,7 +26,7 @@ def list_albums(albums=None, pg=None, search=None, artist=None, include_channels
else: else:
play_artist_albums = True play_artist_albums = True
albums_results = albums albums_results = albums
view = ['Search'] view = ['Search', 'Library']
if play_artist_albums: if play_artist_albums:
view.append('Play all') view.append('Play all')
if albums_next: if albums_next:
@ -50,6 +51,9 @@ def list_albums(albums=None, pg=None, search=None, artist=None, include_channels
elif select == 'Search': elif select == 'Search':
print('Search by albums: ') print('Search by albums: ')
list_albums(search=input()) list_albums(search=input())
elif select == 'Library':
select_lib = libraries()
list_albums(library=select_lib)
elif select == 'Play all': elif select == 'Play all':
if artist: if artist:
src.fw_artists.play_artist(artist) src.fw_artists.play_artist(artist)

View File

@ -88,7 +88,7 @@ def get_audio_file(track_uuid, listen_url=False, download=False,
@logger.catch @logger.catch
def get_tracks(page=None, q=None, artist=None, album=None, def get_tracks(page=None, q=None, artist=None, album=None, library=None,
tag=None, favourites=None, include_channels=None, pg=None): tag=None, favourites=None, include_channels=None, pg=None):
'''This function get tracks by params''' '''This function get tracks by params'''
params = { params = {
@ -98,6 +98,7 @@ def get_tracks(page=None, q=None, artist=None, album=None,
'album': album, 'album': album,
'tag': tag, 'tag': tag,
'favourites': favourites, 'favourites': favourites,
'library': library,
'include_channels': include_channels 'include_channels': include_channels
} }
if pg: if pg:
@ -126,13 +127,15 @@ def get_favorires_tracks(page=None, q=None, scope=None, include_channels=None, p
@logger.catch @logger.catch
def get_artists(page=None, q=None, artist=None, album=None, favourites=None, refresh=False, pg=None): def get_artists(page=None, q=None, artist=None, album=None,
library=None, favourites=None, refresh=False, pg=None):
'''This function get artists by params''' '''This function get artists by params'''
params = { params = {
'page': page, 'page': page,
'q': q, 'q': q,
'artist': artist, 'artist': artist,
'album': album, 'album': album,
'library': library,
'favourites': favourites, 'favourites': favourites,
'refresh': refresh 'refresh': refresh
} }
@ -145,12 +148,13 @@ def get_artists(page=None, q=None, artist=None, album=None, favourites=None, ref
@logger.catch @logger.catch
def get_albums(page=None, q=None, artist=None, include_channels=None, refresh=False, pg=None): def get_albums(page=None, q=None, artist=None, library=None, include_channels=None, refresh=False, pg=None):
'''This function get artists by params''' '''This function get artists by params'''
params = { params = {
'page': page, 'page': page,
'q': q, 'q': q,
'artist': artist, 'artist': artist,
'library': library,
'include_channels': include_channels, 'include_channels': include_channels,
'refresh': refresh 'refresh': refresh
} }
@ -245,6 +249,25 @@ def federate_search_by_url(object):
return r.json() return r.json()
@logger.catch
def federate_remote_library(fid):
'''Fetch remote library for follow and scan'''
params = {
'fid': fid
}
r = current_instance.s.post(
f'https://{current_instance.instance}/api/v1/federation/libraries/fetch', json=params)
return r.json()
@logger.catch
def scan_remote_library(uuid):
'''Scan remote library'''
r = current_instance.s.post(
f'https://{current_instance.instance}/api/v1/federation/libraries/{uuid}')
return r.json()
@logger.catch @logger.catch
def record_track_in_history(track_id): def record_track_in_history(track_id):
params = { params = {

View File

@ -1,5 +1,6 @@
from src.fw_api import get_artists, get_tracks, get_audio_file from src.fw_api import get_artists, get_tracks, get_audio_file
from src.fw_albums import list_albums from src.fw_albums import list_albums
from src.fw_libraries import libraries
from src.mpv_control import player, player_menu, track_url_to_uuid from src.mpv_control import player, player_menu, track_url_to_uuid
from pyfzf.pyfzf import FzfPrompt from pyfzf.pyfzf import FzfPrompt
from loguru import logger from loguru import logger
@ -8,12 +9,12 @@ fzf = FzfPrompt()
@logger.catch @logger.catch
def list_artists(pg=None, search=None): def list_artists(pg=None, search=None, library=None):
artists = get_artists(q=search, pg=pg) artists = get_artists(q=search, library=library, pg=pg)
artists_next = artists.get('next') artists_next = artists.get('next')
artists_prev = artists.get('previous') artists_prev = artists.get('previous')
artists_results = artists.get('results') artists_results = artists.get('results')
view = ['Search'] view = ['Search', 'Library']
if artists_next: if artists_next:
view.append('Next page') view.append('Next page')
if artists_prev: if artists_prev:
@ -31,6 +32,9 @@ def list_artists(pg=None, search=None):
elif select == 'Search': elif select == 'Search':
print('Search by artist:') print('Search by artist:')
list_artists(search=input()) list_artists(search=input())
elif select == 'Library':
select_lib = libraries()
list_artists(library=select_lib)
else: else:
albums = artists_results[int(select)].get('albums') albums = artists_results[int(select)].get('albums')
if albums: if albums:

View File

@ -1,12 +1,13 @@
from src.fw_api import list_libraries from src.fw_api import list_libraries, federate_remote_library, scan_remote_library
from pyfzf.pyfzf import FzfPrompt from pyfzf.pyfzf import FzfPrompt
from loguru import logger from loguru import logger
import time
fzf = FzfPrompt() fzf = FzfPrompt()
@logger.catch @logger.catch
def libraries(pg=None): def libraries(pg=None, radio=False):
libs_res = list_libraries(pg=pg) libs_res = list_libraries(pg=pg)
libs_count = libs_res.get('count') libs_count = libs_res.get('count')
libs_next = libs_res.get('next') libs_next = libs_res.get('next')
@ -17,6 +18,9 @@ def libraries(pg=None):
libraries_listing.append('Next') libraries_listing.append('Next')
if libs_prev: if libs_prev:
libraries_listing.append('Prev') libraries_listing.append('Prev')
if radio == False:
libraries_listing.append('Add remote library')
for lib_i in libs: for lib_i in libs:
index = libs.index(lib_i) index = libs.index(lib_i)
lib_name = lib_i.get('name') lib_name = lib_i.get('name')
@ -28,8 +32,33 @@ def libraries(pg=None):
return libraries(pg=libs_next) return libraries(pg=libs_next)
elif lib_select[0] == 'Prev': elif lib_select[0] == 'Prev':
return libraries(pg=libs_prev) return libraries(pg=libs_prev)
elif lib_select[0] == 'Add remote library':
print('Search a remote library (url\\fid):')
new_library = federate_remote_library(input())
if new_library.get('detail'):
logger.error(new_library['detail'])
return
if new_library.get('count') > 0:
print('Library found')
one_lib = new_library['results'][0]
scan = scan_remote_library(one_lib['uuid'])
if scan.get('detail'):
logger.error(scan['detail'])
return
status = scan['status']
if status == 'scheduled':
print(f'Scanning {status}. Please wait few minutes for scan and open libraries menu again')
else:
print(f'Scan is {status}')
time.sleep(3)
return
else: else:
lib_addr = lib_select[0] lib_addr = lib_select[0]
lib_name = lib_select[1] lib_name = lib_select[1]
lib_uuid = libs[int(lib_addr)].get('uuid') lib_uuid = libs[int(lib_addr)]['uuid']
return None, 'library', lib_name, lib_uuid lib_fid = libs[int(lib_addr)]['fid']
if radio:
return None, 'library', f'{lib_name}\n{lib_fid}', lib_uuid
else:
return lib_uuid

View File

@ -45,7 +45,7 @@ def list_radios():
elif 'Random' in selected: elif 'Random' in selected:
radio_load(id_radio, 'random', name='totally random') radio_load(id_radio, 'random', name='totally random')
elif 'Libraries' in selected: elif 'Libraries' in selected:
id_radio, type_radio, name_radio, related_obj = libraries() id_radio, type_radio, name_radio, related_obj = libraries(radio=True)
radio_load(id_radio, type_radio, name_radio, related_obj) radio_load(id_radio, type_radio, name_radio, related_obj)
elif 'Users' in selected: elif 'Users' in selected:
libs = list_libraries()['results'] libs = list_libraries()['results']

View File

@ -1,5 +1,6 @@
from src.fw_api import get_tracks, get_audio_file from src.fw_api import get_tracks, get_audio_file
from src.fw_tags import list_tags from src.fw_tags import list_tags
from src.fw_libraries import libraries
from src.mpv_control import player, player_menu, track_url_to_uuid, play_track from src.mpv_control import player, player_menu, track_url_to_uuid, play_track
from pyfzf.pyfzf import FzfPrompt from pyfzf.pyfzf import FzfPrompt
from loguru import logger from loguru import logger
@ -8,12 +9,12 @@ fzf = FzfPrompt()
@logger.catch @logger.catch
def list_tracks(pg=None, search=None, tag=None): def list_tracks(pg=None, search=None, tag=None, library=None):
tracks = get_tracks(q=search, pg=pg, tag=tag) tracks = get_tracks(q=search, pg=pg, tag=tag, library=library)
tracks_next = tracks.get('next') tracks_next = tracks.get('next')
tracks_prev = tracks.get('previous') tracks_prev = tracks.get('previous')
tracks_results = tracks.get('results') tracks_results = tracks.get('results')
view = ['Search', 'Tags', 'Play this page'] view = ['Search', 'Tags', 'Library', 'Play this page']
if tracks_next: if tracks_next:
view.append('Next page') view.append('Next page')
if tracks_prev: if tracks_prev:
@ -34,6 +35,9 @@ def list_tracks(pg=None, search=None, tag=None):
elif select == 'Tags': elif select == 'Tags':
select_tag = list_tags() select_tag = list_tags()
list_tracks(tag=select_tag) list_tracks(tag=select_tag)
elif select == 'Library':
select_lib = libraries()
list_tracks(library=select_lib)
elif select == 'Play this page': elif select == 'Play this page':
for i in tracks_results: for i in tracks_results:
play_track(track=i, multi=True) play_track(track=i, multi=True)

View File

@ -92,7 +92,7 @@ def universal_observer(_name, value):
else: else:
cache_speed = '' cache_speed = ''
if player.playlist_count > -1: if player.playlist_count > -1:
player_pos = f'{player.playlist_current_pos}/{player.playlist_count}' player_pos = f'{player.playlist_pos_1}/{player.playlist_count}'
else: else:
player_pos = '-/-' player_pos = '-/-'
print_there(2, 2, f'\r'+' '*get_terminal_size().columns) print_there(2, 2, f'\r'+' '*get_terminal_size().columns)