2017-06-25 21:33:19 +00:00
|
|
|
Importing music
|
|
|
|
================
|
|
|
|
|
|
|
|
From music directory on the server
|
|
|
|
----------------------------------
|
|
|
|
|
|
|
|
You can import music files in funkwhale assuming they are located on the server
|
2017-07-17 20:00:32 +00:00
|
|
|
and readable by the funkwhale application. Your music files should contain at
|
|
|
|
least an ``artist``, ``album`` and ``title`` tags.
|
2017-06-25 21:33:19 +00:00
|
|
|
|
2017-07-17 20:00:32 +00:00
|
|
|
You can import those tracks as follows, assuming they are located in
|
|
|
|
``/srv/funkwhale/data/music``:
|
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
python api/manage.py import_files "/srv/funkwhale/data/music/**/*.ogg" --recursive --noinput
|
|
|
|
|
|
|
|
When you use docker, the ``/srv/funkwhale/data/music`` is mounted from the host
|
|
|
|
to the ``/music`` directory on the container:
|
2017-06-25 21:33:19 +00:00
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
2017-06-25 21:39:18 +00:00
|
|
|
docker-compose run --rm api python manage.py import_files "/music/**/*.ogg" --recursive --noinput
|
2017-06-25 21:33:19 +00:00
|
|
|
|
2017-06-26 19:56:24 +00:00
|
|
|
For the best results, we recommand tagging your music collection through
|
|
|
|
`Picard <http://picard.musicbrainz.org/>`_ in order to have the best quality metadata.
|
|
|
|
|
2017-07-17 20:00:32 +00:00
|
|
|
|
2017-06-25 21:33:19 +00:00
|
|
|
.. note::
|
|
|
|
|
|
|
|
This command is idempotent, meaning you can run it multiple times on the same
|
|
|
|
files and already imported files will simply be skipped.
|
|
|
|
|
2017-06-26 19:56:24 +00:00
|
|
|
.. note::
|
|
|
|
|
|
|
|
At the moment, only OGG/Vorbis and MP3 files with ID3 tags are supported
|
2017-06-25 21:33:19 +00:00
|
|
|
|
2017-07-17 20:00:32 +00:00
|
|
|
.. note::
|
|
|
|
|
|
|
|
The --recursive flag will work only on Python 3.5+, which is the default
|
|
|
|
version When using Docker or Debian 9. If you use an older version of Python,
|
|
|
|
remove the --recursive flag and use more explicit import patterns instead::
|
|
|
|
|
|
|
|
# this will only import ogg files at the second level
|
|
|
|
"/srv/funkwhale/data/music/*/*.ogg"
|
|
|
|
# this will only import ogg files in the fiven directory
|
|
|
|
"/srv/funkwhale/data/music/System-of-a-down/*.ogg"
|
|
|
|
|
|
|
|
|
2017-06-25 21:33:19 +00:00
|
|
|
|
|
|
|
Getting demo tracks
|
|
|
|
^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
If you do not have any music on your server but still want to test the import
|
|
|
|
process, you can call the following methods do download a few albums licenced
|
|
|
|
under creative commons (courtesy of Jamendo):
|
|
|
|
|
2017-07-17 20:00:32 +00:00
|
|
|
.. parsed-literal::
|
2017-06-25 21:33:19 +00:00
|
|
|
|
2017-07-17 20:00:32 +00:00
|
|
|
curl -L -o download-tracks.sh "https://code.eliotberriot.com/funkwhale/funkwhale/raw/|version|/demo/download-tracks.sh"
|
|
|
|
curl -L -o music.txt "https://code.eliotberriot.com/funkwhale/funkwhale/raw/|version|/demo/music.txt"
|
2017-06-25 21:33:19 +00:00
|
|
|
chmod +x download-tracks.sh
|
|
|
|
./download-tracks.sh music.txt
|
|
|
|
|
|
|
|
This will download a bunch of zip archives (one per album) under the ``data/music`` directory and unzip their content.
|