MaxKB/apps/application/sql/list_application_user_ee.sql
2025-06-23 12:09:44 +08:00

43 lines
2.1 KiB
SQL

select *
from (select application."id"::text,
application."name",
application. "desc",
application. "is_publish",
application."type",
'application' as "resource_type",
application."workspace_id",
application. "folder_id",
application."user_id",
"user"."nick_name" as "nick_name",
application."create_time",
application."update_time"
from application left join "user" on user_id = "user".id
where "application".id in (select target
from workspace_user_resource_permission
where auth_target_type = 'APPLICATION'
and case
when auth_type = 'ROLE' then
'APPLICATION:READ' in (select (case when user_role_relation.role_id = any (array ['USER']) THEN 'APPLICATION:READ' else role_permission.permission_id END)
from role_permission role_permission
right join user_role_relation user_role_relation
on user_role_relation.role_id=role_permission.role_id
${user_query_set})
else
'VIEW' = any (permission_list)
end)
UNION
select application_folder."id",
application_folder."name",
application_folder."desc",
true as "is_publish",
'folder' as "type",
'folder' as "resource_type",
application_folder."workspace_id",
application_folder."parent_id" as "folder_id",
application_folder."user_id",
"user"."nick_name" as "nick_name",
application_folder."create_time",
application_folder."update_time"
from application_folder left join "user" on user_id = "user".id ${folder_query_set}) temp
${application_query_set}