Last active 1531452378

MiniDLNA Python REST API server and associated Tkinter GUI for reading from it https://github.com/blha303/PythonMiniDLNARestAPI

Revision e840799fa025d6e757b7730a5aa484898b541fe9

minidlnagui.py Raw
1# Run this on a client machine (not the media server)
2# This is my first GUI!
3
4# Copyright 2013 Steven Smith (blha303). All Rights Reserved.
5# New BSD license
6# http://www.opensource.org/licenses/BSD-3-Clause
7
8from Tkinter import *
9import tkMessageBox
10import requests
11import json
12
13hostname = "home.blha303.com.au"
14port = "5000"
15url = "http://%s:%s/api/DETAILS" % (hostname, port if port else "5000")
16fields = ['ARTIST', 'ID', 'PATH', 'SIZE', 'TIMESTAMP', 'TITLE', 'DURATION', 'BITRATE',
17 'SAMPLERATE', 'CREATOR', 'ALBUM', 'GENRE', 'COMMENT', 'CHANNELS', 'DISC',
18 'TRACK', 'DATE', 'RESOLUTION', 'THUMBNAIL', 'ALBUM_ART', 'ROTATION',
19 'DLNA_PN', 'MIME']
20
21def search(term, name='artist'):
22 url = "http://home.blha303.com.au:5000/api/DETAILS"
23 headers = {'Content-Type': 'application/json'}
24 filters = [dict(name=name.upper(), op='like', val=term)]
25 params = dict(q=json.dumps(dict(filters=filters)))
26 response = requests.get(url, params=params, headers=headers)
27 assert response.status_code == 200
28 return response.json()
29
30master = Tk()
31master.wm_title("MiniDLNA REST API gui (by blha303)")
32windows = PanedWindow()
33windows.pack(fill=BOTH, expand=1)
34textbox = Text(windows)
35windows.add(textbox)
36rightside = PanedWindow(windows, orient=VERTICAL)
37windows.add(rightside)
38top = Entry(rightside)
39rightside.add(top)
40middle = Listbox(rightside)
41x = 1
42for i in fields:
43 middle.insert(x, i)
44 x += 1
45
46rightside.add(middle)
47
48def buttonCallback():
49 term = top.get()
50 name = middle.get(middle.curselection() if middle.curselection() else 0)
51 data = search(term, name=name)
52 textbox.delete(1.0, END)
53 if data['num_results'] == 0:
54 textbox.insert(INSERT, str(data))
55 return
56 else:
57 output = []
58 for i in data['objects']:
59 if str(i['PATH']) != "None":
60 output.append("PATH: " + str(i['PATH']))
61 for a in fields:
62 if a != "PATH":
63 output.append(" " + a + ": " + str(i[a]))
64 output.append("")
65 textbox.insert(INSERT, "\n".join(output))
66
67bottom = Button(rightside, text="Submit", command=buttonCallback)
68rightside.add(bottom)
69mainloop()
70
minidlnarestserver.py Raw
1# Requirements (rather, the versions of these requirements that I have):
2# Flask==0.10.1
3# Flask-Restless==0.12.0
4# Flask-SQLAlchemy==1.0
5# SQLAlchemy==0.8.2
6
7# Run this on the media server. It runs on port 5000 by default.
8
9# Copyright 2013 Steven Smith (blha303). All Rights Reserved.
10# New BSD license
11# http://www.opensource.org/licenses/BSD-3-Clause
12
13import flask
14import flask.ext.sqlalchemy
15app = flask.Flask(__name__)
16app.config['DEBUG'] = True
17app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:////var/lib/minidlna/files.db'
18#app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///data.db'
19db = flask.ext.sqlalchemy.SQLAlchemy(app)
20
21class Details(db.Model):
22 __tablename__ = "DETAILS"
23 ID = db.Column(db.Integer, primary_key=True)
24 PATH = db.Column(db.Text)
25 SIZE = db.Column(db.Integer)
26 TIMESTAMP = db.Column(db.Integer)
27 TITLE = db.Column(db.Text)
28 DURATION = db.Column(db.Text)
29 BITRATE = db.Column(db.Integer)
30 SAMPLERATE = db.Column(db.Integer)
31 CREATOR = db.Column(db.Text)
32 ARTIST = db.Column(db.Text)
33 ALBUM = db.Column(db.Text)
34 GENRE = db.Column(db.Text)
35 COMMENT = db.Column(db.Text)
36 CHANNELS = db.Column(db.Integer)
37 DISC = db.Column(db.Integer)
38 TRACK = db.Column(db.Integer)
39 DATE = db.Column(db.Date)
40 RESOLUTION = db.Column(db.Text)
41 THUMBNAIL = db.Column(db.Boolean)
42 ALBUM_ART = db.Column(db.Integer)
43 ROTATION = db.Column(db.Integer)
44 DLNA_PN = db.Column(db.Text)
45 MIME = db.Column(db.Text)
46
47import flask.ext.restless
48
49manager = flask.ext.restless.APIManager(app, flask_sqlalchemy_db=db)
50
51manager.create_api(Details, methods=['GET'], results_per_page=20)
52
53app.run(host='0.0.0.0')
54