converted ascii media_type to plugin
This commit is contained in:
parent
e699197258
commit
2293081231
@ -17,15 +17,36 @@
|
|||||||
from mediagoblin.media_types import MediaManagerBase
|
from mediagoblin.media_types import MediaManagerBase
|
||||||
from mediagoblin.media_types.ascii.processing import process_ascii, \
|
from mediagoblin.media_types.ascii.processing import process_ascii, \
|
||||||
sniff_handler
|
sniff_handler
|
||||||
|
from mediagoblin.tools import pluginapi
|
||||||
|
|
||||||
|
ACCEPTED_EXTENSIONS = ["txt", "asc", "nfo"]
|
||||||
|
MEDIA_TYPE = 'mediagoblin.media_types.ascii'
|
||||||
|
|
||||||
|
|
||||||
|
def setup_plugin():
|
||||||
|
config = pluginapi.get_config(MEDIA_TYPE)
|
||||||
|
|
||||||
|
|
||||||
class ASCIIMediaManager(MediaManagerBase):
|
class ASCIIMediaManager(MediaManagerBase):
|
||||||
human_readable = "ASCII"
|
human_readable = "ASCII"
|
||||||
processor = staticmethod(process_ascii)
|
processor = staticmethod(process_ascii)
|
||||||
sniff_handler = staticmethod(sniff_handler)
|
|
||||||
display_template = "mediagoblin/media_displays/ascii.html"
|
display_template = "mediagoblin/media_displays/ascii.html"
|
||||||
default_thumb = "images/media_thumbs/ascii.jpg"
|
default_thumb = "images/media_thumbs/ascii.jpg"
|
||||||
accepted_extensions = ["txt", "asc", "nfo"]
|
|
||||||
|
|
||||||
|
|
||||||
MEDIA_MANAGER = ASCIIMediaManager
|
|
||||||
|
def get_media_manager(media_type):
|
||||||
|
if media_type == MEDIA_TYPE:
|
||||||
|
return ASCIIMediaManager
|
||||||
|
|
||||||
|
|
||||||
|
def get_media_type_and_manager(ext):
|
||||||
|
if ext in ACCEPTED_EXTENSIONS:
|
||||||
|
return MEDIA_TYPE, ASCIIMediaManager
|
||||||
|
|
||||||
|
|
||||||
|
hooks = {
|
||||||
|
'setup': setup_plugin,
|
||||||
|
'get_media_type_and_manager': get_media_type_and_manager,
|
||||||
|
'sniff_handler': sniff_handler,
|
||||||
|
'get_media_manager': get_media_manager,
|
||||||
|
}
|
||||||
|
@ -28,17 +28,19 @@ from mediagoblin.media_types.ascii import asciitoimage
|
|||||||
_log = logging.getLogger(__name__)
|
_log = logging.getLogger(__name__)
|
||||||
|
|
||||||
SUPPORTED_EXTENSIONS = ['txt', 'asc', 'nfo']
|
SUPPORTED_EXTENSIONS = ['txt', 'asc', 'nfo']
|
||||||
|
MEDIA_TYPE = 'mediagoblin.media_types.ascii'
|
||||||
|
|
||||||
|
|
||||||
def sniff_handler(media_file, **kw):
|
def sniff_handler(media_file, **kw):
|
||||||
|
_log.info('Sniffing {0}'.format(MEDIA_TYPE))
|
||||||
if kw.get('media') is not None:
|
if kw.get('media') is not None:
|
||||||
name, ext = os.path.splitext(kw['media'].filename)
|
name, ext = os.path.splitext(kw['media'].filename)
|
||||||
clean_ext = ext[1:].lower()
|
clean_ext = ext[1:].lower()
|
||||||
|
|
||||||
if clean_ext in SUPPORTED_EXTENSIONS:
|
if clean_ext in SUPPORTED_EXTENSIONS:
|
||||||
return True
|
return MEDIA_TYPE
|
||||||
|
|
||||||
return False
|
return None
|
||||||
|
|
||||||
|
|
||||||
def process_ascii(proc_state):
|
def process_ascii(proc_state):
|
||||||
|
Loading…
x
Reference in New Issue
Block a user