Skip to main content

Open web audio application with semantics

Project description

Telemeta : collaborative multimedia asset management system

.. image::
:alt: Telemeta logo


Telemeta is a free and open source collaborative multimedia asset management system (MAM) which introduces fast and secure methods to archive, backup, transcode, analyse, annotate and publish any digitalized video or audio file with extensive metadata. It is dedicated to collaborative media archiving projects, research laboratories and digital humanities - especially in ethno-musicological use cases - who need to easily organize and publish documented sound collections of audio files, CDs, digitalized vinyls and magnetic tapes over a strong database, through a smart and secure platform, in accordance with open web standards.

Key features:

* Secure archiving, editing and publishing of audio files over internet.
* Pure HTML web user interface including dynamical forms and smart workflows
* "On the fly" audio analyzing and transcoding thanks to TimeSide_
* Smart dynamical and skinnable audio player with annotations
* Collaborative indexing with semantic ontologies and timecoded markers
* Multi-format support : FLAC, OGG, MP3, WAV, MP4, WebM (video) and more
* User management with individual desk, lists, profiles and rights
* Playlist management for all users with CSV data export
* Geo-Navigator for audio geolocalization
* High level search engine
* DublinCore compatibility
* OAI-PMH data provider
* RSS feed generators
* XML and ZIP serialized backups
* EPUB3 "audio book" collection exporter
* SQLite, MySQL, PostgreSQL or Oracle DB backends
* Multi-language support (now english and french)
* Run on any OS

Telemeta has been developed since 2006 and is based exclusively on 100% open source modules.

It is mostly written in Python, HTML5 and JavaScript.

The *Telemeta* name stands for *Tele* as "remote access" and *meta* for "metadata".

|version| |downloads| |travis_master| |coverage_master|

.. |version| image::
:alt: Version

.. |travis_master| image::
:alt: Travis

.. |coverage_master| image::
:alt: Coverage

Funding and support

To fund this long time libre and open source project, we need your explicit support. So if you use Telemeta in production or even in a development or experimental setup, please let us know by:

* staring or forking the project on GitHub_
* tweeting something to `@parisson_studio <>`_ or `@telemeta <>`_
* drop us an email <>

Thank you so much for your help!

* Minor bug fixes and improvments
* Fix HTML5 audio compatibility (#173) for the web audio player. The SoundManager Flash player fallback should not be used in most modern web browser. Media files are now serves through Nginx (#155) which enables to stream music with byte range requests.
* Add a User permission "can_run_analysis" to specify that a user or a group of users has the right to list and select advanced Timeside analysis to be displayed in the Timeside web audio player.
* Add enumeration management and statitics
* Improved media security allowing streaming through Nginx only from the application
* Add TimeSide as a submodule
* Add a validator for Corpus and Fonds
* Upgrade various dependencies


Telemeta is now usable on **any OS**, ready for development and for production in 5 mn! B-)

* Provide a docker image and composition for the full Telemeta application bundle.
One month after the publication of docker-compose around march 2015, we had managed to build a prototyped composition which bundled all the dependencies of Telemeta and TimeSide. It took almost one year to deeply investigate all the capabilities of Docker and various images to finally release a propoer composition which bundles all the necessary applications and modules.
* Full refactoring of the search engine and interface using django-haystack and ElasticSearch with new faceting and smart filtering features
* Add an automatic EPUB3 ebook exporter for corpus and collections embedding metadata, image and audio materials.
* More inline forms and functional buttons
* Install new useful tools and modules like Conda, Jupyter notebook and `many others <>`_
* Add resource sharing links
* Switch to Affero GPL licence
* Upgrade of every dependency bundle in the composition
* Many, many `bugfixes <>`_
* Thanks to all partners for this **huge** release!


* Fix geo-navigator lists and pagination
* Fix item analyses cleanup after file edit
* Fix performance and keywords copy during item copy
* Add various annotation mime types (ELAN, Trancriber, Sonic Visualizer)
* Add arabic translations through Telemeta-locales (thanks to @AnasGhrab)
* Fix arabic and chinese codes in sandbox
* Better locale / pages management
* A better management of RTL for arabic page style

`More changes <>`_.


* `CREM Sound archives <>`_ of the CREM_ - CNRS_ and MdH_
* `LAM Sound archives <>`_ of the LAM_ of the IJLRDA_ at Université Pierre et Maris Curie (UPMC_)
* `Phonothèque Nationale <>`_ du Centre des Musiques Arabes et Méditerranéennes (CMAM_)
* Scaled BIOdiversity (SABIOD_)


* login: admin
* password: admin


Thanks to Docker, Telemeta is now fully available as a docker composition ready to work. The docker based composition bundles some powerfull applications and modern frameworks out-of-the-box like: Python, Conda, Numpy, Jupyter, Gstreamer, Django, Celery, Haystack, ElasticSearch, MySQL, Redis, uWSGI, Nginx and many more.

* on **Linux**, first install `Git <>`_, `Docker engine <>`_ (>=1.9) and `docker-compose <>`_ (>=1.8) and open a terminal.
* on **MacOSX** or **Windows** install the `Docker Toolbox <>`_ and open a **Docker Quickstart Terminal**.

Then clone Telemeta::

git clone --recursive
cd Telemeta

Start it up

For a production environment setup, first read / edit `env/prod.env`, then::

docker-compose up

Then browse the app at http://localhost:8000/ (replacing 'localhost' by the IP given by the docker terminal on OSX or Windows)

