Work towards getting plugin static linking/serving to work
authorChristopher Allan Webber <cwebber@dustycloud.org>
Tue, 21 May 2013 21:07:18 +0000 (16:07 -0500)
committerChristopher Allan Webber <cwebber@dustycloud.org>
Thu, 23 May 2013 18:33:07 +0000 (13:33 -0500)
 - add link_plugin_assets.  For now, incorrectly running from
   ./bin/gmg theme assetlink... uh, will fix ;)
 - Update paste and config_spec.ini configs to handle the locations
   and serving of the plugins' static resources

This commit sponsored by Marko Dimjašević.  Thank you!

mediagoblin/config_spec.ini
mediagoblin/gmg_commands/theme.py
mediagoblin/init/__init__.py
paste.ini

index 2af4adb217fc4deedc549b35ccf8557a97d93747..75fffffddff6972f9079c301d763b071823bc720 100644 (file)
@@ -69,6 +69,10 @@ theme_web_path = string(default="/theme_static/")
 theme_linked_assets_dir = string(default="%(here)s/user_dev/theme_static/")
 theme = string()
 
+# plugin default assets directory
+plugin_web_path = string(default="/plugin_static/")
+plugin_linked_assets_dir = string(default="%(here)s/user_dev/plugin_static/")
+
 
 [storage:publicstore]
 storage_class = string(default="mediagoblin.storage.filestorage:BasicFileStorage")
index 71abb982f2e56952bf120ecb373cb567baca4cdb..3b77fe887c7d09c73fe230bc165388ac62e3f44f 100644 (file)
 import os
 
 from mediagoblin.init import setup_global_and_app_config
+from mediagoblin.gmg_commands import util as commands_util
 from mediagoblin.tools.theme import register_themes
 from mediagoblin.tools.translate import pass_to_ugettext as _
 from mediagoblin.tools.common import simple_printer
+from mediagoblin.tools import pluginapi
 
 
 def theme_parser_setup(subparser):
@@ -44,7 +46,7 @@ def theme_parser_setup(subparser):
 # Utilities
 ###########
 
-def link_assets(theme, link_dir, printer=simple_printer):
+def link_theme_assets(theme, link_dir, printer=simple_printer):
     """
     Returns a list of string of text telling the user what we did
     which should be printable.
@@ -52,11 +54,9 @@ def link_assets(theme, link_dir, printer=simple_printer):
     link_dir = link_dir.rstrip(os.path.sep)
     link_parent_dir = os.path.dirname(link_dir)
 
-    results = []
-
     if theme is None:
         printer(_("Cannot link theme... no theme set\n"))
-        return results
+        return
 
     def _maybe_unlink_link_dir():
         """unlink link directory if it exists"""
@@ -65,14 +65,14 @@ def link_assets(theme, link_dir, printer=simple_printer):
             os.unlink(link_dir)
             return True
 
-        return results
+        return
 
     if theme.get('assets_dir') is None:
         printer(_("No asset directory for this theme\n"))
         if _maybe_unlink_link_dir():
             printer(
                 _("However, old link directory symlink found; removed.\n"))
-        return results
+        return
 
     _maybe_unlink_link_dir()
 
@@ -87,6 +87,51 @@ def link_assets(theme, link_dir, printer=simple_printer):
         theme['assets_dir'], link_dir))
 
 
+def link_plugin_assets(plugin_static, plugins_link_dir, printer=simple_printer):
+    """
+    Arguments:
+     - plugin_static: a mediagoblin.tools.staticdirect.PluginStatic instance
+       representing the static assets of this plugins' configuration
+     - plugins_link_dir: Base directory plugins are linked from
+    """
+    # link_dir is the final directory we'll link to, a combination of
+    # the plugin assetlink directory and plugin_static.name
+    link_dir = os.path.sep.join(
+        plugins_link_dir.rstrip(os.path.sep), plugin_static.name)
+
+    # make the link directory parent dirs if necessary
+    if not os.path.lexists(plugins_link_dir):
+        os.makedirs(plugins_link_dir)
+
+    # See if the link_dir already exists.
+    if os.path.lexists(link_dir):
+        # if this isn't a symlink, there's something wrong... error out.
+        if not os.path.islink(link_dir):
+            printer(_('Could not link "%s": %s exists and is not a symlink') % (
+                link_dir))
+            return
+
+        # if this is a symlink and the path already exists, skip it.
+        if os.path.realpath(link_dir) == plugin_static.file_path:
+            # Is this comment helpful or not?
+            printer(_('Skipping "%s"; already set up.') % (
+                plugin_static.name))
+            return
+
+        # Otherwise, it's a link that went to something else... unlink it
+        printer(_('Old link found for "%s"; removing.') % (
+            plugin_static.name))
+        os.unlink(link_dir)
+
+    os.symlink(
+        plugin_static.file_path.rstrip(os.path.sep),
+        link_dir)
+    printer('Linked asset directory for plugin "%s":\n  %s\nto:\n  %s\n' % (
+        plugin_static.name,
+        plugin_static.file_path.rstrip(os.path.sep),
+        link_dir))
+
+
 def install_theme(install_dir, themefile):
     pass # TODO ;)
 
@@ -101,7 +146,18 @@ def assetlink_command(args):
     """
     global_config, app_config = setup_global_and_app_config(args.conf_file)
     theme_registry, current_theme = register_themes(app_config)
-    link_assets(current_theme, app_config['theme_linked_assets_dir'])
+
+    # link theme
+    link_theme_assets(current_theme, app_config['theme_linked_assets_dir'])
+
+    # Set up the app specifically so we can access the plugin infrastructure
+    commands_util.setup_app(args)
+
+    # link plugin assets
+    ## ... probably for this we need the whole application initialized
+    for plugin_static in pluginapi.hook_runall("static_setup"):
+        link_plugin_assets(
+            plugin_static, app_config['plugin_linked_assets_dir'])
 
 
 def install_command(args):
index 1eb9f1ba156bd328f83f78bde55614c4d0c9c506..6eed8ff8292268babe19464b586c2cb3f69916ec 100644 (file)
@@ -24,7 +24,7 @@ from mediagoblin import mg_globals
 from mediagoblin.mg_globals import setup_globals
 from mediagoblin.db.open import setup_connection_and_db_from_config, \
     check_db_migrations_current, load_models
-from mediagoblin.pluginapi import hook_runall
+from mediagoblin.tools.pluginapi import hook_runall
 from mediagoblin.tools.workbench import WorkbenchManager
 from mediagoblin.storage import storage_system_from_config
 
index 4c6397fad793336b02f6327ea713b8ddd247bb8d..3ac785adcf0d83a8ba3d579a559ebbb9408e006e 100644 (file)
--- a/paste.ini
+++ b/paste.ini
@@ -56,6 +56,11 @@ use = egg:Paste#static
 document_root = %(here)s/user_dev/theme_static/
 cache_max_age = 86400
 
+[app:plugin_static]
+use = egg:Paste#static
+document_root = %(here)s/user_dev/plugin_static/
+cache_max_age = 86400
+
 [filter:errors]
 use = egg:mediagoblin#errors
 debug = false