-
Notifications
You must be signed in to change notification settings - Fork 11
Installation
<script src=”//ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js”></script>Wiki ▸ Installation
Welcome to the slimpd wiki!
##DEPENDENCIES
- MPD music player daemon
- MySQL/MariaDB
- PHP
- Python2.X
- Sphinx 1↵
-
Webserver (Apache, Nginx, Lighttpd, ...)
- read-access to MPD-database-file (plain-text or gzip supported)
- read-access to filesystem configured in
'mpd.conf:music_directory'
- optional: enable module mod_rewrite
MP3, M4A, MP4, AAC, FLAC, WMA, AC3, and, OGG* __Lame__ _(for displaying waveforms)_ * _optional:_
* __FAAD2__ _(for displaying waveforms for .m4a, .mp4, and, .aac)_
* __Flac__ and __Metaflac__(usually included within the Flac package) _(for displaying waveforms for .flac)_
* __Mplayer__ _(for displaying waveforms for .wma and .ac3)_
* __Vorbis-Tools__ _(for displaying waveforms for .ogg)_
##SETUP
- Create a virtual-host which points to your filesystem
For help: MYsQL/MariaDB database creation* [MySQL](https://dev.mysql.com/doc/refman/5.5/en/data-directory-initialization.html "MySQL initialization") and [MariaDB](https://mariadb.com/kb/en/mariadb/mariadb-vs-mysql-compatibility/ "MariaDB vs. MySQL compatibility") are considered interchangeable although MariaDB is recomended. * __Webserver-user__ must have _write_ permission to __[CREATE DATABASE](https://github.com/killhellokitty/slimpd/wiki/Configuration#database "config_local.ini [database]")__.
###Configure sliMpd
For help: Configuration* Copy
\*/slimpd/config/config_local.sample.ini
to */slimpd/config/config_local.ini
and check values.
* Make sure that your web-server has write access to these directories:
```bsh
*/slimpd/cache/
*/slimpd/embedded/
*/slimpd/peakfiles/
```
###Import music library
-
This will create your MySQL database tables and begin the import of your music from your Mpd-database:
$ php '*/slimpd/slimpd' hard-reset
###Create Sphinx database
- Add Sphinx-configuration to:
/etc/sphinx/sphinx.conf
based on*/slimpd/config/sphinx.example.conf
.
Under most circumstances you can copy*/slimpd/config/sphinx.example.conf
to/etc/sphinx/sphinx.conf.
- Update the Sphinx-index.
-
The first time after setting up Sphinx you must run:
# indexer slimpdmain slimpdsuggest
-
For all future Sphinx updates run:
# */slimpd/scripts/sphinx-rotate.sh
-
###Systemcheck
- After completing setup, run
systemcheck
. Either type in sliMpd's web-address and at*/index.php/*
,change it to*/index.php/systemcheck
, or simply press the 'Gear Icon' on the sliMpd web-page. - Scroll down the page and check for 'Success' or 'Error' messages. This is how to debug your installation.
-
Filesystem: make certain it says 'Success' for every subheading. All 'Error' messages under this heading must be fixed!
READ-PERMISSION TO ACCESS MPD'S MUSIC-DIRECTORY
- Your [MPD music-directory](https://github.com/othmar52/slimpd/wiki/Configuration/#mpd ""config_local.ini [mpd]") and its children must be read accessible to your webserver-user.WRITE-PERMISSION FOR CACHE-DIRECTORY
- Your webserver-user must have write permission to the'/slimpd/cache/'
directory.WRITE-PERMISSION FOR EMBEDDED-DIRECTORY
- Your webserver-user must have write permission to the'/slimpd/embedded/'
directory.WRITE-PERMISSION FOR PEAKFILES-DIRECTORY
- Your webserver-user must have write permission to the'/slimpd/peakfiles/'
directory.
-
Database: MySQL-database, make certain it says 'Success' for every subheading. All 'Error' messages under this heading must be fixed!
CONNECTION
- You must be able to successfully connect to the MySQL-database created for sliMpd athttp://localhost
, by having the correct dbusername, dbpassword, and dbdatabase information added to your'/slimpd/config/config_local.ini'.
PERMISSIONS OF DATABASE-USER
- MySQL database user has permission to create databases.SCHEMA
- MySQL database tables created correctly via running thephp '*/slimpd/slimpd' hard-reset
script.DATABASE CONTENT
- Confirmation of Mpd-database import into the MySQL database. Listing the number of imported Tracks, Albums, Artists, Genres, and Labels.
-
MPD: make certain it says 'Success' for every subheading. All 'Error' messages under this heading must be fixed!
CONNECTION
READ ACCESS TO DATABASE FILE
-
Sphinx: 1 ↵ make certain it says 'Success' for every subheading. All 'Error' messages under this heading must be fixed!
CONNECTION
SCHEMA
INDEXED DATA
-
Waveform: The 'Success' or 'Error' messages are for the codecs installed. Only the codecs required for your music collection are necessary to have installed. The 'Show More' buttons, when pressed give detailed information for the creation of the test music file 'Fingerprint' with result comparison. It also provides details for the executed command used to create the test music file 'Waveform' and states whether the test failed or succeeded. These may prove helpful to debug should a codec you have installed not show as successfully creating the 'Fingerprint' and 'Waveform'.
MP3 EXTRACT FINGERPRINT
andMP3 EXTRACT PEAKS FOR WAVEFORM
These are the only exception. They must be successfully installed with a green 'Check'!FLAC EXTRACT FINGERPRINT
andFLAC EXTRACT PEAKS FOR WAVEFORM
WAV EXTRACT FINGERPRINT
andWAV EXTRACT PEAKS FOR WAVEFORM
M4A EXTRACT FINGERPRINT
andM4A EXTRACT PEAKS FOR WAVEFORM
AIF EXTRACT FINGERPRINT
andAIF EXTRACT PEAKS FOR WAVEFORM
AAC EXTRACT FINGERPRINT
andAAC EXTRACT PEAKS FOR WAVEFORM
OGG EXTRACT FINGERPRINT
andOGG EXTRACT PEAKS FOR WAVEFORM
WMA EXTRACT FINGERPRINT
andWMA EXTRACT PEAKS FOR WAVEFORM
AC3 EXTRACT FINGERPRINT
andAC3 EXTRACT PEAKS FOR WAVEFORM
-
Enviroment: Currently unimplemented.
check if php-pdo is enabled
Unimplementedcheck locale settings to avoid errors caused by special chars
Unimplemented
-
Xwax: Currently unimpliimented.
check connection
Unimplemented
-
<a href=”#” class=”back-to-top” style=”display: inline;”>
<i class=”fa fa-arrow-circle-up”>
<script> jQuery(document).ready(function() { var offset = 250; var duration = 300; jQuery(window).scroll(function() { if (jQuery(this).scrollTop() > offset) { jQuery(‘.back-to-top’).fadeIn(duration); } else { jQuery(‘.back-to-top’).fadeOut(duration); } }); jQuery(‘.back-to-top’).click(function(event) { event.preventDefault(); jQuery(‘html, body’).animate({scrollTop: 0}, duration); return false; }) }); </script>1. Sphinx will be optional in the future