Compare commits

...

2 Commits

Author SHA1 Message Date
Hugh A. Miles II
80ba00952e change relationship (#14435)
(cherry picked from commit efcdc8cb9b)
2021-05-03 11:30:58 -07:00
Daniel Vaz Gaspar
55ba0f9fce fix: bootstrap data permissions (#14348)
(cherry picked from commit b4e527a8c4)
2021-05-03 11:30:45 -07:00
4 changed files with 11 additions and 16 deletions

View File

@@ -66,7 +66,7 @@ dnspython==2.0.0
# via email-validator # via email-validator
email-validator==1.1.1 email-validator==1.1.1
# via flask-appbuilder # via flask-appbuilder
flask-appbuilder==3.2.1 flask-appbuilder==3.2.3
# via apache-superset # via apache-superset
flask-babel==1.0.0 flask-babel==1.0.0
# via flask-appbuilder # via flask-appbuilder

View File

@@ -75,7 +75,7 @@ setup(
"cron-descriptor", "cron-descriptor",
"cryptography>=3.2.1", "cryptography>=3.2.1",
"flask>=1.1.0, <2.0.0", "flask>=1.1.0, <2.0.0",
"flask-appbuilder>=3.2.1, <4.0.0", "flask-appbuilder>=3.2.3, <4.0.0",
"flask-caching", "flask-caching",
"flask-compress", "flask-compress",
"flask-talisman", "flask-talisman",

View File

@@ -420,7 +420,7 @@ const DatasetList: FunctionComponent<DatasetListProps> = ({
Header: t('Database'), Header: t('Database'),
id: 'database', id: 'database',
input: 'select', input: 'select',
operator: FilterOperator.relationManyMany, operator: FilterOperator.relationOneMany,
unfilteredLabel: 'All', unfilteredLabel: 'All',
fetchSelects: createFetchRelated( fetchSelects: createFetchRelated(
'dataset', 'dataset',

View File

@@ -40,7 +40,7 @@ from superset.exceptions import (
SupersetException, SupersetException,
SupersetSecurityException, SupersetSecurityException,
) )
from superset.extensions import cache_manager from superset.extensions import cache_manager, security_manager
from superset.legacy import update_time_range from superset.legacy import update_time_range
from superset.models.core import Database from superset.models.core import Database
from superset.models.dashboard import Dashboard from superset.models.dashboard import Dashboard
@@ -87,20 +87,15 @@ def get_permissions(
if not user.roles: if not user.roles:
raise AttributeError("User object does not have roles") raise AttributeError("User object does not have roles")
roles = {} roles = defaultdict(list)
permissions = defaultdict(set) permissions = defaultdict(set)
for role in user.roles: for role in user.roles:
perms = set() permissions_ = security_manager.get_role_permissions(role)
for perm in role.permissions: for permission in permissions_:
if perm.permission and perm.view_menu: if permission[0] in ("datasource_access", "database_access"):
perms.add((perm.permission.name, perm.view_menu.name)) permissions[permission[0]].add(permission[1])
if perm.permission.name in ("datasource_access", "database_access"): roles[role.name].append([permission[0], permission[1]])
permissions[perm.permission.name].add(perm.view_menu.name)
roles[role.name] = [
[perm.permission.name, perm.view_menu.name]
for perm in role.permissions
if perm.permission and perm.view_menu
]
return roles, permissions return roles, permissions