mirror of
https://git.mirrors.martin98.com/https://github.com/langgenius/dify.git
synced 2025-08-14 04:35:56 +08:00
owner and admin have all permission of knowledge base (#12157)
This commit is contained in:
parent
5a3fe61f2a
commit
f4f2567105
@ -86,12 +86,15 @@ class DatasetService:
|
|||||||
else:
|
else:
|
||||||
return [], 0
|
return [], 0
|
||||||
else:
|
else:
|
||||||
|
if user.current_role not in (TenantAccountRole.OWNER, TenantAccountRole.ADMIN):
|
||||||
# show all datasets that the user has permission to access
|
# show all datasets that the user has permission to access
|
||||||
if permitted_dataset_ids:
|
if permitted_dataset_ids:
|
||||||
query = query.filter(
|
query = query.filter(
|
||||||
db.or_(
|
db.or_(
|
||||||
Dataset.permission == DatasetPermissionEnum.ALL_TEAM,
|
Dataset.permission == DatasetPermissionEnum.ALL_TEAM,
|
||||||
db.and_(Dataset.permission == DatasetPermissionEnum.ONLY_ME, Dataset.created_by == user.id),
|
db.and_(
|
||||||
|
Dataset.permission == DatasetPermissionEnum.ONLY_ME, Dataset.created_by == user.id
|
||||||
|
),
|
||||||
db.and_(
|
db.and_(
|
||||||
Dataset.permission == DatasetPermissionEnum.PARTIAL_TEAM,
|
Dataset.permission == DatasetPermissionEnum.PARTIAL_TEAM,
|
||||||
Dataset.id.in_(permitted_dataset_ids),
|
Dataset.id.in_(permitted_dataset_ids),
|
||||||
@ -102,7 +105,9 @@ class DatasetService:
|
|||||||
query = query.filter(
|
query = query.filter(
|
||||||
db.or_(
|
db.or_(
|
||||||
Dataset.permission == DatasetPermissionEnum.ALL_TEAM,
|
Dataset.permission == DatasetPermissionEnum.ALL_TEAM,
|
||||||
db.and_(Dataset.permission == DatasetPermissionEnum.ONLY_ME, Dataset.created_by == user.id),
|
db.and_(
|
||||||
|
Dataset.permission == DatasetPermissionEnum.ONLY_ME, Dataset.created_by == user.id
|
||||||
|
),
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
@ -377,12 +382,17 @@ class DatasetService:
|
|||||||
if dataset.tenant_id != user.current_tenant_id:
|
if dataset.tenant_id != user.current_tenant_id:
|
||||||
logging.debug(f"User {user.id} does not have permission to access dataset {dataset.id}")
|
logging.debug(f"User {user.id} does not have permission to access dataset {dataset.id}")
|
||||||
raise NoPermissionError("You do not have permission to access this dataset.")
|
raise NoPermissionError("You do not have permission to access this dataset.")
|
||||||
|
if user.current_role not in (TenantAccountRole.OWNER, TenantAccountRole.ADMIN):
|
||||||
if dataset.permission == DatasetPermissionEnum.ONLY_ME and dataset.created_by != user.id:
|
if dataset.permission == DatasetPermissionEnum.ONLY_ME and dataset.created_by != user.id:
|
||||||
logging.debug(f"User {user.id} does not have permission to access dataset {dataset.id}")
|
logging.debug(f"User {user.id} does not have permission to access dataset {dataset.id}")
|
||||||
raise NoPermissionError("You do not have permission to access this dataset.")
|
raise NoPermissionError("You do not have permission to access this dataset.")
|
||||||
if dataset.permission == "partial_members":
|
if dataset.permission == "partial_members":
|
||||||
user_permission = DatasetPermission.query.filter_by(dataset_id=dataset.id, account_id=user.id).first()
|
user_permission = DatasetPermission.query.filter_by(dataset_id=dataset.id, account_id=user.id).first()
|
||||||
if not user_permission and dataset.tenant_id != user.current_tenant_id and dataset.created_by != user.id:
|
if (
|
||||||
|
not user_permission
|
||||||
|
and dataset.tenant_id != user.current_tenant_id
|
||||||
|
and dataset.created_by != user.id
|
||||||
|
):
|
||||||
logging.debug(f"User {user.id} does not have permission to access dataset {dataset.id}")
|
logging.debug(f"User {user.id} does not have permission to access dataset {dataset.id}")
|
||||||
raise NoPermissionError("You do not have permission to access this dataset.")
|
raise NoPermissionError("You do not have permission to access this dataset.")
|
||||||
|
|
||||||
@ -394,6 +404,7 @@ class DatasetService:
|
|||||||
if not user:
|
if not user:
|
||||||
raise ValueError("User not found")
|
raise ValueError("User not found")
|
||||||
|
|
||||||
|
if user.current_role not in (TenantAccountRole.OWNER, TenantAccountRole.ADMIN):
|
||||||
if dataset.permission == DatasetPermissionEnum.ONLY_ME:
|
if dataset.permission == DatasetPermissionEnum.ONLY_ME:
|
||||||
if dataset.created_by != user.id:
|
if dataset.created_by != user.id:
|
||||||
raise NoPermissionError("You do not have permission to access this dataset.")
|
raise NoPermissionError("You do not have permission to access this dataset.")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user