add docstrings to python code

This commit is contained in:
geoffrey45
2022-02-06 23:26:22 +03:00
parent 195a50382a
commit 60ba512e64
13 changed files with 407 additions and 277 deletions
+107 -99
View File
@@ -1,13 +1,14 @@
import os
import urllib
from typing import List
from flask import Blueprint, request
from app import functions, instances, helpers, cache
bp = Blueprint('api', __name__, url_prefix='')
bp = Blueprint("api", __name__, url_prefix="")
home_dir = helpers.home_dir
all_the_f_music = helpers.getAllSongs()
all_the_f_music = helpers.get_all_songs()
def initialize() -> None:
@@ -15,45 +16,58 @@ def initialize() -> None:
Runs all the necessary setup functions.
"""
helpers.create_config_dir()
# helpers.check_for_new_songs()
helpers.check_for_new_songs()
initialize()
@bp.route('/')
def adutsfsd():
@bp.route("/")
def say_hi():
"""Returns some text for the default route"""
return "^ _ ^"
@bp.route('/search')
def get_tracks(query: str) -> List:
"""
Gets all songs with a given title.
"""
return [track for track in all_the_f_music if query.lower() in track.title.lower()]
def get_search_albums(query: str) -> List:
"""
Gets all songs with a given album.
"""
return [track for track in all_the_f_music if query.lower() in track.album.lower()]
def get_artists(artist: str) -> List:
"""
Gets all songs with a given artist.
"""
return [
track
for track in all_the_f_music
if artist.lower() in str(track.artists).lower()
]
@bp.route("/search")
def search_by_title():
if not request.args.get('q'):
query:str = "mexican girl"
else:
query:str = str(request.args.get('q'))
albums = []
artists = []
tracks = []
"""
Returns a list of songs, albums and artists that match the search query.
"""
query = request.args.get("q") or "Mexican girl"
albums = get_search_albums(query)
albums_dicts = []
artists_dicts = []
for track in all_the_f_music:
if query.lower() in track.title.lower():
tracks.append(track)
if query.lower() in track.album.lower():
albums.append(track)
if query.lower() in str(track.artists).lower():
artists.append(track)
for song in albums:
album_obj = {
"name": song.album,
"artist": song.album_artist,
"artist": song.albumartist,
}
if album_obj not in albums_dicts:
@@ -61,61 +75,52 @@ def search_by_title():
for album in albums_dicts:
for track in albums:
if album['name'] == track.album:
album['image'] = track.image
if album["name"] == track.album:
album["image"] = track.image
for song in artists:
for song in get_artists(query):
for artist in song.artists:
if query.lower() in artist.lower():
artist_obj = {
"name": artist,
"image": "http://0.0.0.0:8900/images/artists/" + artist.replace("/", "::") + ".webp"
"image": "http://0.0.0.0:8900/images/artists/"
+ artist.replace("/", "::")
+ ".webp",
}
if artist_obj not in artists_dicts:
artists_dicts.append(artist_obj)
tracks = helpers.remove_duplicates(tracks)
tracks = helpers.remove_duplicates(get_tracks(query))
if len(tracks) > 5:
more_tracks = True
else:
more_tracks = False
if len(artists_dicts) > 6:
more_artists = True
else:
more_artists = False
if len(albums_dicts) > 6:
more_albums = True
else:
more_albums = False
return {'data': [
{'tracks': tracks[:5], 'more': more_tracks},
{'albums': albums_dicts[:6], 'more': more_albums},
{'artists': artists_dicts[:6], 'more': more_artists}
]}
return {
"data": [
{"tracks": tracks[:5], "more": len(tracks) > 5},
{"albums": albums_dicts[:6], "more": len(albums_dicts) > 6},
{"artists": artists_dicts[:6], "more": len(artists_dicts) > 6},
]
}
@bp.route('/populate')
def x():
@bp.route("/populate")
def find_tracks():
"""call the populate function"""
functions.populate()
return "🎸"
@bp.route("/album/<album>/<artist>/artists")
@cache.cached()
def get_album_artists(album, artist):
album = album.replace('|', '/')
artist = artist.replace('|', '/')
def get_albumartists(album, artist):
"""Returns a list of artists featured in a given album."""
album = album.replace("|", "/")
artist = artist.replace("|", "/")
tracks = []
for track in all_the_f_music:
if track.album == album and track.album_artist == artist:
if track.album == album and track.albumartist == artist:
tracks.append(track)
artists = []
@@ -129,11 +134,13 @@ def get_album_artists(album, artist):
for artist in artists:
artist_obj = {
"name": artist,
"image": "http://0.0.0.0:8900/images/artists/" + artist.replace('/', '::') + ".webp"
"image": "http://0.0.0.0:8900/images/artists/"
+ artist.replace("/", "::")
+ ".webp",
}
final_artists.append(artist_obj)
return {'artists': final_artists}
return {"artists": final_artists}
@bp.route("/populate/images")
@@ -144,55 +151,54 @@ def populate_images():
@bp.route("/artist/<artist>")
@cache.cached()
def getArtistData(artist: str):
print(artist)
def get_artist_data(artist: str):
"""Returns the artist's data, tracks and albums"""
artist = urllib.parse.unquote(artist)
artist_obj = instances.artist_instance.get_artists_by_name(artist)
def getArtistSongs():
def get_artist_tracks():
songs = instances.songs_instance.find_songs_by_artist(artist)
return songs
artist_songs = getArtistSongs()
artist_songs = get_artist_tracks()
songs = helpers.remove_duplicates(artist_songs)
def getArtistAlbums():
def get_artist_albums():
artist_albums = []
albums_with_count = []
albums = instances.songs_instance.find_songs_by_album_artist(artist)
albums = instances.songs_instance.find_songs_by_albumartist(artist)
for song in albums:
if song['album'] not in artist_albums:
artist_albums.append(song['album'])
if song["album"] not in artist_albums:
artist_albums.append(song["album"])
for album in artist_albums:
count = 0
length = 0
for song in artist_songs:
if song['album'] == album:
if song["album"] == album:
count = count + 1
length = length + song['length']
length = length + song["length"]
album_ = {
"title": album,
"count": count,
"length": length
}
album_ = {"title": album, "count": count, "length": length}
albums_with_count.append(album_)
return albums_with_count
return {'artist': artist_obj, 'songs': songs, 'albums': getArtistAlbums()}
return {"artist": artist_obj, "songs": songs, "albums": get_artist_albums()}
@bp.route("/f/<folder>")
@cache.cached()
def getFolderTree(folder: str):
req_dir = folder.replace('|', '/')
def get_folder_tree(folder: str):
"""
Returns a list of all the folders and tracks in the given folder.
"""
req_dir = folder.replace("|", "/")
if folder == "home":
req_dir = home_dir
@@ -202,9 +208,8 @@ def getFolderTree(folder: str):
folders = []
for entry in dir_content:
if entry.is_dir() and not entry.name.startswith('.'):
files_in_dir = helpers.run_fast_scandir(
entry.path, [".flac", ".mp3"])[1]
if entry.is_dir() and not entry.name.startswith("."):
files_in_dir = helpers.run_fast_scandir(entry.path, [".flac", ".mp3"])[1]
if len(files_in_dir) != 0:
_dir = {
@@ -221,35 +226,36 @@ def getFolderTree(folder: str):
if track.folder == req_dir:
songs.append(track)
return {"files": helpers.remove_duplicates(songs), "folders": sorted(folders, key=lambda i: i['name'])}
return {
"files": helpers.remove_duplicates(songs),
"folders": sorted(folders, key=lambda i: i["name"]),
}
@bp.route('/albums')
def getAlbums():
@bp.route("/albums")
def get_albums():
"""returns all the albums"""
s = instances.songs_instance.get_all_songs()
albums = []
for song in s:
al_obj = {
"name": song['album'],
"artist": song['artists']
}
al_obj = {"name": song["album"], "artist": song["artists"]}
if al_obj not in albums:
albums.append(al_obj)
return {'albums': albums}
return {"albums": albums}
@bp.route('/album/<title>/<artist>/tracks')
@bp.route("/album/<title>/<artist>/tracks")
@cache.cached()
def get_album_tracks(title:str, artist:str):
def get_album_tracks(title: str, artist: str):
"""Returns all the tracks in the given album."""
songs = []
for track in all_the_f_music:
if track.album_artist == artist and track.album == title:
if track.albumartist == artist and track.album == title:
songs.append(track)
songs = helpers.remove_duplicates(songs)
@@ -259,16 +265,18 @@ def get_album_tracks(title:str, artist:str):
"count": len(songs),
"duration": "56 Minutes",
"image": songs[0].image,
"artist": songs[0].album_artist,
"artist_image": "http://127.0.0.1:8900/images/artists/" + songs[0].album_artist.replace('/', '::') + ".webp"
"artist": songs[0].albumartist,
"artist_image": "http://127.0.0.1:8900/images/artists/"
+ songs[0].albumartist.replace("/", "::")
+ ".webp",
}
return {'songs': songs, 'info': album_obj}
return {"songs": songs, "info": album_obj}
@bp.route('/album/<title>/<artist>/bio')
@bp.route("/album/<title>/<artist>/bio")
@cache.cached()
def drop_db(title, artist):
bio = functions.getAlbumBio(title, artist)
return {'bio': bio}, 200
def get_album_bio(title, artist):
"""Returns the album bio for the given album."""
bio = functions.get_album_bio(title, artist)
return {"bio": bio}, 200