Switching the hook 'get_media_manager' to a more "directed" tuple-hook
[mediagoblin.git] / mediagoblin / media_types / ascii / __init__.py
1 # GNU MediaGoblin -- federated, autonomous media hosting
2 # Copyright (C) 2011, 2012 MediaGoblin contributors. See AUTHORS.
3 #
4 # This program is free software: you can redistribute it and/or modify
5 # it under the terms of the GNU Affero General Public License as published by
6 # the Free Software Foundation, either version 3 of the License, or
7 # (at your option) any later version.
8 #
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU Affero General Public License for more details.
13 #
14 # You should have received a copy of the GNU Affero General Public License
15 # along with this program. If not, see <http://www.gnu.org/licenses/>.
16
17 from mediagoblin.media_types import MediaManagerBase
18 from mediagoblin.media_types.ascii.processing import process_ascii, \
19 sniff_handler
20 from mediagoblin.tools import pluginapi
21
22 ACCEPTED_EXTENSIONS = ["txt", "asc", "nfo"]
23 MEDIA_TYPE = 'mediagoblin.media_types.ascii'
24
25
26 def setup_plugin():
27 config = pluginapi.get_config(MEDIA_TYPE)
28
29
30 class ASCIIMediaManager(MediaManagerBase):
31 human_readable = "ASCII"
32 processor = staticmethod(process_ascii)
33 display_template = "mediagoblin/media_displays/ascii.html"
34 default_thumb = "images/media_thumbs/ascii.jpg"
35
36
37 def get_media_type_and_manager(ext):
38 if ext in ACCEPTED_EXTENSIONS:
39 return MEDIA_TYPE, ASCIIMediaManager
40
41
42 hooks = {
43 'setup': setup_plugin,
44 'get_media_type_and_manager': get_media_type_and_manager,
45 ('media_manager', MEDIA_TYPE): lambda: ASCIIMediaManager,
46 'sniff_handler': sniff_handler,
47 }