Merge branch 'panel'
[mediagoblin.git] / docs / source / siteadmin / media-types.rst
CommitLineData
473a4431
CAW
1.. MediaGoblin Documentation
2
8af91cea 3 Written in 2011, 2012, 2014, 2015 by MediaGoblin contributors
473a4431
CAW
4
5 To the extent possible under law, the author(s) have dedicated all
6 copyright and related and neighboring rights to this software to
7 the public domain worldwide. This software is distributed without
8 any warranty.
9
10 You should have received a copy of the CC0 Public Domain
11 Dedication along with this software. If not, see
12 <http://creativecommons.org/publicdomain/zero/1.0/>.
13
9bc2fc6c
CAW
14.. _media-types-chapter:
15
16====================
d34757dc 17Media Types
9bc2fc6c
CAW
18====================
19
20In the future, there will be all sorts of media types you can enable,
ffbf9c8b
OHO
21but in the meanwhile there are six additional media types: video, audio,
22raw image, ascii art, STL/3d models, PDF and Document.
9bc2fc6c
CAW
23
24First, you should probably read ":doc:`configuration`" to make sure
25you know how to modify the mediagoblin config file.
26
d34757dc
JW
27Enabling Media Types
28====================
29
91bee92e
RE
30.. note::
31 Media types are now plugins
32
d34757dc
JW
33Media types are enabled in your mediagoblin configuration file, typically it is
34created by copying ``mediagoblin.ini`` to ``mediagoblin_local.ini`` and then
35applying your changes to ``mediagoblin_local.ini``. If you don't already have a
36``mediagoblin_local.ini``, create one in the way described.
37
38Most media types have additional dependencies that you will have to install.
39You will find descriptions on how to satisfy the requirements of each media type
40on this page.
41
91bee92e
RE
42To enable a media type, add the the media type under the ``[plugins]`` section
43in you ``mediagoblin_local.ini``. For example, if your system supported image
44and video media types, then it would look like this::
d34757dc 45
91bee92e
RE
46 [plugins]
47 [[mediagoblin.media_types.image]]
48 [[mediagoblin.media_types.video]]
d34757dc 49
9d5cd0b9
CAW
50Note that after enabling new media types, you must run dbupdate like so::
51
52 ./bin/gmg dbupdate
53
54If you are running an active site, depending on your server
55configuration, you may need to stop it first (and it's certainly a
56good idea to restart it after the update).
57
58
d34757dc
JW
59How does MediaGoblin decide which media type to use for a file?
60===============================================================
61
62MediaGoblin has two methods for finding the right media type for an uploaded
63file. One is based on the file extension of the uploaded file; every media type
64maintains a list of supported file extensions. The second is based on a sniffing
65handler, where every media type may inspect the uploaded file and tell if it
66will accept it.
67
68The file-extension-based approach is used before the sniffing-based approach,
69if the file-extension-based approach finds a match, the sniffing-based approach
70will be skipped as it uses far more processing power.
71
63b5959f
LD
72Configuring Media Types
73=======================
74
75Each media type has a ``config_spec.ini`` file with configurable
76options and comments explaining their intended side effect. For
77instance the ``video`` media type configuration can be found in
78``mediagoblin/media_types/video/config_spec.ini``.
79
d34757dc 80
9bc2fc6c
CAW
81Video
82=====
83
84To enable video, first install gstreamer and the python-gstreamer
85bindings (as well as whatever gstremaer extensions you want,
3a8b18f8 86good/bad/ugly). On Debianoid systems
9bc2fc6c 87
3a8b18f8
JW
88.. code-block:: bash
89
919cd2fd
BB
90 sudo apt-get install python-gi python3-gi \
91 gstreamer1.0-tools \
92 gir1.2-gstreamer-1.0 \
93 gir1.2-gst-plugins-base-1.0 \
94 gstreamer1.0-plugins-good \
95 gstreamer1.0-plugins-ugly \
96 gstreamer1.0-plugins-bad \
eade529e
BB
97 gstreamer1.0-libav \
98 python-gst-1.0
582958e3 99
9bc2fc6c 100
91bee92e
RE
101Add ``[[mediagoblin.media_types.video]]`` under the ``[plugins]`` section in
102your ``mediagoblin_local.ini`` and restart MediaGoblin.
5ef7ab08 103
3a8b18f8
JW
104Run
105
106.. code-block:: bash
3fe3b222 107
5ef7ab08
CAW
108 ./bin/gmg dbupdate
109
9bc2fc6c
CAW
110Now you should be able to submit videos, and mediagoblin should
111transcode them.
112
7798f911
WKG
113.. note::
114
115 You almost certainly want to separate Celery from the normal
116 paste process or your users will probably find that their connections
117 time out as the video transcodes. To set that up, check out the
118 ":doc:`production-deployments`" section of this manual.
efd69313
CAW
119
120
d34757dc
JW
121Audio
122=====
123
124To enable audio, install the gstreamer and python-gstreamer bindings (as well
125as whatever gstreamer plugins you want, good/bad/ugly), scipy and numpy are
126also needed for the audio spectrograms.
127To install these on Debianoid systems, run::
128
8af91cea 129 sudo apt-get install python-gst-1.0 gstreamer1.0-plugins-{base,bad,good,ugly} \
94a5d6a8 130 gstreamer1.0-libav python-numpy python-scipy libsndfile1-dev libasound2-dev
d34757dc 131
34a85313 132.. note::
8518e95e 133 scikits.audiolab will display a warning every time it's imported if you do
34a85313 134 not compile it with alsa support. Alsa support is not necessary for the GNU
8af91cea 135 MediaGoblin application.
34a85313 136
d34757dc
JW
137Then install ``scikits.audiolab`` for the spectrograms::
138
139 ./bin/pip install scikits.audiolab
140
91bee92e 141Add ``[[mediagoblin.media_types.audio]]`` under the ``[plugins]`` section in your
5ef7ab08
CAW
142``mediagoblin_local.ini`` and restart MediaGoblin.
143
3a8b18f8
JW
144Run
145
146.. code-block:: bash
3fe3b222 147
5ef7ab08
CAW
148 ./bin/gmg dbupdate
149
150You should now be able to upload and listen to audio files!
d34757dc
JW
151
152
ffbf9c8b
OHO
153Raw image
154=========
155
156To enable raw image you need to install pyexiv2. On Debianoid systems
157
158.. code-block:: bash
159
160 sudo apt-get install python-pyexiv2
161
162Add ``[[mediagoblin.media_types.raw_image]]`` under the ``[plugins]``
163section in your ``mediagoblin_local.ini`` and restart MediaGoblin.
164
165Run
166
167.. code-block:: bash
168
169 ./bin/gmg dbupdate
170
171Now you should be able to submit raw images, and mediagoblin should
172extract the JPEG preview from them.
173
174
efd69313
CAW
175Ascii art
176=========
177
178To enable ascii art support, first install the
179`chardet <http://pypi.python.org/pypi/chardet>`_
3a8b18f8
JW
180library, which is necessary for creating thumbnails of ascii art
181
182.. code-block:: bash
efd69313
CAW
183
184 ./bin/easy_install chardet
185
186
187Next, modify (and possibly copy over from ``mediagoblin.ini``) your
91bee92e
RE
188``mediagoblin_local.ini``. In the ``[plugins]`` section, add
189``[[mediagoblin.media_types.ascii]]``.
efd69313 190
3a8b18f8
JW
191Run
192
193.. code-block:: bash
3fe3b222 194
5ef7ab08
CAW
195 ./bin/gmg dbupdate
196
efd69313 197Now any .txt file you uploaded will be processed as ascii art!
5ef7ab08
CAW
198
199
200STL / 3d model support
201======================
202
203To enable the "STL" 3d model support plugin, first make sure you have
204a recentish `Blender <http://blender.org>`_ installed and available on
205your execution path. This feature has been tested with Blender 2.63.
206It may work on some earlier versions, but that is not guaranteed (and
207is surely not to work prior to Blender 2.5X).
208
91bee92e 209Add ``[[mediagoblin.media_types.stl]]`` under the ``[plugins]`` section in your
919cd2fd 210``mediagoblin_local.ini`` and restart MediaGoblin.
5ef7ab08 211
3a8b18f8
JW
212Run
213
214.. code-block:: bash
3fe3b222 215
5ef7ab08
CAW
216 ./bin/gmg dbupdate
217
218You should now be able to upload .obj and .stl files and MediaGoblin
219will be able to present them to your wide audience of admirers!
a80ebf3b
AL
220
221PDF and Document
222================
223
376dcbb4
AL
224To enable the "PDF and Document" support plugin, you need:
225
2261. pdftocairo and pdfinfo for pdf only support.
227
2282. unoconv with headless support to support converting libreoffice supported
229 documents as well, such as doc/ppt/xls/odf/odg/odp and more.
230 For the full list see mediagoblin/media_types/pdf/processing.py,
231 unoconv_supported.
232
233All executables must be on your execution path.
a80ebf3b
AL
234
235To install this on Fedora:
236
237.. code-block:: bash
238
3606316e 239 sudo yum install -y poppler-utils unoconv libreoffice-headless
a80ebf3b 240
376dcbb4
AL
241Note: You can leave out unoconv and libreoffice-headless if you want only pdf
242support. This will result in a much smaller list of dependencies.
243
a80ebf3b
AL
244pdf.js relies on git submodules, so be sure you have fetched them:
245
246.. code-block:: bash
247
248 git submodule init
249 git submodule update
250
251This feature has been tested on Fedora with:
252 poppler-utils-0.20.2-9.fc18.x86_64
253 unoconv-0.5-2.fc18.noarch
254 libreoffice-headless-3.6.5.2-8.fc18.x86_64
255
256It may work on some earlier versions, but that is not guaranteed.
257
91bee92e 258Add ``[[mediagoblin.media_types.pdf]]`` under the ``[plugins]`` section in your
919cd2fd 259``mediagoblin_local.ini`` and restart MediaGoblin.
a80ebf3b
AL
260
261Run
262
263.. code-block:: bash
264
265 ./bin/gmg dbupdate
266
267
b7d854bf
CAW
268Blog (HIGHLY EXPERIMENTAL)
269==========================
270
271MediaGoblin has a blog media type, which you might notice by looking
272through the docs! However, it is *highly experimental*. We have not
273security reviewed this, and it acts in a way that is not like normal
274blogs (the blogposts are themselves media types!).
275
2352f7c8
CAW
276So you can play with this, but it is not necessarily recommended yet
277for production use! :)