mirror of
https://github.com/freedombox/FreedomBox.git
synced 2026-01-28 08:03:36 +00:00
- Add a field `allowed_groups` to shortcuts, which will contain groups which can access a particular app - When a user is logged in, only return those shortcuts to the front page if the user is allowed to access them. This check is done based on the allowed_groups field of the shortcut - Add allowed_groups for shortcuts of all apps with group-restricted access Signed-off-by: Hemanth Kumar Veeranki <hemanthveeranki@gmail.com> Reviewed-by: Joseph Nuthalapati <njoseph@thoughtworks.com>
102 lines
3.1 KiB
Python
102 lines
3.1 KiB
Python
#
|
|
# This file is part of FreedomBox.
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Affero General Public License as
|
|
# published by the Free Software Foundation, either version 3 of the
|
|
# License, or (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU Affero General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
"""
|
|
Manage application shortcuts on front page.
|
|
"""
|
|
from . import actions
|
|
|
|
shortcuts = {}
|
|
|
|
|
|
def get_shortcuts(username):
|
|
"""Return menu items in sorted order according to current locale."""
|
|
if username:
|
|
shortcuts_to_return = {}
|
|
output = actions.superuser_run('users', ['get-user-groups', username])
|
|
user_groups = set(output.strip().split('\n'))
|
|
|
|
if 'admin' in user_groups:
|
|
# Admin has access to all services
|
|
return sorted(shortcuts.values(), key=lambda item: item['label'])
|
|
|
|
for shortcut_id, shortcut in shortcuts.items():
|
|
if shortcut['allowed_groups']:
|
|
if not user_groups.isdisjoint(shortcut['allowed_groups']):
|
|
shortcuts_to_return[shortcut_id] = shortcut
|
|
else:
|
|
shortcuts_to_return[shortcut_id] = shortcut
|
|
|
|
return sorted(shortcuts_to_return.values(),
|
|
key=lambda item: item['label'])
|
|
else:
|
|
return sorted(shortcuts.values(), key=lambda item: item['label'])
|
|
|
|
|
|
def add_shortcut(shortcut_id, name, short_description="", login_required=False,
|
|
icon=None, url=None, details=None, configure_url=None,
|
|
allowed_groups=None):
|
|
"""Add shortcut to front page."""
|
|
|
|
if not url:
|
|
url = '?selected={id}'.format(id=shortcut_id)
|
|
|
|
if not icon:
|
|
icon = shortcut_id
|
|
|
|
label = '{0}\n({1})'.format(short_description, name) if short_description \
|
|
else name
|
|
|
|
shortcuts[shortcut_id] = {
|
|
'id': shortcut_id,
|
|
'name': name,
|
|
'short_description': short_description,
|
|
'label': label,
|
|
'url': url,
|
|
'icon': icon,
|
|
'login_required': login_required,
|
|
'details': details,
|
|
'configure_url': configure_url,
|
|
'hidden': False,
|
|
'allowed_groups': allowed_groups
|
|
}
|
|
|
|
|
|
def remove_shortcut(shortcut_id):
|
|
"""
|
|
Remove shortcut from front page.
|
|
|
|
If shortcut_id ends with *, remove all shortcuts with that prefix.
|
|
"""
|
|
|
|
def match(item):
|
|
if shortcut_id[-1] == '*':
|
|
return item['id'].startswith(shortcut_id[:-1])
|
|
|
|
return item['id'] == shortcut_id
|
|
|
|
global shortcuts
|
|
shortcuts = {
|
|
shortcut_id: shortcut
|
|
for shortcut_id, shortcut in shortcuts.items() if not match(shortcut)
|
|
}
|
|
|
|
|
|
def hide_shortcut(shortcut_id, hide=True):
|
|
"""Mark a shortcut as hidden or not hidden."""
|
|
global shortcuts
|
|
shortcuts[shortcut_id]['hidden'] = hide
|