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

1099.1.1 by Matt Giuca
Began implementing new dispatch framework (with Will Grant and Nick Chadwick).
1
# IVLE - Informatics Virtual Learning Environment
2
# Copyright (C) 2007-2009 The University of Melbourne
3
#
4
# This program is free software; you can redistribute it and/or modify
5
# it under the terms of the GNU General Public License as published by
6
# the Free Software Foundation; either version 2 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 General Public License for more details.
13
#
14
# You should have received a copy of the GNU General Public License
15
# along with this program; if not, write to the Free Software
16
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
17
18
# Author: Matt Giuca, Will Grant
19
20
class BasePlugin(object):
21
    """
22
    Base class for all Plugin classes.
23
    """
24
    pass
1099.1.115 by William Grant
Add tabs to the new framework. Move the app icons into the apps themselves.
25
1099.1.72 by Nick Chadwick
Dispatch now generates an index for each plugin type, allowing plugins to
26
class ViewPlugin(BasePlugin):
27
    """Marker class for plugins that provide views.
1099.1.115 by William Grant
Add tabs to the new framework. Move the app icons into the apps themselves.
28
1294.2.123 by William Grant
Fix up the ViewPlugin docstring; it's all different now.
29
    View plugins have three main types of registration:
30
     - forward_routes: A list of traversals from objects to their
31
       descendants. The discriminator is the source class and a list of zero
32
       or more intermediate path segments. An optional argument count may be
33
       given -- arguments will be taken from the path after the intermediate
34
       segments. The specified callable will be given the source object and
35
       any arguments, and should return the target object.
36
37
     - reverse_routes: A list of traversals from objects to their parents.
38
       The discriminator is just the child class. The provided callable must
39
       return a tuple of (parent_object, ('intermediate', path', 'segments')).
40
41
     - views: A list of named views for objects. The discriminator is the
42
       context object class, view name, and an optional view set. An optional
43
       (possibly infinite) argument count may again be given. The arguments
44
       values will be taken from the path after the view name. The callable
45
       should take the request object, target object and subpath, and return
46
       a view object.
47
48
    See ivle.dispatch.generate_publisher for the registry code.
1099.1.115 by William Grant
Add tabs to the new framework. Move the app icons into the apps themselves.
49
1099.1.100 by Nick Chadwick
Created a new help system.
50
    View plugins may also have a 'help' property, which should contain a dict
51
    of dicts and help file names. This dict is then used to generate the
52
    appropriate entries in the help system.
1099.1.115 by William Grant
Add tabs to the new framework. Move the app icons into the apps themselves.
53
54
    Tabs can also be defined by view plugins. To define tabs, provide a 'tabs'
55
    property containing 6-tuples of (name, title, desc, icon, path, weight).
56
    The icon should be relative to the plugin's media directory, and the path
57
    should be relative to the root. The weight is used for ordering; larger
58
    weights are further right.
1099.1.72 by Nick Chadwick
Dispatch now generates an index for each plugin type, allowing plugins to
59
    """
60
    pass
1099.1.115 by William Grant
Add tabs to the new framework. Move the app icons into the apps themselves.
61
1099.1.146 by William Grant
Add support for public mode views to the new framework.
62
class PublicViewPlugin(BasePlugin):
63
    """Marker class for plugins that provide public mode views.
64
65
    Public view plugins can specify the same 'urls' property as normal view
1294.3.3 by William Grant
req.router -> req.publisher
66
    plugins, but they are added to the public mode publisher instead.
1099.1.146 by William Grant
Add support for public mode views to the new framework.
67
    """
68
    pass
69
1099.1.74 by Nick Chadwick
Added overlay system and console overlay. Note that the console overlay
70
class OverlayPlugin(BasePlugin):
1099.1.100 by Nick Chadwick
Created a new help system.
71
    """Marker class for plugins which provide overlays.
1099.1.115 by William Grant
Add tabs to the new framework. Move the app icons into the apps themselves.
72
1099.1.74 by Nick Chadwick
Added overlay system and console overlay. Note that the console overlay
73
    Overlay plugins provide mini-views which can be displayed on top of other
74
    views. The canonical example of a plugin of this type is the Console plugin.
75
    """
76
    pass
1099.1.80 by William Grant
Port the forum app to the new framework. With it also comes new cookie
77
78
class CookiePlugin(BasePlugin):
79
    """Marker class for plugins which provide cookies.
80
81
    Cookie plugins provide a 'cookies' dict mapping names to generation
82
    functions. The function should return the data to store in the cookie on
83
    login. If the function is None, the cookie is not created on login, just
84
    deleted on logout.
85
    """
86
    pass
1099.1.99 by William Grant
Require that plugins providing media subclass MediaPlugin.
87
88
class MediaPlugin(BasePlugin):
89
    """Marker class for plugins which provide media files.
90
91
    Media plugins provide a 'media' attribute, which is a string pointing to a
92
    subdirectory that contains media files to be served statically.
93
    """
94
    pass