3 # Copyright (C) 2014 Simo Sorce <simo@redhat.com>
5 # see file 'COPYING' for use and warranty information
7 # This program is free software; you can redistribute it and/or modify
8 # it under the terms of the GNU General Public License as published by
9 # the Free Software Foundation, either version 3 of the License, or
10 # (at your option) any later version.
12 # This program is distributed in the hope that it will be useful,
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License
18 # along with this program. If not, see <http://www.gnu.org/licenses/>.
21 from ipsilon.util.page import Page
22 from ipsilon.util.page import admin_protect
25 class AdminPage(Page):
27 def __init__(self, *args, **kwargs):
28 super(AdminPage, self).__init__(*args, **kwargs)
29 self.default_headers.update({
30 'Cache-Control': 'no-cache, must-revalidate',
32 'Expires': 'Thu, 01 Dec 1994 16:00:00 GMT',
34 self.auth_protect = True
37 class AdminPluginPage(AdminPage):
39 def __init__(self, obj, site, parent):
40 super(AdminPluginPage, self).__init__(site, form=True)
42 self.title = '%s plugin' % obj.name
43 self.url = '%s/%s' % (parent.url, obj.name)
44 self.facility = parent.facility
46 self.back = parent.url
49 self.plugin_config = obj.get_config_desc()
50 if not self.plugin_config:
51 self.plugin_config = dict()
53 # Now overlay the actual config
54 for option in self.plugin_config:
55 self.plugin_config[option][2] = obj.get_config_value(option)
57 self.options_order = []
58 if hasattr(obj, 'conf_opt_order'):
59 self.options_order = obj.conf_opt_order
61 # append any undefined options
63 for k in self.plugin_config.keys():
64 if k not in self.options_order:
69 self.options_order.append(k)
72 def GET(self, *args, **kwargs):
73 return self._template('admin/plugin_config.html', title=self.title,
74 name='admin_%s_%s_form' % (self.facility,
76 menu=self.menu, action=self.url, back=self.back,
77 options_order=self.options_order,
78 options=self.plugin_config)
81 def POST(self, *args, **kwargs):
83 message = "Nothing was modified."
87 for key, value in kwargs.iteritems():
88 if key in self.plugin_config:
89 if value != self.plugin_config[key][2]:
90 cherrypy.log.error("Storing [%s]: %s = %s" %
91 (self._obj.name, key, value))
92 new_values[key] = value
94 if len(new_values) != 0:
95 # First we try to save in the database
97 self._obj.save_plugin_config(self.facility, new_values)
98 message = "New configuration saved."
99 message_type = "success"
100 except Exception: # pylint: disable=broad-except
101 message = "Failed to save data!"
102 message_type = "error"
104 # And only if it succeeds we change the live object
105 for name, value in new_values.items():
106 self._obj.set_config_value(name, value)
107 self.plugin_config[name][2] = value
109 return self._template('admin/plugin_config.html', title=self.title,
111 message_type=message_type,
112 name='admin_%s_%s_form' % (self.facility,
114 menu=self.menu, action=self.url,
115 options=self.plugin_config)
118 class Admin(AdminPage):
120 def __init__(self, site, mount):
121 super(Admin, self).__init__(site)
122 self.url = '%s/%s' % (self.basepath, mount)
125 def root(self, *args, **kwargs):
126 return self._template('admin/index.html',
127 title='Configuration',
130 def add_subtree(self, name, page):
131 self.__dict__[name] = page
132 self.menu.append(page)
134 def del_subtree(self, name):
135 self.menu.remove(self.__dict__[name])
136 del self.__dict__[name]