1
0
mirror of https://github.com/SuperBFG7/ympd synced 2025-01-27 09:24:54 +00:00
Standalone MPD Web GUI written in C, utilizing Websockets and Bootstrap/JS. Updated and somewhat fixed fork.
Go to file
2018-07-16 23:39:17 +01:00
.github/ISSUE_TEMPLATE Update issue templates 2018-05-25 21:23:16 +02:00
cmake initial mongoose checkin 2014-03-08 12:30:48 +01:00
contrib cleanup: move manpage to contrib directory 2018-07-15 23:45:10 +01:00
htdocs fix: remove .map reference from bootstrap css 2018-07-16 22:48:17 +01:00
src cleanup 2018-07-16 23:36:01 +01:00
CMakeLists.txt cleanups 2018-07-16 21:56:56 +01:00
LICENSE replaces libwebsockets with mongoose, changed licese to gpl 2014-03-08 12:30:49 +01:00
mkdebug.sh Dont run under uid 0 2018-06-21 23:15:54 +01:00
mkrelease.sh feat: minify html in mkrelease.sh 2018-07-16 18:51:59 +01:00
README.md Add libasan3 dependency 2018-07-16 22:39:32 +01:00

myMPD

myMPD is a lightweight MPD web client that runs without a dedicated webserver or interpreter. It's tuned for minimal resource usage and requires only very litte dependencies. myMPD is a fork of ympd (https://github.com/notandy/ympd).

This fork provides a reworked ui based on Bootstrap 4 and a modernized backend.

Design principles:

  • Keep it small and simple
  • Uses only mpd as source of truth
  • Mobile first UI
  • Keep security in mind

Featurelist:

  • Browse mpd database by artist
  • Browse filesystem and playlists
  • Queue management
  • Advanced search
  • Progressiv Web App enabled
  • Local coverart support

myMPD is work in progress. Bugreportes and feature requests are very welcome. Please use the issues function from github (https://github.com/jcorporation/myMPD/issues). Planed functions are managed in a github project (https://github.com/jcorporation/myMPD/projects/1).

image

UI Components

Backend

Dependencies

Unix Build Instructions

  1. Install dependencies: cmake, libmpdclient (dev) and OpenSSL (dev) are available from all major distributions.
  2. Build and install: cd /path/to/src; ./mkrelease.sh.
  3. Link your mpd music directory to /usr/share/mympd/htdocs/library and put folder.jpg files in your album directories (mkrelease.sh tries to do this for you).
  4. Configure your mpd with http stream output to use the local player.

Run flags

Usage: ./mympd [OPTION]...

 -h, --mpdhost <host>          connect to mpd at host [localhost]
 -p, --mpdport <port>          connect to mpd at port [6600]
 -m, --mpdpass <password>      specifies the password to use when connecting to mpd
 -w, --webport <port>          listen port for webserver [80]
 -S, --ssl		       enable ssl
 -W, --sslport <port>	       listen port for ssl webserver [443]
 -C, --sslcert <filename>      filename for ssl certificate [/etc/mympd/ssl/server.pem]
 -K, --sslkey <filename>       filename for ssl key [/etc/mympd/ssl/server.key]
 -s, --streamport <port>       connect to mpd http stream at port [8000]
 -u, --user <username>         drop priviliges to user after socket bind
 -i, --coverimage <filename>   filename for coverimage [folder.jpg]
 -t, --statefile <filename>    filename for mympd state [/var/lib/mympd/mympd.state]
 -v, --version                 get version
 --help                        this help

SSL

  1. Create ca and certificate /path/to/src/contrib/crcert.sh (mkrelease.sh do this for you).
  2. Start myMPD with -S (use default certificate under /etc/mympd/ssl/).
  3. Import /etc/mympd/ssl/ca/ca.pem in your browser to trust the certificate.
  4. myMPD redirects http requests to https, ensure that myMPD hostname is resolvable.

ympd: 2013-2014 andy@ndyk.de

myMPD: 2018 mail@jcgames.de