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

Implemented scrobbling via POST

This commit is contained in:
Krateng 2018-11-30 13:39:12 +01:00
parent 5b0436e256
commit 75a70a10b7
3 changed files with 37 additions and 8 deletions

View File

@ -1,4 +1,4 @@
from bottle import route, run, template, static_file, request, response, FormsDict from bottle import route, get, post, run, template, static_file, request, response, FormsDict
from importlib.machinery import SourceFileLoader from importlib.machinery import SourceFileLoader
import urllib import urllib
import waitress import waitress
@ -96,6 +96,7 @@ def get_scrobbles():
def get_tracks(): def get_tracks():
artist = request.query.get("artist") artist = request.query.get("artist")
if artist is not None:
artistid = ARTISTS.index(artist) artistid = ARTISTS.index(artist)
# Option 1 # Option 1
@ -122,8 +123,8 @@ def get_charts():
#results = db_query(since=since,to=to) #results = db_query(since=since,to=to)
#return {"list":results} #return {"list":results}
@route("/newscrobble") @get("/newscrobble")
def post_scrobble(): def pseudo_post_scrobble():
keys = FormsDict.decode(request.query) # The Dal★Shabet handler keys = FormsDict.decode(request.query) # The Dal★Shabet handler
artists = keys.get("artist") artists = keys.get("artist")
title = keys.get("title") title = keys.get("title")
@ -143,6 +144,27 @@ def post_scrobble():
return "" return ""
@post("/newscrobble")
def post_scrobble():
keys = FormsDict.decode(request.forms) # The Dal★Shabet handler
artists = keys.get("artist")
title = keys.get("title")
try:
time = int(keys.get("time"))
except:
time = int(datetime.datetime.now(tz=datetime.timezone.utc).timestamp())
(artists,title) = c.fullclean(artists,title)
## this is necessary for localhost testing
response.set_header("Access-Control-Allow-Origin","*")
createScrobble(artists,title,time)
if (time - lastsync) > 3600:
sync()
return ""
@route("/sync") @route("/sync")
def abouttoshutdown(): def abouttoshutdown():
sync() sync()

View File

@ -211,8 +211,8 @@ function scrobble(artist,title,seconds) {
artiststring = encodeURIComponent(artist) artiststring = encodeURIComponent(artist)
titlestring = encodeURIComponent(title) titlestring = encodeURIComponent(title)
var xhttp = new XMLHttpRequest(); var xhttp = new XMLHttpRequest();
xhttp.open("GET","http://localhost:42010/db/newscrobble?artist=" + artiststring + "&title=" + titlestring + "&duration=" + seconds,true); xhttp.open("POST","http://localhost:42010/db/newscrobble",true);
xhttp.send() xhttp.send("artist=" + artiststring + "&title=" + titlestring + "&duration=" + seconds)
} }
function setUpdate() { function setUpdate() {

View File

@ -1,4 +1,4 @@
from bottle import route, run, template, static_file, request, response, FormsDict from bottle import route, get, post, run, template, static_file, request, response, FormsDict
from importlib.machinery import SourceFileLoader from importlib.machinery import SourceFileLoader
import _thread import _thread
import waitress import waitress
@ -22,7 +22,7 @@ def mainpage():
# this is the fallback option. If you run this service behind a reverse proxy, it is recommended to rewrite /db/ requests to the port of the db server # this is the fallback option. If you run this service behind a reverse proxy, it is recommended to rewrite /db/ requests to the port of the db server
# e.g. location /db { rewrite ^/db(.*)$ $1 break; proxy_pass http://yoururl:12349; } # e.g. location /db { rewrite ^/db(.*)$ $1 break; proxy_pass http://yoururl:12349; }
@route("/db/<pth:path>") @get("/db/<pth:path>")
def database(pth): def database(pth):
keys = FormsDict.decode(request.query) # The Dal★Shabet handler keys = FormsDict.decode(request.query) # The Dal★Shabet handler
keystring = "?" keystring = "?"
@ -34,6 +34,13 @@ def database(pth):
#print("Returning " + "http://localhost:" + str(DATABASE_PORT) + "/" + pth) #print("Returning " + "http://localhost:" + str(DATABASE_PORT) + "/" + pth)
return contents return contents
@post("/db/<pth:path>")
def database(pth):
contents = urllib.request.urlopen("http://localhost:" + str(DATABASE_PORT) + "/" + pth,request.body).read()
response.content_type = "application/json"
response.set_header("Access-Control-Allow-Origin","*")
return contents
@route("/exit") @route("/exit")
def shutdown(): def shutdown():
graceful_exit() graceful_exit()