~azzar1/unity/add-show-desktop-key

« back to all changes in this revision

Viewing changes to ivle/webapp/base/plugins.py

Merge from object-publishing.

Show diffs side-by-side

added added

removed removed

Lines of Context:
22
22
    Base class for all Plugin classes.
23
23
    """
24
24
    pass
 
25
 
 
26
class ViewPlugin(BasePlugin):
 
27
    """Marker class for plugins that provide views.
 
28
 
 
29
    View plugins must have a 'urls' property which contains an iterable of pairs
 
30
    or triples, like (routex string, handler class, kwargs dict). The kwargs
 
31
    dict is optional. If present, the members of the kwargs dict will be passed
 
32
    as keyword arguments to the constructor of the view object.
 
33
 
 
34
    View plugins may also have a 'help' property, which should contain a dict
 
35
    of dicts and help file names. This dict is then used to generate the
 
36
    appropriate entries in the help system.
 
37
 
 
38
    Tabs can also be defined by view plugins. To define tabs, provide a 'tabs'
 
39
    property containing 6-tuples of (name, title, desc, icon, path, weight).
 
40
    The icon should be relative to the plugin's media directory, and the path
 
41
    should be relative to the root. The weight is used for ordering; larger
 
42
    weights are further right.
 
43
    """
 
44
    pass
 
45
 
 
46
class PublicViewPlugin(BasePlugin):
 
47
    """Marker class for plugins that provide public mode views.
 
48
 
 
49
    Public view plugins can specify the same 'urls' property as normal view
 
50
    plugins, but they are added to the public mode publisher instead.
 
51
    """
 
52
    pass
 
53
 
 
54
class OverlayPlugin(BasePlugin):
 
55
    """Marker class for plugins which provide overlays.
 
56
 
 
57
    Overlay plugins provide mini-views which can be displayed on top of other
 
58
    views. The canonical example of a plugin of this type is the Console plugin.
 
59
    """
 
60
    pass
 
61
 
 
62
class CookiePlugin(BasePlugin):
 
63
    """Marker class for plugins which provide cookies.
 
64
 
 
65
    Cookie plugins provide a 'cookies' dict mapping names to generation
 
66
    functions. The function should return the data to store in the cookie on
 
67
    login. If the function is None, the cookie is not created on login, just
 
68
    deleted on logout.
 
69
    """
 
70
    pass
 
71
 
 
72
class MediaPlugin(BasePlugin):
 
73
    """Marker class for plugins which provide media files.
 
74
 
 
75
    Media plugins provide a 'media' attribute, which is a string pointing to a
 
76
    subdirectory that contains media files to be served statically.
 
77
    """
 
78
    pass