@authup/client-web-kit 1.0.0-beta.22 → 1.0.0-beta.24

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.
Files changed (136) hide show
  1. package/dist/components/client/AClient.d.ts +4 -4
  2. package/dist/components/client/AClient.d.ts.map +1 -1
  3. package/dist/components/client/AClientForm.d.ts +2 -2
  4. package/dist/components/client/AClients.d.ts +3 -3
  5. package/dist/components/client/AClients.d.ts.map +1 -1
  6. package/dist/components/client-scope/AClientScope.d.ts +4 -4
  7. package/dist/components/client-scope/AClientScope.d.ts.map +1 -1
  8. package/dist/components/client-scope/AClientScopeAssignment.d.ts +2 -2
  9. package/dist/components/client-scope/AClientScopes.d.ts +3 -3
  10. package/dist/components/client-scope/AClientScopes.d.ts.map +1 -1
  11. package/dist/components/identity-provider/AIdentityProvider.d.ts +4 -4
  12. package/dist/components/identity-provider/AIdentityProvider.d.ts.map +1 -1
  13. package/dist/components/identity-provider/AIdentityProviderLdapForm.d.ts +2 -2
  14. package/dist/components/identity-provider/AIdentityProviderOAuth2Form.d.ts +2 -2
  15. package/dist/components/identity-provider/AIdentityProviders.d.ts +3 -3
  16. package/dist/components/identity-provider/AIdentityProviders.d.ts.map +1 -1
  17. package/dist/components/identity-provider-role/AIdentityProviderRoleAssignment.d.ts +2 -2
  18. package/dist/components/permission/APermission.d.ts +4 -4
  19. package/dist/components/permission/APermission.d.ts.map +1 -1
  20. package/dist/components/permission/APermissionCheck.d.ts +1 -1
  21. package/dist/components/permission/APermissionCheck.d.ts.map +1 -1
  22. package/dist/components/permission/APermissionForm.d.ts +2 -2
  23. package/dist/components/permission/APermissions.d.ts +3 -3
  24. package/dist/components/permission/APermissions.d.ts.map +1 -1
  25. package/dist/components/realm/ARealm.d.ts +4 -4
  26. package/dist/components/realm/ARealm.d.ts.map +1 -1
  27. package/dist/components/realm/ARealmForm.d.ts +2 -2
  28. package/dist/components/realm/ARealms.d.ts +3 -3
  29. package/dist/components/realm/ARealms.d.ts.map +1 -1
  30. package/dist/components/robot/ARobot.d.ts +4 -4
  31. package/dist/components/robot/ARobot.d.ts.map +1 -1
  32. package/dist/components/robot/ARobotForm.d.ts +2 -2
  33. package/dist/components/robot/ARobots.d.ts +3 -3
  34. package/dist/components/robot/ARobots.d.ts.map +1 -1
  35. package/dist/components/robot-permission/ARobotPermissionAssignment.d.ts +2 -2
  36. package/dist/components/robot-role/ARobotRoleAssignment.d.ts +2 -2
  37. package/dist/components/role/ARole.d.ts +4 -4
  38. package/dist/components/role/ARole.d.ts.map +1 -1
  39. package/dist/components/role/ARoleForm.d.ts +2 -2
  40. package/dist/components/role/ARoles.d.ts +3 -3
  41. package/dist/components/role/ARoles.d.ts.map +1 -1
  42. package/dist/components/role-permission/ARolePermissionAssignment.d.ts +2 -2
  43. package/dist/components/scope/AScope.d.ts +4 -4
  44. package/dist/components/scope/AScope.d.ts.map +1 -1
  45. package/dist/components/scope/AScopeForm.d.ts +2 -2
  46. package/dist/components/scope/AScopes.d.ts +3 -3
  47. package/dist/components/scope/AScopes.d.ts.map +1 -1
  48. package/dist/components/user/AUser.d.ts +4 -4
  49. package/dist/components/user/AUser.d.ts.map +1 -1
  50. package/dist/components/user/AUserForm.d.ts +2 -2
  51. package/dist/components/user/AUsers.d.ts +3 -3
  52. package/dist/components/user/AUsers.d.ts.map +1 -1
  53. package/dist/components/user-permission/AUserPermissionAssignment.d.ts +2 -2
  54. package/dist/components/user-role/AUserRoleAssignment.d.ts +2 -2
  55. package/dist/composables/use-permission-check.d.ts +1 -1
  56. package/dist/composables/use-permission-check.d.ts.map +1 -1
  57. package/dist/core/index.d.ts +2 -2
  58. package/dist/core/index.d.ts.map +1 -1
  59. package/dist/core/permission-check/types.d.ts +1 -1
  60. package/dist/core/permission-check/types.d.ts.map +1 -1
  61. package/dist/core/resource/collection/constants.d.ts.map +1 -0
  62. package/dist/core/resource/collection/index.d.ts +4 -0
  63. package/dist/core/resource/collection/index.d.ts.map +1 -0
  64. package/dist/core/resource/collection/module.d.ts +4 -0
  65. package/dist/core/resource/collection/module.d.ts.map +1 -0
  66. package/dist/core/{list/type.d.ts → resource/collection/types.d.ts} +21 -25
  67. package/dist/core/resource/collection/types.d.ts.map +1 -0
  68. package/dist/core/{list → resource/collection}/utils/component.d.ts +3 -3
  69. package/dist/core/resource/collection/utils/component.d.ts.map +1 -0
  70. package/dist/core/resource/collection/utils/handlers.d.ts.map +1 -0
  71. package/dist/core/resource/collection/utils/index.d.ts.map +1 -0
  72. package/dist/core/resource/collection/utils/options.d.ts +3 -0
  73. package/dist/core/resource/collection/utils/options.d.ts.map +1 -0
  74. package/dist/core/resource/index.d.ts +4 -0
  75. package/dist/core/resource/index.d.ts.map +1 -0
  76. package/dist/core/resource/record/error.d.ts +4 -0
  77. package/dist/core/resource/record/error.d.ts.map +1 -0
  78. package/dist/core/{entity-manager → resource/record}/index.d.ts +1 -1
  79. package/dist/core/resource/record/index.d.ts.map +1 -0
  80. package/dist/core/resource/record/module.d.ts +4 -0
  81. package/dist/core/resource/record/module.d.ts.map +1 -0
  82. package/dist/core/{entity-manager/type.d.ts → resource/record/types.d.ts} +19 -21
  83. package/dist/core/resource/record/types.d.ts.map +1 -0
  84. package/dist/core/{entity-manager → resource/record}/utils.d.ts +4 -4
  85. package/dist/core/resource/record/utils.d.ts.map +1 -0
  86. package/dist/core/resource/socket/index.d.ts.map +1 -0
  87. package/dist/core/resource/socket/module.d.ts +4 -0
  88. package/dist/core/resource/socket/module.d.ts.map +1 -0
  89. package/dist/core/resource/socket/type.d.ts +23 -0
  90. package/dist/core/resource/socket/type.d.ts.map +1 -0
  91. package/dist/core/store/create.d.ts +4 -4
  92. package/dist/core/store/create.d.ts.map +1 -1
  93. package/dist/core/store/singleton.d.ts +1 -1
  94. package/dist/core/store/singleton.d.ts.map +1 -1
  95. package/dist/index.cjs +194 -209
  96. package/dist/index.cjs.map +1 -1
  97. package/dist/index.mjs +175 -190
  98. package/dist/index.mjs.map +1 -1
  99. package/package.json +26 -20
  100. package/dist/core/entity-manager/error.d.ts +0 -4
  101. package/dist/core/entity-manager/error.d.ts.map +0 -1
  102. package/dist/core/entity-manager/index.d.ts.map +0 -1
  103. package/dist/core/entity-manager/module.d.ts +0 -6
  104. package/dist/core/entity-manager/module.d.ts.map +0 -1
  105. package/dist/core/entity-manager/type.d.ts.map +0 -1
  106. package/dist/core/entity-manager/utils.d.ts.map +0 -1
  107. package/dist/core/entity-socket/index.d.ts.map +0 -1
  108. package/dist/core/entity-socket/module.d.ts +0 -6
  109. package/dist/core/entity-socket/module.d.ts.map +0 -1
  110. package/dist/core/entity-socket/type.d.ts +0 -24
  111. package/dist/core/entity-socket/type.d.ts.map +0 -1
  112. package/dist/core/list/constants.d.ts.map +0 -1
  113. package/dist/core/list/index.d.ts +0 -4
  114. package/dist/core/list/index.d.ts.map +0 -1
  115. package/dist/core/list/module.d.ts +0 -6
  116. package/dist/core/list/module.d.ts.map +0 -1
  117. package/dist/core/list/type.d.ts.map +0 -1
  118. package/dist/core/list/utils/component.d.ts.map +0 -1
  119. package/dist/core/list/utils/handlers.d.ts.map +0 -1
  120. package/dist/core/list/utils/index.d.ts.map +0 -1
  121. package/dist/core/list/utils/options.d.ts +0 -3
  122. package/dist/core/list/utils/options.d.ts.map +0 -1
  123. package/dist/security/index.d.ts +0 -2
  124. package/dist/security/index.d.ts.map +0 -1
  125. package/dist/security/policy/index.d.ts +0 -3
  126. package/dist/security/policy/index.d.ts.map +0 -1
  127. package/dist/security/policy/module.d.ts +0 -5
  128. package/dist/security/policy/module.d.ts.map +0 -1
  129. package/dist/security/policy/variants/evaluator.d.ts +0 -11
  130. package/dist/security/policy/variants/evaluator.d.ts.map +0 -1
  131. package/dist/security/policy/variants/index.d.ts +0 -2
  132. package/dist/security/policy/variants/index.d.ts.map +0 -1
  133. /package/dist/core/{list → resource/collection}/constants.d.ts +0 -0
  134. /package/dist/core/{list → resource/collection}/utils/handlers.d.ts +0 -0
  135. /package/dist/core/{list → resource/collection}/utils/index.d.ts +0 -0
  136. /package/dist/core/{entity-socket → resource/socket}/index.d.ts +0 -0
