@goplusvn/core 0.1.1 → 0.1.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +31 -175
- package/dist/audit/index.d.mts +0 -115
- package/dist/audit/index.d.ts +0 -115
- package/dist/audit/index.js +0 -204
- package/dist/audit/index.js.map +0 -1
- package/dist/audit/index.mjs +0 -200
- package/dist/audit/index.mjs.map +0 -1
- package/dist/auth/index.d.mts +0 -86
- package/dist/auth/index.d.ts +0 -86
- package/dist/auth/index.js +0 -210
- package/dist/auth/index.js.map +0 -1
- package/dist/auth/index.mjs +0 -198
- package/dist/auth/index.mjs.map +0 -1
- package/dist/button-1dWvP9Ib.d.mts +0 -30
- package/dist/button-1dWvP9Ib.d.ts +0 -30
- package/dist/calendar-2QzdEo1z.d.mts +0 -20
- package/dist/calendar-2QzdEo1z.d.ts +0 -20
- package/dist/code-generation/index.d.mts +0 -30
- package/dist/code-generation/index.d.ts +0 -30
- package/dist/code-generation/index.js +0 -31
- package/dist/code-generation/index.js.map +0 -1
- package/dist/code-generation/index.mjs +0 -28
- package/dist/code-generation/index.mjs.map +0 -1
- package/dist/configs/index.d.mts +0 -175
- package/dist/configs/index.d.ts +0 -175
- package/dist/configs/index.js +0 -254
- package/dist/configs/index.js.map +0 -1
- package/dist/configs/index.mjs +0 -233
- package/dist/configs/index.mjs.map +0 -1
- package/dist/crud/index.d.mts +0 -646
- package/dist/crud/index.d.ts +0 -646
- package/dist/crud/index.js +0 -11772
- package/dist/crud/index.js.map +0 -1
- package/dist/crud/index.mjs +0 -11665
- package/dist/crud/index.mjs.map +0 -1
- package/dist/crud/server.d.mts +0 -20
- package/dist/crud/server.d.ts +0 -20
- package/dist/crud/server.js +0 -123
- package/dist/crud/server.js.map +0 -1
- package/dist/crud/server.mjs +0 -120
- package/dist/crud/server.mjs.map +0 -1
- package/dist/data-table-skeleton-12NA8Mjx.d.mts +0 -39
- package/dist/data-table-skeleton-12NA8Mjx.d.ts +0 -39
- package/dist/dialog-bKfjZMTd.d.mts +0 -22
- package/dist/dialog-bKfjZMTd.d.ts +0 -22
- package/dist/dynamic-icon-DrGIiu2N.d.mts +0 -10
- package/dist/dynamic-icon-DrGIiu2N.d.ts +0 -10
- package/dist/home/index.d.mts +0 -269
- package/dist/home/index.d.ts +0 -269
- package/dist/home/index.js +0 -1678
- package/dist/home/index.js.map +0 -1
- package/dist/home/index.mjs +0 -1635
- package/dist/home/index.mjs.map +0 -1
- package/dist/hooks/index.d.mts +0 -7
- package/dist/hooks/index.d.ts +0 -7
- package/dist/hooks/index.js +0 -8316
- package/dist/hooks/index.js.map +0 -1
- package/dist/hooks/index.mjs +0 -8255
- package/dist/hooks/index.mjs.map +0 -1
- package/dist/index-50hpiPrV.d.ts +0 -116
- package/dist/index-B9zQVEVi.d.mts +0 -116
- package/dist/index.d.mts +0 -5
- package/dist/index.d.ts +0 -5
- package/dist/index.js +0 -123
- package/dist/index.js.map +0 -1
- package/dist/index.mjs +0 -118
- package/dist/index.mjs.map +0 -1
- package/dist/infrastructure/index.d.mts +0 -423
- package/dist/infrastructure/index.d.ts +0 -423
- package/dist/infrastructure/index.js +0 -633
- package/dist/infrastructure/index.js.map +0 -1
- package/dist/infrastructure/index.mjs +0 -619
- package/dist/infrastructure/index.mjs.map +0 -1
- package/dist/label-DWTEkNPo.d.ts +0 -226
- package/dist/label-LPpdcoBx.d.mts +0 -226
- package/dist/layout/index.d.mts +0 -48
- package/dist/layout/index.d.ts +0 -48
- package/dist/layout/index.js +0 -117
- package/dist/layout/index.js.map +0 -1
- package/dist/layout/index.mjs +0 -90
- package/dist/layout/index.mjs.map +0 -1
- package/dist/navigation/index.d.mts +0 -16
- package/dist/navigation/index.d.ts +0 -16
- package/dist/navigation/index.js +0 -53
- package/dist/navigation/index.js.map +0 -1
- package/dist/navigation/index.mjs +0 -50
- package/dist/navigation/index.mjs.map +0 -1
- package/dist/notification/index.d.mts +0 -105
- package/dist/notification/index.d.ts +0 -105
- package/dist/notification/index.js +0 -278
- package/dist/notification/index.js.map +0 -1
- package/dist/notification/index.mjs +0 -274
- package/dist/notification/index.mjs.map +0 -1
- package/dist/organization/index.d.mts +0 -99
- package/dist/organization/index.d.ts +0 -99
- package/dist/organization/index.js +0 -360
- package/dist/organization/index.js.map +0 -1
- package/dist/organization/index.mjs +0 -352
- package/dist/organization/index.mjs.map +0 -1
- package/dist/plugin/index.d.mts +0 -83
- package/dist/plugin/index.d.ts +0 -83
- package/dist/plugin/index.js +0 -86
- package/dist/plugin/index.js.map +0 -1
- package/dist/plugin/index.mjs +0 -84
- package/dist/plugin/index.mjs.map +0 -1
- package/dist/providers/index.d.mts +0 -25
- package/dist/providers/index.d.ts +0 -25
- package/dist/providers/index.js +0 -84
- package/dist/providers/index.js.map +0 -1
- package/dist/providers/index.mjs +0 -77
- package/dist/providers/index.mjs.map +0 -1
- package/dist/rbac/index.d.mts +0 -226
- package/dist/rbac/index.d.ts +0 -226
- package/dist/rbac/index.js +0 -4784
- package/dist/rbac/index.js.map +0 -1
- package/dist/rbac/index.mjs +0 -4722
- package/dist/rbac/index.mjs.map +0 -1
- package/dist/rbac/permissions.d.mts +0 -26
- package/dist/rbac/permissions.d.ts +0 -26
- package/dist/rbac/permissions.js +0 -94
- package/dist/rbac/permissions.js.map +0 -1
- package/dist/rbac/permissions.mjs +0 -90
- package/dist/rbac/permissions.mjs.map +0 -1
- package/dist/rbac/server.d.mts +0 -1
- package/dist/rbac/server.d.ts +0 -1
- package/dist/rbac/server.js +0 -128
- package/dist/rbac/server.js.map +0 -1
- package/dist/rbac/server.mjs +0 -124
- package/dist/rbac/server.mjs.map +0 -1
- package/dist/schemas/index.d.mts +0 -1257
- package/dist/schemas/index.d.ts +0 -1257
- package/dist/schemas/index.js +0 -572
- package/dist/schemas/index.js.map +0 -1
- package/dist/schemas/index.mjs +0 -523
- package/dist/schemas/index.mjs.map +0 -1
- package/dist/server-QuYCTa89.d.mts +0 -83
- package/dist/server-QuYCTa89.d.ts +0 -83
- package/dist/sonner-C74GlRDQ.d.mts +0 -71
- package/dist/sonner-C74GlRDQ.d.ts +0 -71
- package/dist/status-BOXZgIqX.d.mts +0 -12
- package/dist/status-BOXZgIqX.d.ts +0 -12
- package/dist/system/index.d.mts +0 -77
- package/dist/system/index.d.ts +0 -77
- package/dist/system/index.js +0 -102
- package/dist/system/index.js.map +0 -1
- package/dist/system/index.mjs +0 -100
- package/dist/system/index.mjs.map +0 -1
- package/dist/tabs-C6FfBwPY.d.mts +0 -18
- package/dist/tabs-C6FfBwPY.d.ts +0 -18
- package/dist/tenant-provider-B8eC_Wpb.d.mts +0 -27
- package/dist/tenant-provider-B8eC_Wpb.d.ts +0 -27
- package/dist/types/index.d.mts +0 -469
- package/dist/types/index.d.ts +0 -469
- package/dist/types/index.js +0 -25
- package/dist/types/index.js.map +0 -1
- package/dist/types/index.mjs +0 -21
- package/dist/types/index.mjs.map +0 -1
- package/dist/ui/auth.d.mts +0 -39
- package/dist/ui/auth.d.ts +0 -39
- package/dist/ui/auth.js +0 -4941
- package/dist/ui/auth.js.map +0 -1
- package/dist/ui/auth.mjs +0 -4896
- package/dist/ui/auth.mjs.map +0 -1
- package/dist/ui/crud.d.mts +0 -2
- package/dist/ui/crud.d.ts +0 -2
- package/dist/ui/crud.js +0 -4
- package/dist/ui/crud.js.map +0 -1
- package/dist/ui/crud.mjs +0 -3
- package/dist/ui/crud.mjs.map +0 -1
- package/dist/ui/data-display.d.mts +0 -596
- package/dist/ui/data-display.d.ts +0 -596
- package/dist/ui/data-display.js +0 -5307
- package/dist/ui/data-display.js.map +0 -1
- package/dist/ui/data-display.mjs +0 -5212
- package/dist/ui/data-display.mjs.map +0 -1
- package/dist/ui/feedback.d.mts +0 -55
- package/dist/ui/feedback.d.ts +0 -55
- package/dist/ui/feedback.js +0 -2608
- package/dist/ui/feedback.js.map +0 -1
- package/dist/ui/feedback.mjs +0 -2526
- package/dist/ui/feedback.mjs.map +0 -1
- package/dist/ui/forms.d.mts +0 -309
- package/dist/ui/forms.d.ts +0 -309
- package/dist/ui/forms.js +0 -4656
- package/dist/ui/forms.js.map +0 -1
- package/dist/ui/forms.mjs +0 -4571
- package/dist/ui/forms.mjs.map +0 -1
- package/dist/ui/index.d.mts +0 -331
- package/dist/ui/index.d.ts +0 -331
- package/dist/ui/index.js +0 -16953
- package/dist/ui/index.js.map +0 -1
- package/dist/ui/index.mjs +0 -16598
- package/dist/ui/index.mjs.map +0 -1
- package/dist/ui/primitives/client.d.mts +0 -61
- package/dist/ui/primitives/client.d.ts +0 -61
- package/dist/ui/primitives/client.js +0 -3408
- package/dist/ui/primitives/client.js.map +0 -1
- package/dist/ui/primitives/client.mjs +0 -3256
- package/dist/ui/primitives/client.mjs.map +0 -1
- package/dist/ui/primitives.d.mts +0 -113
- package/dist/ui/primitives.d.ts +0 -113
- package/dist/ui/primitives.js +0 -3356
- package/dist/ui/primitives.js.map +0 -1
- package/dist/ui/primitives.mjs +0 -3227
- package/dist/ui/primitives.mjs.map +0 -1
- package/dist/user/index.d.mts +0 -228
- package/dist/user/index.d.ts +0 -228
- package/dist/user/index.js +0 -4306
- package/dist/user/index.js.map +0 -1
- package/dist/user/index.mjs +0 -4260
- package/dist/user/index.mjs.map +0 -1
- package/dist/utils/index.d.mts +0 -205
- package/dist/utils/index.d.ts +0 -205
- package/dist/utils/index.js +0 -574
- package/dist/utils/index.js.map +0 -1
- package/dist/utils/index.mjs +0 -514
- package/dist/utils/index.mjs.map +0 -1
- package/dist/workflow/index.d.mts +0 -40
- package/dist/workflow/index.d.ts +0 -40
- package/dist/workflow/index.js +0 -3710
- package/dist/workflow/index.js.map +0 -1
- package/dist/workflow/index.mjs +0 -3677
- package/dist/workflow/index.mjs.map +0 -1
package/dist/rbac/index.d.ts
DELETED
|
@@ -1,226 +0,0 @@
|
|
|
1
|
-
import { Permission, CrudPermissions } from '../types/index.js';
|
|
2
|
-
import { Session } from 'next-auth';
|
|
3
|
-
export { R as ResourcePrismaClient, a as RoleData, b as RoleFilters, c as RolePrismaClient, g as getActionsForPermissionMatrix, d as getResourcesData, e as getResourcesForPermissionMatrix, f as getRolesData } from '../server-QuYCTa89.js';
|
|
4
|
-
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
5
|
-
import 'lucide-react';
|
|
6
|
-
import 'react';
|
|
7
|
-
import 'zod';
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* Interface defining the subset of Prisma Client required for RBAC operations.
|
|
11
|
-
* This allows the service to be agnostic of the actual PrismaClient instance.
|
|
12
|
-
*/
|
|
13
|
-
interface RBACPrismaClient {
|
|
14
|
-
userRole: {
|
|
15
|
-
findMany: (args: {
|
|
16
|
-
where: {
|
|
17
|
-
userId: string;
|
|
18
|
-
};
|
|
19
|
-
select: {
|
|
20
|
-
roleCode: boolean;
|
|
21
|
-
role: {
|
|
22
|
-
select: {
|
|
23
|
-
rolePermissions: {
|
|
24
|
-
select: {
|
|
25
|
-
resourceCode: boolean;
|
|
26
|
-
actionCode: boolean;
|
|
27
|
-
};
|
|
28
|
-
};
|
|
29
|
-
};
|
|
30
|
-
};
|
|
31
|
-
};
|
|
32
|
-
}) => Promise<Array<{
|
|
33
|
-
roleCode: string;
|
|
34
|
-
role: {
|
|
35
|
-
rolePermissions: Array<{
|
|
36
|
-
resourceCode: string;
|
|
37
|
-
actionCode: string;
|
|
38
|
-
}>;
|
|
39
|
-
};
|
|
40
|
-
}>>;
|
|
41
|
-
};
|
|
42
|
-
}
|
|
43
|
-
/**
|
|
44
|
-
* Fetch user permissions from database based on roles.
|
|
45
|
-
* Deduplicates permissions by resourceCode:actionCode.
|
|
46
|
-
*
|
|
47
|
-
* @param db - The tenant-specific Prisma Client instance
|
|
48
|
-
* @param userId - The user ID to fetch permissions for
|
|
49
|
-
*/
|
|
50
|
-
declare function getUserPermissionsFromDB(db: RBACPrismaClient, userId: string): Promise<Permission[]>;
|
|
51
|
-
/**
|
|
52
|
-
* Get permissions with caching.
|
|
53
|
-
*
|
|
54
|
-
* @param db - The tenant-specific Prisma Client instance
|
|
55
|
-
* @param userId - The user ID
|
|
56
|
-
* @param opts.forceRefresh - Bypass cache
|
|
57
|
-
*/
|
|
58
|
-
declare function getCachedUserPermissions(db: RBACPrismaClient, userId: string, opts?: {
|
|
59
|
-
forceRefresh?: boolean;
|
|
60
|
-
}): Promise<Permission[]>;
|
|
61
|
-
|
|
62
|
-
/**
|
|
63
|
-
* Resource Validator
|
|
64
|
-
* Validates resource codes against DB with caching
|
|
65
|
-
*/
|
|
66
|
-
interface ResourcePrismaClient {
|
|
67
|
-
resource: {
|
|
68
|
-
findUnique: (args: {
|
|
69
|
-
where: {
|
|
70
|
-
code: string;
|
|
71
|
-
};
|
|
72
|
-
}) => Promise<{
|
|
73
|
-
code: string;
|
|
74
|
-
} | null>;
|
|
75
|
-
findMany: (args?: {
|
|
76
|
-
select?: {
|
|
77
|
-
code: boolean;
|
|
78
|
-
};
|
|
79
|
-
}) => Promise<{
|
|
80
|
-
code: string;
|
|
81
|
-
}[]>;
|
|
82
|
-
};
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Check if a resource code exists.
|
|
86
|
-
* Checks cache first, then DB if not found.
|
|
87
|
-
*
|
|
88
|
-
* @param db - Prisma client
|
|
89
|
-
* @param resourceCode - Resource code to validate
|
|
90
|
-
* @returns true if valid, false otherwise
|
|
91
|
-
*/
|
|
92
|
-
declare function isValidResourceCode(db: ResourcePrismaClient, resourceCode: string): Promise<boolean>;
|
|
93
|
-
/**
|
|
94
|
-
* Get the correct resource code for permission checking.
|
|
95
|
-
* Priority: config.permissionResource > config.name > entity param
|
|
96
|
-
*
|
|
97
|
-
* @param config - Entity config (may be partial)
|
|
98
|
-
* @param entityParam - Entity param from URL
|
|
99
|
-
* @returns Resource code to use for permission check
|
|
100
|
-
*/
|
|
101
|
-
declare function getPermissionResourceCode(config: {
|
|
102
|
-
permissionResource?: string;
|
|
103
|
-
name?: string;
|
|
104
|
-
} | null | undefined, entityParam: string): string;
|
|
105
|
-
/**
|
|
106
|
-
* Validate and get resource code for permission checking.
|
|
107
|
-
* Combines getPermissionResourceCode with DB validation.
|
|
108
|
-
*
|
|
109
|
-
* @param db - Prisma client
|
|
110
|
-
* @param config - Entity config
|
|
111
|
-
* @param entityParam - Entity param from URL
|
|
112
|
-
* @returns Object with resourceCode and isValid flag
|
|
113
|
-
*/
|
|
114
|
-
declare function validatePermissionResource(db: ResourcePrismaClient, config: {
|
|
115
|
-
permissionResource?: string;
|
|
116
|
-
name?: string;
|
|
117
|
-
} | null | undefined, entityParam: string): Promise<{
|
|
118
|
-
resourceCode: string;
|
|
119
|
-
isValid: boolean;
|
|
120
|
-
}>;
|
|
121
|
-
/**
|
|
122
|
-
* Preload all resource codes into cache.
|
|
123
|
-
* Call this on app startup for better performance.
|
|
124
|
-
*
|
|
125
|
-
* @param db - Prisma client
|
|
126
|
-
*/
|
|
127
|
-
declare function preloadResourceCodes(db: ResourcePrismaClient): Promise<void>;
|
|
128
|
-
/**
|
|
129
|
-
* Clear resource cache.
|
|
130
|
-
* Call when resources are added/removed.
|
|
131
|
-
*/
|
|
132
|
-
declare function clearResourceCache(): Promise<void>;
|
|
133
|
-
|
|
134
|
-
type User = {
|
|
135
|
-
id: string;
|
|
136
|
-
name: string | null;
|
|
137
|
-
email: string | null;
|
|
138
|
-
image: string | null;
|
|
139
|
-
isActive: boolean;
|
|
140
|
-
jobTitle?: string;
|
|
141
|
-
};
|
|
142
|
-
type Role = {
|
|
143
|
-
id: string;
|
|
144
|
-
name: string;
|
|
145
|
-
code: string;
|
|
146
|
-
description?: string | null | undefined;
|
|
147
|
-
status: string;
|
|
148
|
-
permissions: string[];
|
|
149
|
-
usersCount: number;
|
|
150
|
-
users: User[];
|
|
151
|
-
createdAt: string;
|
|
152
|
-
updatedAt: string;
|
|
153
|
-
createdBy?: string | null | undefined;
|
|
154
|
-
updatedBy?: string | null | undefined;
|
|
155
|
-
};
|
|
156
|
-
type RolesResponse = {
|
|
157
|
-
total: number;
|
|
158
|
-
page: number;
|
|
159
|
-
pageSize: number;
|
|
160
|
-
items: Role[];
|
|
161
|
-
};
|
|
162
|
-
|
|
163
|
-
interface RoleListPageProps {
|
|
164
|
-
dictionary: any;
|
|
165
|
-
permissions: CrudPermissions;
|
|
166
|
-
lang: string;
|
|
167
|
-
initialData: RolesResponse;
|
|
168
|
-
resources: Array<{
|
|
169
|
-
id: string;
|
|
170
|
-
code: string;
|
|
171
|
-
name: string;
|
|
172
|
-
group: string | null;
|
|
173
|
-
description: string | null;
|
|
174
|
-
icon: string | null;
|
|
175
|
-
order: number | null;
|
|
176
|
-
config: any;
|
|
177
|
-
}>;
|
|
178
|
-
actions: Array<{
|
|
179
|
-
id: string;
|
|
180
|
-
code: string;
|
|
181
|
-
name: string;
|
|
182
|
-
description: string | null;
|
|
183
|
-
isDefault?: boolean;
|
|
184
|
-
}>;
|
|
185
|
-
}
|
|
186
|
-
declare function RoleListPage({ dictionary, permissions, lang, initialData, resources, actions, }: RoleListPageProps): react_jsx_runtime.JSX.Element;
|
|
187
|
-
|
|
188
|
-
declare const CRUD_ACTIONS: {
|
|
189
|
-
readonly create: "create";
|
|
190
|
-
readonly view: "view";
|
|
191
|
-
readonly update: "update";
|
|
192
|
-
readonly delete: "delete";
|
|
193
|
-
readonly export: "export";
|
|
194
|
-
readonly import: "import";
|
|
195
|
-
readonly approve: "approve";
|
|
196
|
-
readonly reject: "reject";
|
|
197
|
-
};
|
|
198
|
-
type CrudAction = keyof typeof CRUD_ACTIONS;
|
|
199
|
-
declare function getActionCode(operation: CrudAction): string;
|
|
200
|
-
declare function getAllCrudActionCodes(): string[];
|
|
201
|
-
declare function isCrudAction(actionCode: string): boolean;
|
|
202
|
-
declare function getFromCache(userId: string): Promise<Permission[] | undefined>;
|
|
203
|
-
declare function setToCache(userId: string, data: Permission[]): Promise<void>;
|
|
204
|
-
declare const pendingQueries: Map<string, Promise<Permission[]>>;
|
|
205
|
-
declare function clearAllPermissionsCache(): Promise<void>;
|
|
206
|
-
declare function clearUserPermissionsCache(userId: string): Promise<void>;
|
|
207
|
-
declare function invalidateUserPermissions(userId: string): Promise<void>;
|
|
208
|
-
|
|
209
|
-
declare function getUserPermissions(session: Session | null): Permission[];
|
|
210
|
-
declare function getCrudPermissionsFromSession(session: Session | null, entity: string): {
|
|
211
|
-
create: boolean;
|
|
212
|
-
view: boolean;
|
|
213
|
-
update: boolean;
|
|
214
|
-
delete: boolean;
|
|
215
|
-
export: boolean;
|
|
216
|
-
import: boolean;
|
|
217
|
-
approve: boolean;
|
|
218
|
-
reject: boolean;
|
|
219
|
-
};
|
|
220
|
-
declare function checkPermission(session: Session | null, resourceCode: string, actionCode: string): boolean;
|
|
221
|
-
declare function hasPermission(session: Session | null, resourceCode: string, actionCode: string): boolean;
|
|
222
|
-
declare function requirePermission(session: Session | null, resourceCode: string, actionCode: string): void;
|
|
223
|
-
declare function hasRole(session: Session | null, roleCode: string): boolean;
|
|
224
|
-
declare function hasAnyRole(session: Session | null, roleCodes: string[]): boolean;
|
|
225
|
-
|
|
226
|
-
export { CRUD_ACTIONS, type CrudAction, type RBACPrismaClient, RoleListPage, checkPermission, clearAllPermissionsCache, clearResourceCache, clearUserPermissionsCache, getActionCode, getAllCrudActionCodes, getCachedUserPermissions, getCrudPermissionsFromSession, getFromCache, getPermissionResourceCode, getUserPermissions, getUserPermissionsFromDB, hasAnyRole, hasPermission, hasRole, invalidateUserPermissions, isCrudAction, isValidResourceCode, pendingQueries, preloadResourceCodes, requirePermission, setToCache, validatePermissionResource };
|