Configuring apps to work with django CMS¶
App Hooks¶
- classcms.app_base.CMSApp¶
Base class for creating apphooks. Apphooks live in a file called
cms_apps.py. To create an AppHook subclassCMSAppincms_apps.pyclassMyAppHook(CMSApp): name = "Problem solver"
- _urls¶
list of urlconfs: example:
_urls = ["myapp.urls"]
list of menu classes: example:
_menus = [MyAppMenu]
- get_config(namespace)¶
Returns the apphook configuration instance linked to the given namespace
To be implemented by apphook subclass.
- get_config_add_url()¶
Returns the url to add a new apphook configuration instance (usually the model admin add view)
To be implemented by apphook subclass.
- get_configs()¶
Returns all the apphook configuration instances.
To be implemented by apphook subclass.
Returns the menus for the apphook instance, eventually selected according to the given arguments.
By default, it returns the menus assigned to
CMSApp._menus.The method accepts page, language and generic keyword arguments: you can customize this function to return different list of menu classes according to the given arguments.
If no menus are returned, then the user will need to attach menus to pages manually in the admin.
If no page and language are provided, this method must return all the menus used by this apphook. Example:
if page and page.reverse_id == 'page1': return [Menu1] elif page and page.reverse_id == 'page2': return [Menu2] else: return [Menu1, Menu2]
- Parameters:
page – page the apphook is attached to
language – current site language
- Returns:
list of menu classes
- get_urls(page=None, language=None, **kwargs)¶
Returns the urlconfs for the apphook instance, eventually selected according to the given arguments.
By default, it returns the urls assigned to
CMSApp._urlsThe method accepts page, language and generic keyword arguments: you can customize this function to return different list of menu classes according to the given arguments.
This method must return a non-empty list of urlconfs, even if no argument is passed.
- Parameters:
page – page the apphook is attached to
language – current site language
- Returns:
list of urlconfs strings
- app_config=None¶
configuration model (optional)
- app_name=None¶
Gives the system a unique way to refer to the apphook. This enables Django namespaces support (optional)
- exclude_permissions=[]¶
list of application names to exclude from inheriting CMS permissions
- name=None¶
Human-readable name of the apphook (required). This name will be displayed on the admin site.
- permissions=True¶
if set to true, apphook inherits permissions from the current page
App Config¶
- classcms.app_base.CMSAppConfig(django_app_config)¶
Added in version 4.0.
Base class that all cms app configurations should inherit from.
CMSAppConfig live in a file called
cms_config.py.Apps subclassing
CMSAppConfigcan setcms_enabled = Truefor their app config to use django CMS’ wizard functionality. Additional wizzwards are listed in the app config’scms_wizzardsproperty.The second functionality that django CMS offers is attaching Model objects to the toolbar. To use this functionality, set list the Model classes in
cms_toolbar_enabled_modelsand havecms_enabled = True
App Extensions¶
- classcms.app_base.CMSAppExtension¶
Added in version 4.0.
Base class that all cms app extensions should inherit from. App extensions allow apps to offer their functionality to other apps, e.g., as done by djangocms-versioning.
CMSAppExtensions live in a file called
cms_config.py.- abstractmethodconfigure_app(cms_config)¶
Implement this method if the app provides functionality that other apps can use and configure.
This method will be run once for every app that defines an attribute like
<app_label>_enabledasTrueon its cms app config class.So for example, if app A with label "app_a" implements this method and app B and app C define
app_a_enabled = Trueon their cms config classes, the method app A has defined will run twice, once for app B and once for app C.- Parameters:
cms_config (
CMSAppConfigsubclass) – the cms config class of the app registering for additional functionality
- ready()¶
Override this method to run code after all CMS extensions have been configured.
This method will be run once, even if no cms app config sets its
<app_label>_enabledattribute toTrue