package/dist/index.mjs CHANGED
@@ -2,10 +2,12 @@ import { REALM_MASTER_NAME, DomainEventName, buildDomainChannelName, DomainType,
2
2
  import { hasInjectionContext, inject as inject$2, provide as provide$1, ref, computed, getCurrentScope, onScopeDispose, toRaw, isRef, isReactive, toRef, unref, h, onMounted, onUnmounted, watch, shallowRef, watchEffect, defineComponent, reactive, nextTick, resolveComponent, openBlock, createElementBlock, createElementVNode, Fragment, renderList, createBlock, withCtx, normalizeClass, withModifiers, toDisplayString, getCurrentInstance, resolveDynamicComponent, mergeProps } from 'vue';
3
3
  import { Client, isClientTokenExpiredError, CookieName, ClientResponseErrorTokenHook } from '@authup/core-http-kit';
4
4
  import { defineStore, storeToRefs as storeToRefs$1 } from 'pinia';
5
- import { BuiltInPolicyType, PolicyError, maybeInvertPolicyOutcome, PermissionBindingPolicyValidator, PolicyEngine as PolicyEngine$1, PermissionMemoryProvider, PermissionChecker, TokenError, buildEventFullName, EventNameSuffix, hasOwnProperty, createNanoID, isOAuth2OpenIDProviderMetadata, isObject as isObject$2 } from '@authup/kit';
6
- import { isObject as isObject$1, merge, createMerger } from 'smob';
5
+ import { PermissionMemoryProvider, PermissionChecker, PolicyEngine } from '@authup/access';
6
+ import { TokenError, isOpenIDProviderMetadata } from '@authup/specs';
7
+ import { merge, isObject as isObject$1, createMerger } from 'smob';
8
+ import { hasOwnProperty, createNanoID, isObject as isObject$2 } from '@authup/kit';
7
9
  import { buildList, SlotName } from '@vuecs/list-controls';
8
- import { ClientManager } from '@authup/core-realtime-kit';
10
+ import { ClientManager, buildEventFullName, EventNameSuffix } from '@authup/core-realtime-kit';
9
11
  import { SortDirection } from 'rapiq';
10
12
  import { buildFormSubmit, buildFormGroup, buildFormInput, buildFormTextarea, buildFormInputCheckbox, buildFormInputText } from '@vuecs/form-controls';
11
13
  import { useTranslationsForBaseValidation as useTranslationsForBaseValidation$1, useTranslationsForNestedValidations, getSeverity, install as install$1 } from '@ilingo/vuelidate';
@@ -61,35 +63,6 @@ function injectHTTPClient(app) {
61
63
  * view the LICENSE file that was distributed with this source code.
62
64
  */ const STORE_ID = 'authup';
63
65
 
64
- class PermissionBindingPolicyEvaluator {
65
- async can(ctx) {
66
- return ctx.spec.type === BuiltInPolicyType.PERMISSION_BINDING;
67
- }
68
- async validateSpecification(ctx) {
69
- return this.validator.run(ctx.spec);
70
- }
71
- async validateData(ctx) {
72
- if (!isObject$1(ctx.data.identity) && !isObject$1(ctx.data.permission)) {
73
- throw PolicyError.evaluatorContextInvalid();
74
- }
75
- return ctx.data;
76
- }
77
- async evaluate(ctx) {
78
- // todo: this must be changed when the permission-checker not only checks owned permissions.
79
- return maybeInvertPolicyOutcome(true, ctx.spec.invert);
80
- }
81
- constructor(){
82
- this.validator = new PermissionBindingPolicyValidator();
83
- }
84
- }
85
-
86
- class PolicyEngine extends PolicyEngine$1 {
87
- constructor(){
88
- super();
89
- this.registerEvaluator(BuiltInPolicyType.PERMISSION_BINDING, new PermissionBindingPolicyEvaluator());
90
- }
91
- }
92
-
93
66
  /*
94
67
  * Copyright (c) 2024.
95
68
  * Author Peter Placzek (tada5hi)
@@ -257,6 +230,38 @@ function createStore(context) {
257
230
  policyEngine: new PolicyEngine()
258
231
  });
259
232
  // --------------------------------------------------------------------
233
+ const cleanup = async ()=>{
234
+ const tempAccessToken = accessToken.value;
235
+ const tempRefreshToken = refreshToken.value;
236
+ setAccessToken(null);
237
+ setAccessTokenExpireDate(null);
238
+ setRefreshToken(null);
239
+ setUser(null);
240
+ setRealm(null);
241
+ setRealmManagement(null);
242
+ permissionRepository.setMany([]);
243
+ tokenResolved.value = false;
244
+ userResolved.value = false;
245
+ try {
246
+ if (tempAccessToken) {
247
+ await client.token.revoke({
248
+ token: tempAccessToken
249
+ });
250
+ }
251
+ } catch (e) {
252
+ // ...
253
+ }
254
+ try {
255
+ if (tempRefreshToken) {
256
+ await client.token.revoke({
257
+ token: tempRefreshToken
258
+ });
259
+ }
260
+ } catch (e) {
261
+ // ...
262
+ }
263
+ };
264
+ // --------------------------------------------------------------------
260
265
  const userResolved = ref(false);
261
266
  const resolveUser = async ()=>{
262
267
  if (!accessToken.value || userResolved.value) {
@@ -316,17 +321,21 @@ function createStore(context) {
316
321
  if (!refreshToken.value) {
317
322
  throw new TokenError('The access token can not be renewed.');
318
323
  }
319
- return client.token.createWithRefreshToken({
320
- refresh_token: refreshToken.value
321
- }).then((r)=>applyTokenGrantResponse(r)).catch((e)=>{
322
- reset();
323
- return Promise.reject(e);
324
- }).finally(()=>{
324
+ try {
325
+ const response = await client.token.createWithRefreshToken({
326
+ refresh_token: refreshToken.value
327
+ });
328
+ applyTokenGrantResponse(response);
329
+ } catch (e) {
330
+ await cleanup();
331
+ throw e;
332
+ } finally{
325
333
  tokenResolved.value = false;
326
334
  userResolved.value = false;
327
- });
335
+ }
328
336
  });
329
337
  // --------------------------------------------------------------------
338
+ // todo: rename to reload() ?
330
339
  const resolveInternal = async ()=>{
331
340
  context.dispatcher.emit(StoreDispatcherEventName.RESOLVING);
332
341
  try {
@@ -342,18 +351,19 @@ function createStore(context) {
342
351
  } catch (e) {
343
352
  if (isClientTokenExpiredError(e) && refreshToken.value) {
344
353
  await refreshSession();
345
- return resolveInternal();
354
+ await resolveToken();
355
+ await resolveUser();
356
+ } else {
357
+ throw e;
346
358
  }
347
- throw e;
348
359
  }
349
360
  context.dispatcher.emit(StoreDispatcherEventName.RESOLVED);
350
- return Promise.resolve();
351
361
  };
352
362
  const resolve = createPromiseShareWrapperFn(resolveInternal);
353
363
  const loggedIn = computed(()=>!!accessToken.value);
354
364
  const login = async (ctx)=>{
355
365
  context.dispatcher.emit(StoreDispatcherEventName.LOGGING_IN);
356
- const response = await client.token.createWithPasswordGrant({
366
+ const response = await client.token.createWithPassword({
357
367
  username: ctx.name,
358
368
  password: ctx.password,
359
369
  ...realmId.value ? {
@@ -361,46 +371,13 @@ function createStore(context) {
361
371
  } : {}
362
372
  });
363
373
  applyTokenGrantResponse(response);
364
- try {
365
- await resolve();
366
- } catch (e) {
367
- await logout();
368
- throw e;
369
- }
374
+ await resolveToken();
375
+ await resolveUser();
370
376
  context.dispatcher.emit(StoreDispatcherEventName.LOGGED_IN);
371
377
  };
372
- const reset = ()=>{
373
- setAccessToken(null);
374
- setAccessTokenExpireDate(null);
375
- setRefreshToken(null);
376
- setUser(null);
377
- setRealm(null);
378
- setRealmManagement(null);
379
- permissionRepository.setMany([]);
380
- tokenResolved.value = false;
381
- userResolved.value = false;
382
- };
383
378
  const logout = async ()=>{
384
379
  context.dispatcher.emit(StoreDispatcherEventName.LOGGING_OUT);
385
- try {
386
- if (accessToken.value) {
387
- await client.token.revoke({
388
- token: accessToken.value
389
- });
390
- }
391
- } catch (e) {
392
- // ...
393
- }
394
- try {
395
- if (refreshToken.value) {
396
- await client.token.revoke({
397
- token: refreshToken.value
398
- });
399
- }
400
- } catch (e) {
401
- // ...
402
- }
403
- reset();
380
+ await cleanup();
404
381
  context.dispatcher.emit(StoreDispatcherEventName.LOGGED_OUT);
405
382
  };
406
383
  return {
@@ -499,7 +476,7 @@ function shouldUpdate(dependencies, newCookies, oldCookies) {
499
476
  }
500
477
 
501
478
  const sym = Symbol.for('AuthupStore');
502
- function useStore(pinia, app) {
479
+ function injectStore(pinia, app) {
503
480
  const instance = injectStoreFactory(app);
504
481
  if (!instance) {
505
482
  throw new Error('The store has not been injected in the app context.');
@@ -770,7 +747,7 @@ function renderEntityAssignAction(ctx) {
770
747
  * Author Peter Placzek (tada5hi)
771
748
  * For the full copyright and license information,
772
749
  * view the LICENSE file that was distributed with this source code.
773
- */ function defineListEvents() {
750
+ */ function defineResourceCollectionVEmitOptions() {
774
751
  return {
775
752
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
776
753
  created: (_item)=>true,
@@ -780,7 +757,7 @@ function renderEntityAssignAction(ctx) {
780
757
  updated: (_item)=>true
781
758
  };
782
759
  }
783
- function defineListProps() {
760
+ function defineResourceCollectionVProps() {
784
761
  return {
785
762
  query: {
786
763
  type: Object,
@@ -955,7 +932,7 @@ function installSocketManager(app, options) {
955
932
  provideSocketManager(manager, app);
956
933
  }
957
934
 
958
- function createEntitySocket(ctx) {
935
+ function create$2(ctx) {
959
936
  if (!isSocketManagerUsable()) {
960
937
  return {
961
938
  mount () {},
@@ -963,7 +940,7 @@ function createEntitySocket(ctx) {
963
940
  };
964
941
  }
965
942
  const socketManager = injectSocketManager();
966
- const store = useStore();
943
+ const store = injectStore();
967
944
  const storeRefs = storeToRefs(store);
968
945
  const realmId = computed(()=>{
969
946
  if (storeRefs.realmName.value === REALM_MASTER_NAME) {
@@ -1067,8 +1044,7 @@ function createEntitySocket(ctx) {
1067
1044
  onUnmounted(()=>unmount());
1068
1045
  watch(targetId, (val, oldValue)=>{
1069
1046
  if (val !== oldValue) {
1070
- unmount();
1071
- mount();
1047
+ Promise.resolve().then(()=>unmount()).then(()=>mount());
1072
1048
  }
1073
1049
  });
1074
1050
  return {
@@ -1076,6 +1052,9 @@ function createEntitySocket(ctx) {
1076
1052
  unmount
1077
1053
  };
1078
1054
  }
1055
+ function createResourceSocketManager(ctx) {
1056
+ return create$2(ctx);
1057
+ }
1079
1058
 
1080
1059
  function isQuerySortedDescByDate(input) {
1081
1060
  if (Array.isArray(input)) {
@@ -1092,7 +1071,7 @@ const merger = createMerger({
1092
1071
  inPlace: false,
1093
1072
  priority: 'left'
1094
1073
  });
1095
- function createList(context) {
1074
+ function create$1(context) {
1096
1075
  const data = ref([]);
1097
1076
  const busy = ref(false);
1098
1077
  const total = ref(0);
@@ -1269,7 +1248,7 @@ function createList(context) {
1269
1248
  handleDeleted(entity);
1270
1249
  };
1271
1250
  socketContext.realmId = realmId;
1272
- createEntitySocket(socketContext);
1251
+ createResourceSocketManager(socketContext);
1273
1252
  }
1274
1253
  return {
1275
1254
  data,
@@ -1283,13 +1262,16 @@ function createList(context) {
1283
1262
  load
1284
1263
  };
1285
1264
  }
1265
+ function createResourceCollectionManager(context) {
1266
+ return create$1(context);
1267
+ }
1286
1268
 
1287
1269
  /*
1288
1270
  * Copyright (c) 2023.
1289
1271
  * Author Peter Placzek (tada5hi)
1290
1272
  * For the full copyright and license information,
1291
1273
  * view the LICENSE file that was distributed with this source code.
1292
- */ class EntityManagerError extends Error {
1274
+ */ class ResourceRecordError extends Error {
1293
1275
  static unresolvable() {
1294
1276
  return new this('Entity could not be resolved.');
1295
1277
  }
@@ -1336,7 +1318,7 @@ function createList(context) {
1336
1318
  return [];
1337
1319
  }
1338
1320
 
1339
- function buildEntityManagerSlotProps(input) {
1321
+ function buildResourceVSlotProps(input) {
1340
1322
  return {
1341
1323
  ...input,
1342
1324
  error: unref(input.error),
@@ -1345,7 +1327,7 @@ function buildEntityManagerSlotProps(input) {
1345
1327
  lockId: unref(input.lockId)
1346
1328
  };
1347
1329
  }
1348
- function defineEntityManagerEvents() {
1330
+ function defineResourceVEmitOptions() {
1349
1331
  return {
1350
1332
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
1351
1333
  failed: (_item)=>true,
@@ -1359,7 +1341,7 @@ function defineEntityManagerEvents() {
1359
1341
  resolved: (_item)=>true
1360
1342
  };
1361
1343
  }
1362
- function defineEntityManagerProps() {
1344
+ function defineResourceVProps() {
1363
1345
  return {
1364
1346
  entity: {
1365
1347
  type: Object
@@ -1379,7 +1361,7 @@ function defineEntityManagerProps() {
1379
1361
  };
1380
1362
  }
1381
1363
 
1382
- function createEntityManager(ctx) {
1364
+ function create(ctx) {
1383
1365
  const client = injectHTTPClient();
1384
1366
  let domainAPI;
1385
1367
  if (hasOwnProperty(client, ctx.type)) {
@@ -1531,7 +1513,7 @@ function createEntityManager(ctx) {
1531
1513
  socketContext.realmId = realmId;
1532
1514
  socketContext.target = true;
1533
1515
  socketContext.targetId = entityId;
1534
- socket = createEntitySocket(socketContext);
1516
+ socket = createResourceSocketManager(socketContext);
1535
1517
  }
1536
1518
  const error = ref(undefined);
1537
1519
  const resolveByProps = ()=>{
@@ -1640,7 +1622,7 @@ function createEntityManager(ctx) {
1640
1622
  await resolve(resolveContext);
1641
1623
  if (typeof entity.value === 'undefined') {
1642
1624
  if (!error.value) {
1643
- throw EntityManagerError.unresolvable();
1625
+ throw ResourceRecordError.unresolvable();
1644
1626
  }
1645
1627
  // eslint-disable-next-line no-throw-literal
1646
1628
  throw error.value;
@@ -1669,7 +1651,7 @@ function createEntityManager(ctx) {
1669
1651
  return typeof content === 'function' ? content() : content;
1670
1652
  }
1671
1653
  if (hasNormalizedSlot('default', ctx.setup.slots)) {
1672
- return normalizeSlot('default', buildEntityManagerSlotProps(manager), ctx.setup.slots);
1654
+ return normalizeSlot('default', buildResourceVSlotProps(manager), ctx.setup.slots);
1673
1655
  }
1674
1656
  return typeof content === 'function' ? content() : content;
1675
1657
  };
@@ -1684,6 +1666,9 @@ function createEntityManager(ctx) {
1684
1666
  };
1685
1667
  return manager;
1686
1668
  }
1669
+ function createResourceManager(ctx) {
1670
+ return create(ctx);
1671
+ }
1687
1672
 
1688
1673
  /*
1689
1674
  * Copyright (c) 2022.
@@ -1902,7 +1887,7 @@ function computedAsync(evaluationCallback, initialState, optionsOrRef) {
1902
1887
  } else {
1903
1888
  options = {};
1904
1889
  }
1905
- const { lazy = false, evaluating = void 0, shallow = true, onError = noop } = options;
1890
+ const { lazy = false, evaluating = undefined, shallow = true, onError = noop } = options;
1906
1891
  const started = ref(!lazy);
1907
1892
  const current = shallow ? shallowRef(initialState) : ref(initialState);
1908
1893
  let counter = 0;
@@ -2232,7 +2217,7 @@ function createPermissionCheckerReactiveFn(ctx = {}) {
2232
2217
  if (ctx.store) {
2233
2218
  store = ctx.store;
2234
2219
  } else {
2235
- store = useStore(ctx.pinia, ctx.app);
2220
+ store = injectStore(ctx.pinia, ctx.app);
2236
2221
  }
2237
2222
  const storeRefs = storeToRefs(store);
2238
2223
  return (ctx)=>{
@@ -2287,11 +2272,11 @@ function createPermissionCheckerReactiveFn(ctx = {}) {
2287
2272
  }
2288
2273
 
2289
2274
  const AClient = defineComponent({
2290
- props: defineEntityManagerProps(),
2291
- emits: defineEntityManagerEvents(),
2275
+ props: defineResourceVProps(),
2276
+ emits: defineResourceVEmitOptions(),
2292
2277
  slots: Object,
2293
2278
  async setup (props, setup) {
2294
- const manager = createEntityManager({
2279
+ const manager = createResourceManager({
2295
2280
  type: `${DomainType.CLIENT}`,
2296
2281
  setup,
2297
2282
  props
@@ -2339,7 +2324,7 @@ function usePermissionCheck(ctx) {
2339
2324
  }
2340
2325
 
2341
2326
  function useRealmResourceWritableCheck(realmId) {
2342
- const store = useStore();
2327
+ const store = injectStore();
2343
2328
  const { realm } = storeToRefs$1(store);
2344
2329
  return computed(()=>{
2345
2330
  const realmIdRaw = unref(realmId);
@@ -2348,11 +2333,11 @@ function useRealmResourceWritableCheck(realmId) {
2348
2333
  }
2349
2334
 
2350
2335
  const ARealm = defineComponent({
2351
- props: defineEntityManagerProps(),
2352
- emits: defineEntityManagerEvents(),
2336
+ props: defineResourceVProps(),
2337
+ emits: defineResourceVEmitOptions(),
2353
2338
  slots: Object,
2354
2339
  async setup (props, setup) {
2355
- const manager = createEntityManager({
2340
+ const manager = createResourceManager({
2356
2341
  type: `${DomainType.REALM}`,
2357
2342
  props,
2358
2343
  setup
@@ -2374,7 +2359,7 @@ const ARealmForm = defineComponent({
2374
2359
  default: undefined
2375
2360
  }
2376
2361
  },
2377
- emits: defineEntityManagerEvents(),
2362
+ emits: defineResourceVEmitOptions(),
2378
2363
  setup (props, ctx) {
2379
2364
  const busy = ref(false);
2380
2365
  const form = reactive({
@@ -2397,7 +2382,7 @@ const ARealmForm = defineComponent({
2397
2382
  maxLength: maxLength(4096)
2398
2383
  }
2399
2384
  }, form);
2400
- const manager = createEntityManager({
2385
+ const manager = createResourceManager({
2401
2386
  type: `${DomainType.REALM}`,
2402
2387
  setup: ctx,
2403
2388
  props
@@ -2532,11 +2517,11 @@ const ARealmForm = defineComponent({
2532
2517
  });
2533
2518
 
2534
2519
  const ARealms = defineComponent({
2535
- props: defineListProps(),
2520
+ props: defineResourceCollectionVProps(),
2536
2521
  slots: Object,
2537
- emits: defineListEvents(),
2522
+ emits: defineResourceCollectionVEmitOptions(),
2538
2523
  setup (props, ctx) {
2539
- const { render } = createList({
2524
+ const { render } = createResourceCollectionManager({
2540
2525
  type: `${DomainType.REALM}`,
2541
2526
  props,
2542
2527
  setup: ctx
@@ -2701,7 +2686,7 @@ const AClientForm = defineComponent({
2701
2686
  default: undefined
2702
2687
  }
2703
2688
  },
2704
- emits: defineEntityManagerEvents(),
2689
+ emits: defineResourceVEmitOptions(),
2705
2690
  setup (props, ctx) {
2706
2691
  const busy = ref(false);
2707
2692
  const form = reactive({
@@ -2743,7 +2728,7 @@ const AClientForm = defineComponent({
2743
2728
  maxLength: maxLength(256)
2744
2729
  }
2745
2730
  }, form);
2746
- const manager = createEntityManager({
2731
+ const manager = createResourceManager({
2747
2732
  type: `${DomainType.CLIENT}`,
2748
2733
  setup: ctx,
2749
2734
  props
@@ -3016,11 +3001,11 @@ const AClientForm = defineComponent({
3016
3001
  });
3017
3002
 
3018
3003
  const AClients = defineComponent({
3019
- props: defineListProps(),
3004
+ props: defineResourceCollectionVProps(),
3020
3005
  slots: Object,
3021
- emits: defineListEvents(),
3006
+ emits: defineResourceCollectionVEmitOptions(),
3022
3007
  setup (props, ctx) {
3023
- const { render } = createList({
3008
+ const { render } = createResourceCollectionManager({
3024
3009
  type: `${DomainType.CLIENT}`,
3025
3010
  props,
3026
3011
  setup: ctx
@@ -3045,11 +3030,11 @@ const AClients = defineComponent({
3045
3030
  });
3046
3031
 
3047
3032
  const AClientScope = defineComponent({
3048
- props: defineEntityManagerProps(),
3049
- emits: defineEntityManagerEvents(),
3033
+ props: defineResourceVProps(),
3034
+ emits: defineResourceVEmitOptions(),
3050
3035
  slots: Object,
3051
3036
  async setup (props, setup) {
3052
- const manager = createEntityManager({
3037
+ const manager = createResourceManager({
3053
3038
  type: `${DomainType.CLIENT_SCOPE}`,
3054
3039
  props,
3055
3040
  setup
@@ -3064,11 +3049,11 @@ const AClientScope = defineComponent({
3064
3049
  });
3065
3050
 
3066
3051
  const AClientScopes = defineComponent({
3067
- props: defineListProps(),
3052
+ props: defineResourceCollectionVProps(),
3068
3053
  slots: Object,
3069
- emits: defineListEvents(),
3054
+ emits: defineResourceCollectionVEmitOptions(),
3070
3055
  setup (props, ctx) {
3071
- const { render } = createList({
3056
+ const { render } = createResourceCollectionManager({
3072
3057
  type: `${DomainType.CLIENT_SCOPE}`,
3073
3058
  props,
3074
3059
  setup: ctx
@@ -3121,7 +3106,7 @@ const AScopeForm = defineComponent({
3121
3106
  type: Object
3122
3107
  }
3123
3108
  },
3124
- emits: defineEntityManagerEvents(),
3109
+ emits: defineResourceVEmitOptions(),
3125
3110
  setup (props, ctx) {
3126
3111
  const busy = ref(false);
3127
3112
  const form = reactive({
@@ -3147,9 +3132,9 @@ const AScopeForm = defineComponent({
3147
3132
  },
3148
3133
  realm_id: {}
3149
3134
  }, form);
3150
- const store = useStore();
3135
+ const store = injectStore();
3151
3136
  const storeRefs = storeToRefs(store);
3152
- const manager = createEntityManager({
3137
+ const manager = createResourceManager({
3153
3138
  type: `${DomainType.SCOPE}`,
3154
3139
  setup: ctx,
3155
3140
  props
@@ -3268,11 +3253,11 @@ const AScopeForm = defineComponent({
3268
3253
  });
3269
3254
 
3270
3255
  const AScopes = defineComponent({
3271
- props: defineListProps(),
3256
+ props: defineResourceCollectionVProps(),
3272
3257
  slots: Object,
3273
- emits: defineListEvents(),
3258
+ emits: defineResourceCollectionVEmitOptions(),
3274
3259
  setup (props, ctx) {
3275
- const { render } = createList({
3260
+ const { render } = createResourceCollectionManager({
3276
3261
  type: DomainType.SCOPE,
3277
3262
  props,
3278
3263
  setup: ctx
@@ -3297,11 +3282,11 @@ const AScopes = defineComponent({
3297
3282
  });
3298
3283
 
3299
3284
  const AScope = defineComponent({
3300
- props: defineEntityManagerProps(),
3301
- emits: defineEntityManagerEvents(),
3285
+ props: defineResourceVProps(),
3286
+ emits: defineResourceVEmitOptions(),
3302
3287
  slots: Object,
3303
3288
  async setup (props, setup) {
3304
- const manager = createEntityManager({
3289
+ const manager = createResourceManager({
3305
3290
  type: `${DomainType.SCOPE}`,
3306
3291
  props,
3307
3292
  setup
@@ -3320,9 +3305,9 @@ const AClientScopeAssignment = defineComponent({
3320
3305
  clientId: String,
3321
3306
  scopeId: String
3322
3307
  },
3323
- emits: defineEntityManagerEvents(),
3308
+ emits: defineResourceVEmitOptions(),
3324
3309
  async setup (props, setup) {
3325
- const manager = createEntityManager({
3310
+ const manager = createResourceManager({
3326
3311
  type: `${DomainType.CLIENT_SCOPE}`,
3327
3312
  setup,
3328
3313
  socket: {
@@ -3371,11 +3356,11 @@ const AClientScopeAssignments = defineComponent({
3371
3356
  });
3372
3357
 
3373
3358
  const AIdentityProvider = defineComponent({
3374
- props: defineEntityManagerProps(),
3375
- emits: defineEntityManagerEvents(),
3359
+ props: defineResourceVProps(),
3360
+ emits: defineResourceVEmitOptions(),
3376
3361
  slots: Object,
3377
3362
  async setup (props, setup) {
3378
- const manager = createEntityManager({
3363
+ const manager = createResourceManager({
3379
3364
  type: `${DomainType.IDENTITY_PROVIDER}`,
3380
3365
  props,
3381
3366
  setup
@@ -3994,9 +3979,9 @@ const AIdentityProviderLdapForm = defineComponent({
3994
3979
  default: undefined
3995
3980
  }
3996
3981
  },
3997
- emits: defineEntityManagerEvents(),
3982
+ emits: defineResourceVEmitOptions(),
3998
3983
  setup (props, ctx) {
3999
- const manager = createEntityManager({
3984
+ const manager = createResourceManager({
4000
3985
  type: `${DomainType.IDENTITY_PROVIDER}`,
4001
3986
  setup: ctx,
4002
3987
  props
@@ -4448,7 +4433,7 @@ const AIdentityProviderOAuth2Discovery = defineComponent({
4448
4433
  }
4449
4434
  try {
4450
4435
  const response = await apiClient.get(form.url);
4451
- if (isOAuth2OpenIDProviderMetadata(response.data)) {
4436
+ if (isOpenIDProviderMetadata(response.data)) {
4452
4437
  setup.emit('lookup', response.data);
4453
4438
  lookupValid.value = true;
4454
4439
  }
@@ -4641,10 +4626,10 @@ const AIdentityProviderOAuth2Form = defineComponent({
4641
4626
  type: String
4642
4627
  }
4643
4628
  },
4644
- emits: defineEntityManagerEvents(),
4629
+ emits: defineResourceVEmitOptions(),
4645
4630
  setup (props, ctx) {
4646
4631
  const apiClient = injectHTTPClient();
4647
- const manager = createEntityManager({
4632
+ const manager = createResourceManager({
4648
4633
  type: `${DomainType.IDENTITY_PROVIDER}`,
4649
4634
  setup: ctx,
4650
4635
  props
@@ -4979,11 +4964,11 @@ const AIdentityProviderForm = defineComponent({
4979
4964
  });
4980
4965
 
4981
4966
  const AIdentityProviders = defineComponent({
4982
- props: defineListProps(),
4967
+ props: defineResourceCollectionVProps(),
4983
4968
  slots: Object,
4984
- emits: defineListEvents(),
4969
+ emits: defineResourceCollectionVEmitOptions(),
4985
4970
  setup (props, ctx) {
4986
- const { render } = createList({
4971
+ const { render } = createResourceCollectionManager({
4987
4972
  type: `${DomainType.IDENTITY_PROVIDER}`,
4988
4973
  props,
4989
4974
  setup: ctx
@@ -5051,7 +5036,7 @@ const AIdentityProviderRoleAssignment = defineComponent({
5051
5036
  required: true
5052
5037
  }
5053
5038
  },
5054
- emits: defineEntityManagerEvents(),
5039
+ emits: defineResourceVEmitOptions(),
5055
5040
  async setup (props, setup) {
5056
5041
  const display = ref(false);
5057
5042
  const toggleDisplay = ()=>{
@@ -5079,7 +5064,7 @@ const AIdentityProviderRoleAssignment = defineComponent({
5079
5064
  key: TranslatorTranslationDefaultKey.VALUE_IS_REGEX
5080
5065
  }
5081
5066
  ]);
5082
- const manager = createEntityManager({
5067
+ const manager = createResourceManager({
5083
5068
  type: `${DomainType.IDENTITY_PROVIDER_ROLE_MAPPING}`,
5084
5069
  setup,
5085
5070
  socket: {
@@ -5260,7 +5245,7 @@ const ARoleForm = defineComponent({
5260
5245
  default: undefined
5261
5246
  }
5262
5247
  },
5263
- emits: defineEntityManagerEvents(),
5248
+ emits: defineResourceVEmitOptions(),
5264
5249
  setup (props, ctx) {
5265
5250
  const busy = ref(false);
5266
5251
  const form = reactive({
@@ -5285,9 +5270,9 @@ const ARoleForm = defineComponent({
5285
5270
  },
5286
5271
  realm_id: {}
5287
5272
  }, form);
5288
- const store = useStore();
5273
+ const store = injectStore();
5289
5274
  const storeRefs = storeToRefs(store);
5290
- const manager = createEntityManager({
5275
+ const manager = createResourceManager({
5291
5276
  type: `${DomainType.ROLE}`,
5292
5277
  setup: ctx,
5293
5278
  props
@@ -5391,11 +5376,11 @@ const ARoleForm = defineComponent({
5391
5376
  });
5392
5377
 
5393
5378
  const ARoles = defineComponent({
5394
- props: defineListProps(),
5379
+ props: defineResourceCollectionVProps(),
5395
5380
  slots: Object,
5396
- emits: defineListEvents(),
5381
+ emits: defineResourceCollectionVEmitOptions(),
5397
5382
  setup (props, ctx) {
5398
- const { render } = createList({
5383
+ const { render } = createResourceCollectionManager({
5399
5384
  type: `${DomainType.ROLE}`,
5400
5385
  props,
5401
5386
  setup: ctx
@@ -5420,11 +5405,11 @@ const ARoles = defineComponent({
5420
5405
  });
5421
5406
 
5422
5407
  const ARole = defineComponent({
5423
- props: defineEntityManagerProps(),
5424
- emits: defineEntityManagerEvents(),
5408
+ props: defineResourceVProps(),
5409
+ emits: defineResourceVEmitOptions(),
5425
5410
  slots: Object,
5426
5411
  async setup (props, setup) {
5427
- const manager = createEntityManager({
5412
+ const manager = createResourceManager({
5428
5413
  type: `${DomainType.ROLE}`,
5429
5414
  props,
5430
5415
  setup
@@ -5460,11 +5445,11 @@ const AIdentityProviderRoleAssignments = defineComponent({
5460
5445
  });
5461
5446
 
5462
5447
  const APermission = defineComponent({
5463
- props: defineEntityManagerProps(),
5464
- emits: defineEntityManagerEvents(),
5448
+ props: defineResourceVProps(),
5449
+ emits: defineResourceVEmitOptions(),
5465
5450
  slots: Object,
5466
5451
  async setup (props, setup) {
5467
- const manager = createEntityManager({
5452
+ const manager = createResourceManager({
5468
5453
  type: `${DomainType.PERMISSION}`,
5469
5454
  setup,
5470
5455
  props
@@ -5516,7 +5501,7 @@ const APermissionForm = defineComponent({
5516
5501
  type: Object
5517
5502
  }
5518
5503
  },
5519
- emits: defineEntityManagerEvents(),
5504
+ emits: defineResourceVEmitOptions(),
5520
5505
  setup (props, ctx) {
5521
5506
  const busy = ref(false);
5522
5507
  const form = reactive({
@@ -5541,9 +5526,9 @@ const APermissionForm = defineComponent({
5541
5526
  },
5542
5527
  realm_id: {}
5543
5528
  }, form);
5544
- const store = useStore();
5529
+ const store = injectStore();
5545
5530
  const storeRefs = storeToRefs(store);
5546
- const manager = createEntityManager({
5531
+ const manager = createResourceManager({
5547
5532
  type: `${DomainType.PERMISSION}`,
5548
5533
  setup: ctx,
5549
5534
  props
@@ -5650,11 +5635,11 @@ const APermissionForm = defineComponent({
5650
5635
  });
5651
5636
 
5652
5637
  const APermissions = defineComponent({
5653
- props: defineListProps(),
5638
+ props: defineResourceCollectionVProps(),
5654
5639
  slots: Object,
5655
- emits: defineListEvents(),
5640
+ emits: defineResourceCollectionVEmitOptions(),
5656
5641
  setup (props, setup) {
5657
- const { render } = createList({
5642
+ const { render } = createResourceCollectionManager({
5658
5643
  type: `${DomainType.PERMISSION}`,
5659
5644
  props,
5660
5645
  setup
@@ -5683,9 +5668,9 @@ const ARobotPermissionAssignment = defineComponent({
5683
5668
  robotId: String,
5684
5669
  permissionId: String
5685
5670
  },
5686
- emits: defineEntityManagerEvents(),
5671
+ emits: defineResourceVEmitOptions(),
5687
5672
  async setup (props, setup) {
5688
- const manager = createEntityManager({
5673
+ const manager = createResourceManager({
5689
5674
  type: `${DomainType.ROBOT_PERMISSION}`,
5690
5675
  setup,
5691
5676
  socket: {
@@ -5715,11 +5700,11 @@ const ARobotPermissionAssignment = defineComponent({
5715
5700
  });
5716
5701
 
5717
5702
  const ARobot = defineComponent({
5718
- props: defineEntityManagerProps(),
5719
- emits: defineEntityManagerEvents(),
5703
+ props: defineResourceVProps(),
5704
+ emits: defineResourceVEmitOptions(),
5720
5705
  slots: Object,
5721
5706
  async setup (props, setup) {
5722
- const manager = createEntityManager({
5707
+ const manager = createResourceManager({
5723
5708
  type: `${DomainType.ROBOT}`,
5724
5709
  props,
5725
5710
  setup
@@ -5748,7 +5733,7 @@ const ARobotForm = defineComponent({
5748
5733
  default: undefined
5749
5734
  }
5750
5735
  },
5751
- emits: defineEntityManagerEvents(),
5736
+ emits: defineResourceVEmitOptions(),
5752
5737
  setup (props, ctx) {
5753
5738
  const busy = ref(false);
5754
5739
  const form = reactive({
@@ -5775,7 +5760,7 @@ const ARobotForm = defineComponent({
5775
5760
  maxLength: maxLength(256)
5776
5761
  }
5777
5762
  }, form);
5778
- const manager = createEntityManager({
5763
+ const manager = createResourceManager({
5779
5764
  type: `${DomainType.ROBOT}`,
5780
5765
  setup: ctx,
5781
5766
  props
@@ -5977,11 +5962,11 @@ const ARobotForm = defineComponent({
5977
5962
  });
5978
5963
 
5979
5964
  const ARobots = defineComponent({
5980
- props: defineListProps(),
5965
+ props: defineResourceCollectionVProps(),
5981
5966
  slots: Object,
5982
- emits: defineListEvents(),
5967
+ emits: defineResourceCollectionVEmitOptions(),
5983
5968
  setup (props, ctx) {
5984
- const { render } = createList({
5969
+ const { render } = createResourceCollectionManager({
5985
5970
  type: `${DomainType.ROBOT}`,
5986
5971
  props,
5987
5972
  setup: ctx
@@ -6029,9 +6014,9 @@ const ARolePermissionAssignment = defineComponent({
6029
6014
  roleId: String,
6030
6015
  permissionId: String
6031
6016
  },
6032
- emits: defineEntityManagerEvents(),
6017
+ emits: defineResourceVEmitOptions(),
6033
6018
  async setup (props, setup) {
6034
- const manager = createEntityManager({
6019
+ const manager = createResourceManager({
6035
6020
  type: `${DomainType.ROLE_PERMISSION}`,
6036
6021
  setup,
6037
6022
  socket: {
@@ -6103,9 +6088,9 @@ const AUserPermissionAssignment = defineComponent({
6103
6088
  userId: String,
6104
6089
  permissionId: String
6105
6090
  },
6106
- emits: defineEntityManagerEvents(),
6091
+ emits: defineResourceVEmitOptions(),
6107
6092
  async setup (props, setup) {
6108
- const manager = createEntityManager({
6093
+ const manager = createResourceManager({
6109
6094
  type: `${DomainType.USER_PERMISSION}`,
6110
6095
  setup,
6111
6096
  socket: {
@@ -6154,11 +6139,11 @@ const AUserPermissionAssignments = defineComponent({
6154
6139
  });
6155
6140
 
6156
6141
  const AUser = defineComponent({
6157
- props: defineEntityManagerProps(),
6158
- emits: defineEntityManagerEvents(),
6142
+ props: defineResourceVProps(),
6143
+ emits: defineResourceVEmitOptions(),
6159
6144
  slots: Object,
6160
6145
  async setup (props, setup) {
6161
- const manager = createEntityManager({
6146
+ const manager = createResourceManager({
6162
6147
  type: `${DomainType.USER}`,
6163
6148
  props,
6164
6149
  setup
@@ -6187,7 +6172,7 @@ const AUserForm = defineComponent({
6187
6172
  default: true
6188
6173
  }
6189
6174
  },
6190
- emits: defineEntityManagerEvents(),
6175
+ emits: defineResourceVEmitOptions(),
6191
6176
  async setup (props, ctx) {
6192
6177
  const busy = ref(false);
6193
6178
  const form = reactive({
@@ -6219,7 +6204,7 @@ const AUserForm = defineComponent({
6219
6204
  required
6220
6205
  }
6221
6206
  }, form);
6222
- const manager = createEntityManager({
6207
+ const manager = createResourceManager({
6223
6208
  type: `${DomainType.USER}`,
6224
6209
  setup: ctx,
6225
6210
  props
@@ -6431,11 +6416,11 @@ const AUserForm = defineComponent({
6431
6416
  });
6432
6417
 
6433
6418
  const AUsers = defineComponent({
6434
- props: defineListProps(),
6419
+ props: defineResourceCollectionVProps(),
6435
6420
  slots: Object,
6436
- emits: defineListEvents(),
6421
+ emits: defineResourceCollectionVEmitOptions(),
6437
6422
  setup (props, ctx) {
6438
- const { render } = createList({
6423
+ const { render } = createResourceCollectionManager({
6439
6424
  type: `${DomainType.USER}`,
6440
6425
  props,
6441
6426
  setup: ctx
@@ -6616,9 +6601,9 @@ const ARobotRoleAssignment = defineComponent({
6616
6601
  roleId: String,
6617
6602
  robotId: String
6618
6603
  },
6619
- emits: defineEntityManagerEvents(),
6604
+ emits: defineResourceVEmitOptions(),
6620
6605
  async setup (props, setup) {
6621
- const manager = createEntityManager({
6606
+ const manager = createResourceManager({
6622
6607
  type: `${DomainType.ROBOT_ROLE}`,
6623
6608
  setup,
6624
6609
  socket: {
@@ -6683,9 +6668,9 @@ const AUserRoleAssignment = defineComponent({
6683
6668
  roleId: String,
6684
6669
  userId: String
6685
6670
  },
6686
- emits: defineEntityManagerEvents(),
6671
+ emits: defineResourceVEmitOptions(),
6687
6672
  async setup (props, setup) {
6688
- const manager = createEntityManager({
6673
+ const manager = createResourceManager({
6689
6674
  type: `${DomainType.USER_ROLE}`,
6690
6675
  setup,
6691
6676
  socket: {
@@ -7287,5 +7272,5 @@ var index = {
7287
7272
  install
7288
7273
  };
7289
7274
 
7290
- export { AClient, AClientForm, AClientRedirectUris, AClientRedirectUrisItem, AClientScope, AClientScopeAssignment, AClientScopeAssignments, AClientScopes, AClients, AEntityDelete, AIdentityProvider, AIdentityProviderForm, AIdentityProviderIcon, AIdentityProviderLdapForm, AIdentityProviderOAuth2Form, AIdentityProviderPreset, AIdentityProviderProtocol, AIdentityProviderRoleAssignment, AIdentityProviderRoleAssignments, AIdentityProviders, APagination, APermission, APermissionCheck, APermissionForm, APermissionRobotAssignments, APermissionRoleAssignments, APermissionUserAssignments, APermissions, ARealm, ARealmForm, ARealms, ARobot, ARobotForm, ARobotPermissionAssignment, ARobotPermissionAssignments, ARobotRoleAssignment, ARobotRoleAssignments, ARobots, ARole, ARoleForm, ARolePermissionAssignment, ARolePermissionAssignments, ARoleRobotAssignments, ARoleUserAssignments, ARoles, AScope, AScopeClientAssignments, AScopeForm, AScopes, ASearch, ATitle, AUser, AUserForm, AUserPasswordForm, AUserPermissionAssignment, AUserPermissionAssignments, AUserRoleAssignment, AUserRoleAssignments, AUsers, EntityManagerError, HTTPClientSymbol, LanguageSwitcherDropdown, STORE_ID, SocketClientSymbol, StoreDispatcherEventName, TranslatorTranslationClientKey, TranslatorTranslationDefaultKey, TranslatorTranslationGroup, TranslatorTranslationVuecsKey, VuelidateCustomRule, VuelidateCustomRuleKey, buildEntityManagerSlotProps, buildFormSubmitWithTranslations, buildListCreatedHandler, buildListDeletedHandler, buildListUpdatedHandler, createEntityManager, createFormSubmitTranslations, createList, createPermissionCheckerReactiveFn, createStore, createStoreDispatcher, index as default, defineEntityManagerEvents, defineEntityManagerProps, defineListEvents, defineListProps, extendObjectProperties, extractVuelidateResultsFromChild, getVuelidateSeverity, hasHTTPClient, hasNormalizedSlot, hasStoreFactory, initFormAttributesFromSource, inject$1 as inject, injectHTTPClient, injectSocketManager, injectStoreDispatcher, injectStoreFactory, injectTranslatorLocale, install, installHTTPClient, installSocketManager, installStore, installTranslator, isQuerySortedDescByDate, isSocketManagerUsable, mergeListOptions, normalizeSlot, onChange, provide, provideHTTPClient, provideSocketManager, provideStoreDispatcher, provideStoreFactory, renderEntityAssignAction, storeToRefs, useIsEditing, usePermissionCheck, useRealmResourceWritableCheck, useStore, useTranslation, useTranslationsForBaseValidation, useTranslationsForGroup, useTranslationsForNestedValidation, useUpdatedAt, wrapFnWithBusyState };
7275
+ export { AClient, AClientForm, AClientRedirectUris, AClientRedirectUrisItem, AClientScope, AClientScopeAssignment, AClientScopeAssignments, AClientScopes, AClients, AEntityDelete, AIdentityProvider, AIdentityProviderForm, AIdentityProviderIcon, AIdentityProviderLdapForm, AIdentityProviderOAuth2Form, AIdentityProviderPreset, AIdentityProviderProtocol, AIdentityProviderRoleAssignment, AIdentityProviderRoleAssignments, AIdentityProviders, APagination, APermission, APermissionCheck, APermissionForm, APermissionRobotAssignments, APermissionRoleAssignments, APermissionUserAssignments, APermissions, ARealm, ARealmForm, ARealms, ARobot, ARobotForm, ARobotPermissionAssignment, ARobotPermissionAssignments, ARobotRoleAssignment, ARobotRoleAssignments, ARobots, ARole, ARoleForm, ARolePermissionAssignment, ARolePermissionAssignments, ARoleRobotAssignments, ARoleUserAssignments, ARoles, AScope, AScopeClientAssignments, AScopeForm, AScopes, ASearch, ATitle, AUser, AUserForm, AUserPasswordForm, AUserPermissionAssignment, AUserPermissionAssignments, AUserRoleAssignment, AUserRoleAssignments, AUsers, HTTPClientSymbol, LanguageSwitcherDropdown, ResourceRecordError, STORE_ID, SocketClientSymbol, StoreDispatcherEventName, TranslatorTranslationClientKey, TranslatorTranslationDefaultKey, TranslatorTranslationGroup, TranslatorTranslationVuecsKey, VuelidateCustomRule, VuelidateCustomRuleKey, buildFormSubmitWithTranslations, buildListCreatedHandler, buildListDeletedHandler, buildListUpdatedHandler, buildResourceVSlotProps, createFormSubmitTranslations, createPermissionCheckerReactiveFn, createResourceCollectionManager, createResourceManager, createStore, createStoreDispatcher, index as default, defineResourceCollectionVEmitOptions, defineResourceCollectionVProps, defineResourceVEmitOptions, defineResourceVProps, extendObjectProperties, extractVuelidateResultsFromChild, getVuelidateSeverity, hasHTTPClient, hasNormalizedSlot, hasStoreFactory, initFormAttributesFromSource, inject$1 as inject, injectHTTPClient, injectSocketManager, injectStore, injectStoreDispatcher, injectStoreFactory, injectTranslatorLocale, install, installHTTPClient, installSocketManager, installStore, installTranslator, isQuerySortedDescByDate, isSocketManagerUsable, mergeListOptions, normalizeSlot, onChange, provide, provideHTTPClient, provideSocketManager, provideStoreDispatcher, provideStoreFactory, renderEntityAssignAction, storeToRefs, useIsEditing, usePermissionCheck, useRealmResourceWritableCheck, useTranslation, useTranslationsForBaseValidation, useTranslationsForGroup, useTranslationsForNestedValidation, useUpdatedAt, wrapFnWithBusyState };
7291
7276
  //# sourceMappingURL=index.mjs.map