To start the application in DEBUG mode::

docker-compose -f docker-compose.yml -f env/debug.yml up

Be **CAREFULL** in production:

* The database is deleted when using `docker-compose rm`
* Define your own passwords and secret keys in `env/*.env` files
* Use a cron rule and the backup script to save your work periodically

Backup / Restore

To backup the database in the data/backup/ folder, run this in **another** terminal (or a Docker Quickstart Terminal)::

docker-compose run db /srv/scripts/sql/

To restore the last backuped database from the data/backup/ folder, run this in **another** terminal (or a Docker Quickstart Terminal)::

docker-compose run db /srv/scripts/sql/

If the app is broken after a restore script, restart the composition with::

docker-compose restart

API / Documentation

* Official website:
* Publications :
* API :
* Player :
* Example :


|travis_dev| |coverage_dev|

.. |travis_dev| image::
:alt: Travis

.. |coverage_dev| image::
:alt: Coverage

To start the application in a development environment setup, first read / edit `env/debug.env`, then::

cd Telemeta
git pull
git checkout dev
docker-compose -f docker-compose.yml -f env/dev.yml up

Then browse the app at http://localhost:9000/ (replacing 'localhost' by the IP given by the docker terminal on OSX or Windows). Note that the service will automatically be reloaded when any code of the app is modified.

You are welcome to participate to the development by forking the Telemeta project on GitHub_, using it as if it were the original and submitting your changes through a Pull Request on the **dev branch ONLY**.

Bugs, issues, ideas

If you find some bugs or have good ideas for enhancement, please `leave a issue on GitHub <>`_ with the right label or tweet it `@telemeta <>`_.

And remember: even if Telemeta suits you, please give us some feedback. We **need** your support!


This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.

You should have received a copy of the GNU Affero General Public License along with this program. If not, see <>.

Sponsors and partners

* CNRS_ : Centre National de la Recherche Scientifique (French Natianal Research and Scientific Center)
* MCC_ : Ministère de la Culture et de la Communication (the french Ministry of the Culture and Communication)
* ANR_ : Agence Nationale de la Recherche (French Research Agency)
* UPMC_ : University Pierre et Marie Curie (Paris 6, Sorbonne Universités, France)
* CREM_ : Centre de Recherche en Ethnomusicologie (Ethnomusicology Research Center, Paris, France)
* LAM_ : Equipe Lutherie, Acoustique et Musique de l'IJLRDA_ (Paris, France)
* IJLRDA_ : Institut Jean le Rond d'Alembert (Paris, France)
* Parisson_ : Open development agency for audio science and arts (Paris, France)
* MNHN_ : Museum National d'Histoire Naturelle (National Museum of Biology, Paris, France)
* U-Paris10_ : University Paris 10 Ouest Nanterre (Nanterre, France)
* MdH_ : Musée de l'Homme (Paris, France)
* IRIT_ : Institut de Recherche en Informatique de Toulouse (Toulouse, France)
* LIMSI_ : Laboratoire d'Informatique pour la Mécanique et les Sciences de l'Ingénieur (Orsay, France)
* LABRI_ : Laboratoire Bordelais de Recherche en Informatique (Bordeaux, France)
* C4DM_ : Centre for Digital Music at `Queen Mary University`_ (London, UK)
* HumaNum_ : TGIR des humanités numériques (Paris, France)
* CMAM_ : Centre des Musiques Arabes et Méditerranéennes (Tunis, Tunisia)
* IRCAM_ : Institut de Recherche et de Coordination Acoustique / Musique (Paris, France)

Related research projects

* DIADEMS_ : Description, Indexation, Access to Sound and Ethnomusicological Documents, funded by the French Research Agency (ANR_ CONTINT 2012), involving IRIT_, CREM_, LAM_, LABRI_, LIMSI_, MNHN_, Parisson_
* TimeSide-DIADEMS_ : a set of Timeside plugins for hich level music analysis developed during the DIADEMS_ project
* SoundSoftware_ : Sustainable Software of Audio and Music Research
* DaCaRyH_ : Le rythme calypso à travers l’histoire : une approche en sciences des données (AHRC_ “Care for the Future” et le Labex-Passé_Présent_ "Les passés dans le présent")
* Kamoulox_ : Démixage en ligne de larges archives sonores (ANR_ Jeune Chercheur 2015)
* WASABI : Web Audio Semantic Aggregated in the Browser for Indexation (ANR_ 2016, currently being submitted)

.. _Telemeta:
.. _TimeSide:
.. _OAI-PMH:
.. _Parisson:
.. _CNRS:
.. _MCC:
.. _CREM:
.. _HumaNum:
.. _IRIT:
.. _LIMSI:
.. _LAM:
.. _LABRI:
.. _MNHN:
.. _MMSH:
.. _UPMC:
.. _ANR:
.. _Publications:
.. _API :
.. _Player :
.. _Example :
.. _Homepage:
.. _GitHub:
.. _Labex-Passé_Présent:
.. _U-Paris10:
.. _MdH:
.. _IRCAM:
.. _TimeSide-DIADEMS:
.. _DaCaRyH:
.. _Kamoulox:
.. _AHRC:
.. _Queen Mary University:
.. _SoundSoftware :
.. _C4DM:
.. _CMAM:

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Telemeta-1.6.4.tar.gz (1.5 MB view hashes)

Uploaded source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page