1
0
mirror of https://github.com/krateng/maloja.git synced 2023-08-10 21:12:55 +03:00

Merged remaining references to two uri modules

This commit is contained in:
Krateng 2020-09-02 14:28:04 +02:00
parent ed1c595e20
commit a6088ec7b7
11 changed files with 18 additions and 186 deletions

View File

@ -5,7 +5,7 @@ author = {
"email":"maloja@krateng.dev", "email":"maloja@krateng.dev",
"github": "krateng" "github": "krateng"
} }
version = 2,8,4 version = 2,8,5
versionstr = ".".join(str(n) for n in version) versionstr = ".".join(str(n) for n in version)
links = { links = {
"pypi":"malojaserver", "pypi":"malojaserver",

View File

@ -5,7 +5,7 @@ from bottle import request, response, FormsDict
from .cleanup import CleanerAgent, CollectorAgent from .cleanup import CleanerAgent, CollectorAgent
from . import utilities from . import utilities
from .malojatime import register_scrobbletime, time_stamps, ranges from .malojatime import register_scrobbletime, time_stamps, ranges
from .urihandler import uri_to_internal, internal_to_uri, compose_querystring from .malojauri import uri_to_internal, internal_to_uri, compose_querystring
from . import compliant_api from . import compliant_api
from .thirdparty import proxy_scrobble_all from .thirdparty import proxy_scrobble_all

View File

@ -1,7 +1,7 @@
from .. import database_packed from .. import database_packed
from . import filters from . import filters
from .. import database, database_packed, malojatime, utilities, urihandler, malojauri from .. import database, database_packed, malojatime, utilities, malojauri
from doreah import settings from doreah import settings
from doreah.regular import repeatdaily from doreah.regular import repeatdaily
@ -29,7 +29,6 @@ def update_jinja_environment():
"dbp":dbp, "dbp":dbp,
"malojatime": malojatime, "malojatime": malojatime,
"utilities": utilities, "utilities": utilities,
"urihandler": urihandler,
"mlj_uri": malojauri, "mlj_uri": malojauri,
"settings": settings.get_settings, "settings": settings.get_settings,
# external # external

View File

@ -63,11 +63,14 @@ def uri_to_internal(keys,forceTrack=False,forceArtist=False):
def create_uri(path,*keydicts): def create_uri(path,*keydicts):
return path + "?" + uriencode(*keydicts)
def uriencode(*keydicts):
keyd = {} keyd = {}
for kd in keydicts: for kd in keydicts:
keyd.update(kd) keyd.update(kd)
return path + "?" + compose_querystring(internal_to_uri(keyd)) return compose_querystring(internal_to_uri(keyd))
def internal_to_uri(keys): def internal_to_uri(keys):

View File

@ -15,9 +15,7 @@ from . import malojatime
from . import utilities from . import utilities
from . import malojauri from . import malojauri
from .utilities import resolveImage from .utilities import resolveImage
from .urihandler import remove_identical from .malojauri import uri_to_internal, remove_identical
from .malojauri import uri_to_internal
from . import urihandler
from . import globalconf from . import globalconf
from .jinjaenv.context import jinja_environment from .jinjaenv.context import jinja_environment
# doreah toolkit # doreah toolkit

View File

@ -1,167 +0,0 @@
import urllib
from bottle import FormsDict
from .malojatime import time_fix, time_str, get_range_object
import math
# necessary because urllib.parse.urlencode doesnt handle multidicts
def compose_querystring(*dicts,exclude=[]):
st = ""
keys = remove_identical(*dicts)
for k in keys:
if k in exclude: continue
values = keys.getall(k)
st += "&".join([urllib.parse.urlencode({k:v},safe="/") for v in values])
st += "&"
return st
# takes any number of multidicts and normal dicts and creates a formsdict with duplicate values removed
def remove_identical(*dicts):
#combine multiple dicts
keys = FormsDict()
for d in dicts:
for k in d:
try: #multidicts
for v in d.getall(k):
keys.append(k,v)
except: #normaldicts
v = d.get(k)
keys.append(k,v)
new = FormsDict()
for k in keys:
#values = set(keys.getall(k))
values = keys.getall(k) # NO IDENTICAL REMOVAL FOR NOW
for v in values:
new.append(k,v)
return new
# this also sets defaults!
def uri_to_internal(keys,forceTrack=False,forceArtist=False):
# output:
# 1 keys that define the filtered object like artist or track
# 2 keys that define time limits of the whole thing
# 3 keys that define interal time ranges
# 4 keys that define amount limits
# 1
if "title" in keys and not forceArtist:
resultkeys1 = {"track":{"artists":keys.getall("artist"),"title":keys.get("title")}}
elif "artist" in keys and not forceTrack:
resultkeys1 = {"artist":keys.get("artist")}
if "associated" in keys: resultkeys1["associated"] = True
else:
resultkeys1 = {}
# 2
resultkeys2 = {}
# if "since" in keys: resultkeys2["since"] = time_fix(keys.get("since"))
# elif "from" in keys: resultkeys2["since"] = time_fix(keys.get("from"))
# elif "start" in keys: resultkeys2["since"] = time_fix(keys.get("start"))
# #
# if "to" in keys: resultkeys2["to"] = time_fix(keys.get("to"))
# elif "until" in keys: resultkeys2["to"] = time_fix(keys.get("until"))
# elif "end" in keys: resultkeys2["to"] = time_fix(keys.get("end"))
# #
# if "since" in resultkeys2 and "to" in resultkeys2 and resultkeys2["since"] == resultkeys2["to"]:
# resultkeys2["within"] = resultkeys2["since"]
# del resultkeys2["since"]
# del resultkeys2["to"]
# #
# if "in" in keys: resultkeys2["within"] = time_fix(keys.get("in"))
# elif "within" in keys: resultkeys2["within"] = time_fix(keys.get("within"))
# elif "during" in keys: resultkeys2["within"] = time_fix(keys.get("during"))
# if "within" in resultkeys2:
# if "since" in resultkeys2:
# del resultkeys2["since"]
# if "to" in resultkeys2:
# del resultkeys2["to"]
since,to,within = None,None,None
if "since" in keys: since = keys.get("since")
elif "from" in keys: since = keys.get("from")
elif "start" in keys: since = keys.get("start")
if "to" in keys: to = keys.get("to")
elif "until" in keys: to = keys.get("until")
elif "end" in keys: to = keys.get("end")
if "in" in keys: within = keys.get("in")
elif "within" in keys: within = keys.get("within")
elif "during" in keys: within = keys.get("during")
resultkeys2["timerange"] = get_range_object(since=since,to=to,within=within)
#3
resultkeys3 = {"step":"month","stepn":1,"trail":1}
if "step" in keys: [resultkeys3["step"],resultkeys3["stepn"]] = (keys["step"].split("-") + [1])[:2]
if "stepn" in keys: resultkeys3["stepn"] = keys["stepn"] #overwrite if explicitly given
if "stepn" in resultkeys3: resultkeys3["stepn"] = int(resultkeys3["stepn"]) #in both cases, convert it here
if "trail" in keys: resultkeys3["trail"] = int(keys["trail"])
if "cumulative" in keys: resultkeys3["trail"] = math.inf
#4
resultkeys4 = {"page":0,"perpage":100}
# if "max" in keys: resultkeys4["max_"] = int(keys["max"])
if "max" in keys: resultkeys4["page"],resultkeys4["perpage"] = 0, int(keys["max"])
#different max than the internal one! the user doesn't get to disable pagination
if "page" in keys: resultkeys4["page"] = int(keys["page"])
if "perpage" in keys: resultkeys4["perpage"] = int(keys["perpage"])
return resultkeys1, resultkeys2, resultkeys3, resultkeys4
def compose_from_dicts(*dicts):
return compose_querystring(internal_to_uri_p(*dicts))
def internal_to_uri_p(*dicts):
return internal_to_uri({k:d[k] for d in dicts for k in d})
def internal_to_uri(keys):
urikeys = FormsDict()
#filter
if "artist" in keys:
urikeys.append("artist",keys["artist"])
if keys.get("associated"): urikeys.append("associated","yes")
elif "track" in keys:
for a in keys["track"]["artists"]:
urikeys.append("artist",a)
urikeys.append("title",keys["track"]["title"])
#time
if "timerange" in keys:
keydict = keys["timerange"].urikeys()
for k in keydict:
urikeys.append(k,keydict[k])
elif "within" in keys:
urikeys.append("in",time_str(keys["within"]))
else:
if "since" in keys and keys["since"] is not None:
urikeys.append("since",time_str(keys["since"]))
if "to" in keys and keys["to"] is not None:
urikeys.append("to",time_str(keys["to"]))
# delimit
if "step" in keys:
urikeys.append("step",keys["step"])
if "stepn" in keys:
urikeys.append("stepn",str(keys["stepn"]))
if "trail" in keys:
if keys["trail"] == math.inf:
urikeys.append("cumulative","yes")
else:
urikeys.append("trail",str(keys["trail"]))
# stuff
#if "max_" in keys:
# urikeys.append("max",str(keys["max_"]))
if "page" in keys:
urikeys.append("page",str(keys["page"]))
if "perpage" in keys:
urikeys.append("perpage",str(keys["perpage"]))
return urikeys

View File

@ -24,8 +24,7 @@
{% endif %} {% endif %}
{% set encodedartist = urihandler.compose_querystring(urihandler.internal_to_uri({'artist':artist})) %} {% set encodedartist = mlj_uri.uriencode({'artist':artist}) %}
{% set encodedcredited = urihandler.compose_querystring(urihandler.internal_to_uri({'artist':credited})) %}
{% block content %} {% block content %}
@ -57,7 +56,7 @@
<span>Competing under {{ links.link(credited) }} (#{{ info.position }})</span> <span>Competing under {{ links.link(credited) }} (#{{ info.position }})</span>
{% endif %} {% endif %}
<p class="stats"><a href="/scrobbles?{{ encodedartist }}">{{ info['scrobbles'] }} Scrobbles</a></p> <p class="stats"><a href="{{ mlj_uri.create_uri("/scrobbles",filterkeys) }}">{{ info['scrobbles'] }} Scrobbles</a></p>
@ -115,7 +114,7 @@
</td> </td>
<td> <td>
<!-- We use the same classes / function calls here because we want it to switch together with pulse --> <!-- We use the same classes / function calls here because we want it to switch together with pulse -->
<h2 class="headerwithextra"><a href='{{ mlj_uri.create_uri("/performance",filterkeys) }}'>Performance</a></h2> <h2 class="headerwithextra"><a href='{{ mlj_uri.create_uri("/performance",{'artist':credited}) }}'>Performance</a></h2>
{% if not competes %}<span class="afterheader">of {{ links.link(credited) }}</span> {% if not competes %}<span class="afterheader">of {{ links.link(credited) }}</span>
{% endif %} {% endif %}
<br/> <br/>

View File

@ -31,7 +31,7 @@
{% macro topweeks(info) %} {% macro topweeks(info) %}
{% set encodedartist = urihandler.compose_querystring(urihandler.internal_to_uri({'artist':info.artist})) %} {% set encodedartist = mlj_uri.uriencode({'artist':info.artist}) %}
<!-- TOPWEEKS --> <!-- TOPWEEKS -->

View File

@ -28,7 +28,7 @@
{% macro topweeks(info) %} {% macro topweeks(info) %}
{% set encodedtrack = urihandler.compose_querystring(urihandler.internal_to_uri({'track':info.track})) %} {% set encodedtrack = mlj_uri.uriencode({'track':info.track}) %}
<!-- TOPWEEKS --> <!-- TOPWEEKS -->
<span> <span>

View File

@ -9,7 +9,7 @@
{% if pages > 1 %} {% if pages > 1 %}
{% if page > 1 %} {% if page > 1 %}
<a href='?{{ urihandler.compose_from_dicts(filterkeys,limitkeys,delimitkeys,amountkeys,{'page':0}) }}'> <a href='{{ mlj_uri.create_uri("",filterkeys,limitkeys,delimitkeys,amountkeys,{'page':0}) }}'>
<span class='stat_selector'>1</span> <span class='stat_selector'>1</span>
</a> | </a> |
{% endif %} {% endif %}
@ -19,7 +19,7 @@
{% endif %} {% endif %}
{% if page > 0 %} {% if page > 0 %}
<a href='?{{ urihandler.compose_from_dicts(filterkeys,limitkeys,delimitkeys,amountkeys,{'page':page-1}) }}'> <a href='{{ mlj_uri.create_uri("",filterkeys,limitkeys,delimitkeys,amountkeys,{'page':page-1}) }}'>
<span class='stat_selector'>{{ page }}</span> <span class='stat_selector'>{{ page }}</span>
</a> « </a> «
{% endif %} {% endif %}
@ -29,7 +29,7 @@
</span> </span>
{% if page < pages-1 %} {% if page < pages-1 %}
» <a href='?{{ urihandler.compose_from_dicts(filterkeys,limitkeys,delimitkeys,amountkeys,{'page':page+1}) }}'> » <a href='{{ mlj_uri.create_uri("",filterkeys,limitkeys,delimitkeys,amountkeys,{'page':page+1}) }}'>
<span class='stat_selector'>{{ page+2 }}</span> <span class='stat_selector'>{{ page+2 }}</span>
</a> </a>
{% endif %} {% endif %}
@ -39,7 +39,7 @@
{% endif %} {% endif %}
{% if page < pages-2 %} {% if page < pages-2 %}
| <a href='?{{ urihandler.compose_from_dicts(filterkeys,limitkeys,delimitkeys,amountkeys,{'page':pages-1}) }}'> | <a href='{{ mlj_uri.create_uri("",filterkeys,limitkeys,delimitkeys,amountkeys,{'page':pages-1}) }}'>
<span class='stat_selector'>{{ pages }}</span> <span class='stat_selector'>{{ pages }}</span>
</a> </a>
{% endif %} {% endif %}

View File

@ -18,7 +18,7 @@
{% set initialrange ='month' %} {% set initialrange ='month' %}
{% set encodedtrack = urihandler.compose_querystring(urihandler.internal_to_uri({'track':track})) %} {% set encodedtrack = mlj_uri.uriencode({'track':track}) %}
{% block content %} {% block content %}