@webiny/api-record-locking 0.0.0-unstable.6844005670 → 0.0.0-unstable.7be00a75a9

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 (170) hide show
  1. package/domain/LockRecord.js +63 -70
  2. package/domain/LockRecord.js.map +1 -1
  3. package/domain/RecordLockingModel.js +26 -23
  4. package/domain/RecordLockingModel.js.map +1 -1
  5. package/domain/abstractions.js +3 -7
  6. package/domain/abstractions.js.map +1 -1
  7. package/domain/calculateExpiresOn.js +5 -6
  8. package/domain/calculateExpiresOn.js.map +1 -1
  9. package/domain/errors.js +71 -81
  10. package/domain/errors.js.map +1 -1
  11. package/domain/index.js +0 -2
  12. package/domain/types.js +6 -9
  13. package/domain/types.js.map +1 -1
  14. package/features/GetLockRecord/GetLockRecordRepository.js +27 -24
  15. package/features/GetLockRecord/GetLockRecordRepository.js.map +1 -1
  16. package/features/GetLockRecord/GetLockRecordUseCase.js +13 -10
  17. package/features/GetLockRecord/GetLockRecordUseCase.js.map +1 -1
  18. package/features/GetLockRecord/abstractions.js +3 -14
  19. package/features/GetLockRecord/abstractions.js.map +1 -1
  20. package/features/GetLockRecord/feature.d.ts +4 -1
  21. package/features/GetLockRecord/feature.js +7 -6
  22. package/features/GetLockRecord/feature.js.map +1 -1
  23. package/features/GetLockRecord/index.js +0 -2
  24. package/features/GetLockedEntryLockRecord/GetLockedEntryLockRecordUseCase.d.ts +1 -1
  25. package/features/GetLockedEntryLockRecord/GetLockedEntryLockRecordUseCase.js +20 -29
  26. package/features/GetLockedEntryLockRecord/GetLockedEntryLockRecordUseCase.js.map +1 -1
  27. package/features/GetLockedEntryLockRecord/abstractions.js +2 -10
  28. package/features/GetLockedEntryLockRecord/abstractions.js.map +1 -1
  29. package/features/GetLockedEntryLockRecord/feature.d.ts +4 -1
  30. package/features/GetLockedEntryLockRecord/feature.js +6 -5
  31. package/features/GetLockedEntryLockRecord/feature.js.map +1 -1
  32. package/features/GetLockedEntryLockRecord/index.js +0 -2
  33. package/features/IsEntryLocked/IsEntryLockedUseCase.d.ts +1 -1
  34. package/features/IsEntryLocked/IsEntryLockedUseCase.js +23 -29
  35. package/features/IsEntryLocked/IsEntryLockedUseCase.js.map +1 -1
  36. package/features/IsEntryLocked/abstractions.js +2 -9
  37. package/features/IsEntryLocked/abstractions.js.map +1 -1
  38. package/features/IsEntryLocked/feature.d.ts +4 -1
  39. package/features/IsEntryLocked/feature.js +6 -5
  40. package/features/IsEntryLocked/feature.js.map +1 -1
  41. package/features/IsEntryLocked/index.js +0 -2
  42. package/features/KickOutCurrentUser/KickOutCurrentUserUseCase.d.ts +1 -1
  43. package/features/KickOutCurrentUser/KickOutCurrentUserUseCase.js +33 -33
  44. package/features/KickOutCurrentUser/KickOutCurrentUserUseCase.js.map +1 -1
  45. package/features/KickOutCurrentUser/abstractions.js +2 -6
  46. package/features/KickOutCurrentUser/abstractions.js.map +1 -1
  47. package/features/KickOutCurrentUser/feature.d.ts +4 -1
  48. package/features/KickOutCurrentUser/feature.js +6 -5
  49. package/features/KickOutCurrentUser/feature.js.map +1 -1
  50. package/features/KickOutCurrentUser/index.js +0 -2
  51. package/features/ListAllLockRecords/ListAllLockRecordsRepository.js +31 -31
  52. package/features/ListAllLockRecords/ListAllLockRecordsRepository.js.map +1 -1
  53. package/features/ListAllLockRecords/ListAllLockRecordsUseCase.js +13 -10
  54. package/features/ListAllLockRecords/ListAllLockRecordsUseCase.js.map +1 -1
  55. package/features/ListAllLockRecords/abstractions.js +3 -14
  56. package/features/ListAllLockRecords/abstractions.js.map +1 -1
  57. package/features/ListAllLockRecords/feature.d.ts +4 -1
  58. package/features/ListAllLockRecords/feature.js +7 -6
  59. package/features/ListAllLockRecords/feature.js.map +1 -1
  60. package/features/ListAllLockRecords/index.js +0 -2
  61. package/features/ListLockRecords/ListLockRecordsRepository.js +31 -31
  62. package/features/ListLockRecords/ListLockRecordsRepository.js.map +1 -1
  63. package/features/ListLockRecords/ListLockRecordsUseCase.d.ts +1 -1
  64. package/features/ListLockRecords/ListLockRecordsUseCase.js +27 -24
  65. package/features/ListLockRecords/ListLockRecordsUseCase.js.map +1 -1
  66. package/features/ListLockRecords/abstractions.js +3 -14
  67. package/features/ListLockRecords/abstractions.js.map +1 -1
  68. package/features/ListLockRecords/feature.d.ts +4 -1
  69. package/features/ListLockRecords/feature.js +7 -6
  70. package/features/ListLockRecords/feature.js.map +1 -1
  71. package/features/ListLockRecords/index.js +0 -2
  72. package/features/LockEntry/LockEntryEventsDecorator.d.ts +1 -1
  73. package/features/LockEntry/LockEntryEventsDecorator.js +32 -32
  74. package/features/LockEntry/LockEntryEventsDecorator.js.map +1 -1
  75. package/features/LockEntry/LockEntryRepository.js +33 -30
  76. package/features/LockEntry/LockEntryRepository.js.map +1 -1
  77. package/features/LockEntry/LockEntryUseCase.js +21 -26
  78. package/features/LockEntry/LockEntryUseCase.js.map +1 -1
  79. package/features/LockEntry/abstractions.js +3 -14
  80. package/features/LockEntry/abstractions.js.map +1 -1
  81. package/features/LockEntry/events.d.ts +8 -8
  82. package/features/LockEntry/events.js +26 -34
  83. package/features/LockEntry/events.js.map +1 -1
  84. package/features/LockEntry/feature.d.ts +4 -1
  85. package/features/LockEntry/feature.js +8 -7
  86. package/features/LockEntry/feature.js.map +1 -1
  87. package/features/LockEntry/index.js +0 -2
  88. package/features/RecordLockingFeature.d.ts +4 -1
  89. package/features/RecordLockingFeature.js +19 -21
  90. package/features/RecordLockingFeature.js.map +1 -1
  91. package/features/UnlockEntry/UnlockEntryEventsDecorator.d.ts +1 -1
  92. package/features/UnlockEntry/UnlockEntryEventsDecorator.js +33 -33
  93. package/features/UnlockEntry/UnlockEntryEventsDecorator.js.map +1 -1
  94. package/features/UnlockEntry/UnlockEntryRepository.js +29 -27
  95. package/features/UnlockEntry/UnlockEntryRepository.js.map +1 -1
  96. package/features/UnlockEntry/UnlockEntryUseCase.d.ts +1 -1
  97. package/features/UnlockEntry/UnlockEntryUseCase.js +54 -70
  98. package/features/UnlockEntry/UnlockEntryUseCase.js.map +1 -1
  99. package/features/UnlockEntry/abstractions.js +3 -14
  100. package/features/UnlockEntry/abstractions.js.map +1 -1
  101. package/features/UnlockEntry/events.d.ts +8 -8
  102. package/features/UnlockEntry/events.js +26 -34
  103. package/features/UnlockEntry/events.js.map +1 -1
  104. package/features/UnlockEntry/feature.d.ts +4 -1
  105. package/features/UnlockEntry/feature.js +8 -7
  106. package/features/UnlockEntry/feature.js.map +1 -1
  107. package/features/UnlockEntry/hasFullAccessPermission.d.ts +1 -1
  108. package/features/UnlockEntry/hasFullAccessPermission.js +6 -7
  109. package/features/UnlockEntry/hasFullAccessPermission.js.map +1 -1
  110. package/features/UnlockEntry/index.js +0 -2
  111. package/features/UnlockEntryRequest/UnlockEntryRequestEventsDecorator.d.ts +1 -1
  112. package/features/UnlockEntryRequest/UnlockEntryRequestEventsDecorator.js +32 -32
  113. package/features/UnlockEntryRequest/UnlockEntryRequestEventsDecorator.js.map +1 -1
  114. package/features/UnlockEntryRequest/UnlockEntryRequestRepository.d.ts +1 -1
  115. package/features/UnlockEntryRequest/UnlockEntryRequestRepository.js +32 -31
  116. package/features/UnlockEntryRequest/UnlockEntryRequestRepository.js.map +1 -1
  117. package/features/UnlockEntryRequest/UnlockEntryRequestUseCase.d.ts +1 -1
  118. package/features/UnlockEntryRequest/UnlockEntryRequestUseCase.js +63 -80
  119. package/features/UnlockEntryRequest/UnlockEntryRequestUseCase.js.map +1 -1
  120. package/features/UnlockEntryRequest/abstractions.js +3 -14
  121. package/features/UnlockEntryRequest/abstractions.js.map +1 -1
  122. package/features/UnlockEntryRequest/events.d.ts +8 -8
  123. package/features/UnlockEntryRequest/events.js +26 -34
  124. package/features/UnlockEntryRequest/events.js.map +1 -1
  125. package/features/UnlockEntryRequest/feature.d.ts +4 -1
  126. package/features/UnlockEntryRequest/feature.js +8 -7
  127. package/features/UnlockEntryRequest/feature.js.map +1 -1
  128. package/features/UnlockEntryRequest/index.js +0 -2
  129. package/features/UpdateEntryLock/UpdateEntryLockRepository.d.ts +1 -1
  130. package/features/UpdateEntryLock/UpdateEntryLockRepository.js +46 -49
  131. package/features/UpdateEntryLock/UpdateEntryLockRepository.js.map +1 -1
  132. package/features/UpdateEntryLock/UpdateEntryLockUseCase.d.ts +1 -1
  133. package/features/UpdateEntryLock/UpdateEntryLockUseCase.js +41 -52
  134. package/features/UpdateEntryLock/UpdateEntryLockUseCase.js.map +1 -1
  135. package/features/UpdateEntryLock/abstractions.js +3 -14
  136. package/features/UpdateEntryLock/abstractions.js.map +1 -1
  137. package/features/UpdateEntryLock/feature.d.ts +4 -1
  138. package/features/UpdateEntryLock/feature.js +7 -6
  139. package/features/UpdateEntryLock/feature.js.map +1 -1
  140. package/features/UpdateEntryLock/index.js +0 -2
  141. package/graphql/checkPermissions.js +6 -10
  142. package/graphql/checkPermissions.js.map +1 -1
  143. package/graphql/resolve.js +15 -17
  144. package/graphql/resolve.js.map +1 -1
  145. package/graphql/schema.d.ts +2 -2
  146. package/graphql/schema.js +147 -168
  147. package/graphql/schema.js.map +1 -1
  148. package/index.d.ts +1 -1
  149. package/index.js +46 -48
  150. package/index.js.map +1 -1
  151. package/package.json +27 -22
  152. package/types.js +6 -9
  153. package/types.js.map +1 -1
  154. package/utils/convertWhereCondition.js +20 -32
  155. package/utils/convertWhereCondition.js.map +1 -1
  156. package/utils/getTimeout.js +8 -15
  157. package/utils/getTimeout.js.map +1 -1
  158. package/utils/lockRecordDatabaseId.js +6 -11
  159. package/utils/lockRecordDatabaseId.js.map +1 -1
  160. package/domain/index.js.map +0 -1
  161. package/features/GetLockRecord/index.js.map +0 -1
  162. package/features/GetLockedEntryLockRecord/index.js.map +0 -1
  163. package/features/IsEntryLocked/index.js.map +0 -1
  164. package/features/KickOutCurrentUser/index.js.map +0 -1
  165. package/features/ListAllLockRecords/index.js.map +0 -1
  166. package/features/ListLockRecords/index.js.map +0 -1
  167. package/features/LockEntry/index.js.map +0 -1
  168. package/features/UnlockEntry/index.js.map +0 -1
  169. package/features/UnlockEntryRequest/index.js.map +0 -1
  170. package/features/UpdateEntryLock/index.js.map +0 -1
@@ -1,42 +1,42 @@
1
1
  import { Result } from "@webiny/feature/api";
2
- import { IdentityContext } from "@webiny/api-core/features/IdentityContext";
2
+ import { IdentityContext } from "@webiny/api-core/features/security/IdentityContext/index.js";
3
3
  import { WebsocketService } from "@webiny/api-websockets/features/WebsocketService/index.js";
4
4
  import { parseIdentifier } from "@webiny/utils";
5
- import { KickOutCurrentUserUseCase as UseCaseAbstraction } from "./abstractions.js";
5
+ import { KickOutCurrentUserUseCase } from "./abstractions.js";
6
6
  class KickOutCurrentUserUseCaseImpl {
7
- constructor(identityContext, websocketService) {
8
- this.identityContext = identityContext;
9
- this.websocketService = websocketService;
10
- }
11
- async execute(record) {
12
- if (!this.websocketService) {
13
- return Result.ok();
7
+ constructor(identityContext, websocketService){
8
+ this.identityContext = identityContext;
9
+ this.websocketService = websocketService;
10
+ }
11
+ async execute(record) {
12
+ if (!this.websocketService) return Result.ok();
13
+ const { lockedBy, id } = record;
14
+ const { id: entryId } = parseIdentifier(id);
15
+ const identity = this.identityContext.getIdentity();
16
+ await this.websocketService.send({
17
+ id: lockedBy.id
18
+ }, {
19
+ action: `recordLocking.entry.kickOut.${entryId}`,
20
+ data: {
21
+ record: record.toObject(),
22
+ user: identity
23
+ }
24
+ });
25
+ return Result.ok();
14
26
  }
15
- const {
16
- lockedBy,
17
- id
18
- } = record;
19
- const {
20
- id: entryId
21
- } = parseIdentifier(id);
22
- const identity = this.identityContext.getIdentity();
23
- await this.websocketService.send({
24
- id: lockedBy.id
25
- }, {
26
- action: `recordLocking.entry.kickOut.${entryId}`,
27
- data: {
28
- record: record.toObject(),
29
- user: identity
30
- }
31
- });
32
- return Result.ok();
33
- }
34
27
  }
35
- export const KickOutCurrentUserUseCase = UseCaseAbstraction.createImplementation({
36
- implementation: KickOutCurrentUserUseCaseImpl,
37
- dependencies: [IdentityContext, [WebsocketService, {
38
- optional: true
39
- }]]
28
+ const KickOutCurrentUserUseCase_KickOutCurrentUserUseCase = KickOutCurrentUserUseCase.createImplementation({
29
+ implementation: KickOutCurrentUserUseCaseImpl,
30
+ dependencies: [
31
+ IdentityContext,
32
+ [
33
+ WebsocketService,
34
+ {
35
+ optional: true
36
+ }
37
+ ]
38
+ ]
40
39
  });
40
+ export { KickOutCurrentUserUseCase_KickOutCurrentUserUseCase as KickOutCurrentUserUseCase };
41
41
 
42
42
  //# sourceMappingURL=KickOutCurrentUserUseCase.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["Result","IdentityContext","WebsocketService","parseIdentifier","KickOutCurrentUserUseCase","UseCaseAbstraction","KickOutCurrentUserUseCaseImpl","constructor","identityContext","websocketService","execute","record","ok","lockedBy","id","entryId","identity","getIdentity","send","action","data","toObject","user","createImplementation","implementation","dependencies","optional"],"sources":["KickOutCurrentUserUseCase.ts"],"sourcesContent":["import { Result } from \"@webiny/feature/api\";\nimport { IdentityContext } from \"@webiny/api-core/features/IdentityContext\";\nimport { WebsocketService } from \"@webiny/api-websockets/features/WebsocketService/index.js\";\nimport { parseIdentifier } from \"@webiny/utils\";\nimport { KickOutCurrentUserUseCase as UseCaseAbstraction } from \"./abstractions.js\";\nimport type { ILockRecord } from \"~/domain/index.js\";\n\nclass KickOutCurrentUserUseCaseImpl implements UseCaseAbstraction.Interface {\n constructor(\n private identityContext: IdentityContext.Interface,\n private websocketService?: WebsocketService.Interface\n ) {}\n\n async execute(record: ILockRecord): Promise<Result<void, UseCaseAbstraction.Error>> {\n if (!this.websocketService) {\n return Result.ok();\n }\n\n const { lockedBy, id } = record;\n\n const { id: entryId } = parseIdentifier(id);\n const identity = this.identityContext.getIdentity();\n\n await this.websocketService.send(\n { id: lockedBy.id },\n {\n action: `recordLocking.entry.kickOut.${entryId}`,\n data: {\n record: record.toObject(),\n user: identity\n }\n }\n );\n\n return Result.ok();\n }\n}\n\nexport const KickOutCurrentUserUseCase = UseCaseAbstraction.createImplementation({\n implementation: KickOutCurrentUserUseCaseImpl,\n dependencies: [IdentityContext, [WebsocketService, { optional: true }]]\n});\n"],"mappings":"AAAA,SAASA,MAAM,QAAQ,qBAAqB;AAC5C,SAASC,eAAe,QAAQ,2CAA2C;AAC3E,SAASC,gBAAgB,QAAQ,2DAA2D;AAC5F,SAASC,eAAe,QAAQ,eAAe;AAC/C,SAASC,yBAAyB,IAAIC,kBAAkB;AAGxD,MAAMC,6BAA6B,CAAyC;EACxEC,WAAWA,CACCC,eAA0C,EAC1CC,gBAA6C,EACvD;IAAA,KAFUD,eAA0C,GAA1CA,eAA0C;IAAA,KAC1CC,gBAA6C,GAA7CA,gBAA6C;EACtD;EAEH,MAAMC,OAAOA,CAACC,MAAmB,EAAmD;IAChF,IAAI,CAAC,IAAI,CAACF,gBAAgB,EAAE;MACxB,OAAOT,MAAM,CAACY,EAAE,CAAC,CAAC;IACtB;IAEA,MAAM;MAAEC,QAAQ;MAAEC;IAAG,CAAC,GAAGH,MAAM;IAE/B,MAAM;MAAEG,EAAE,EAAEC;IAAQ,CAAC,GAAGZ,eAAe,CAACW,EAAE,CAAC;IAC3C,MAAME,QAAQ,GAAG,IAAI,CAACR,eAAe,CAACS,WAAW,CAAC,CAAC;IAEnD,MAAM,IAAI,CAACR,gBAAgB,CAACS,IAAI,CAC5B;MAAEJ,EAAE,EAAED,QAAQ,CAACC;IAAG,CAAC,EACnB;MACIK,MAAM,EAAE,+BAA+BJ,OAAO,EAAE;MAChDK,IAAI,EAAE;QACFT,MAAM,EAAEA,MAAM,CAACU,QAAQ,CAAC,CAAC;QACzBC,IAAI,EAAEN;MACV;IACJ,CACJ,CAAC;IAED,OAAOhB,MAAM,CAACY,EAAE,CAAC,CAAC;EACtB;AACJ;AAEA,OAAO,MAAMR,yBAAyB,GAAGC,kBAAkB,CAACkB,oBAAoB,CAAC;EAC7EC,cAAc,EAAElB,6BAA6B;EAC7CmB,YAAY,EAAE,CAACxB,eAAe,EAAE,CAACC,gBAAgB,EAAE;IAAEwB,QAAQ,EAAE;EAAK,CAAC,CAAC;AAC1E,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"features/KickOutCurrentUser/KickOutCurrentUserUseCase.js","sources":["../../../src/features/KickOutCurrentUser/KickOutCurrentUserUseCase.ts"],"sourcesContent":["import { Result } from \"@webiny/feature/api\";\nimport { IdentityContext } from \"@webiny/api-core/features/security/IdentityContext/index.js\";\nimport { WebsocketService } from \"@webiny/api-websockets/features/WebsocketService/index.js\";\nimport { parseIdentifier } from \"@webiny/utils\";\nimport { KickOutCurrentUserUseCase as UseCaseAbstraction } from \"./abstractions.js\";\nimport type { ILockRecord } from \"~/domain/index.js\";\n\nclass KickOutCurrentUserUseCaseImpl implements UseCaseAbstraction.Interface {\n constructor(\n private identityContext: IdentityContext.Interface,\n private websocketService?: WebsocketService.Interface\n ) {}\n\n async execute(record: ILockRecord): Promise<Result<void, UseCaseAbstraction.Error>> {\n if (!this.websocketService) {\n return Result.ok();\n }\n\n const { lockedBy, id } = record;\n\n const { id: entryId } = parseIdentifier(id);\n const identity = this.identityContext.getIdentity();\n\n await this.websocketService.send(\n { id: lockedBy.id },\n {\n action: `recordLocking.entry.kickOut.${entryId}`,\n data: {\n record: record.toObject(),\n user: identity\n }\n }\n );\n\n return Result.ok();\n }\n}\n\nexport const KickOutCurrentUserUseCase = UseCaseAbstraction.createImplementation({\n implementation: KickOutCurrentUserUseCaseImpl,\n dependencies: [IdentityContext, [WebsocketService, { optional: true }]]\n});\n"],"names":["KickOutCurrentUserUseCaseImpl","identityContext","websocketService","record","Result","lockedBy","id","entryId","parseIdentifier","identity","KickOutCurrentUserUseCase","UseCaseAbstraction","IdentityContext","WebsocketService"],"mappings":";;;;;AAOA,MAAMA;IACF,YACYC,eAA0C,EAC1CC,gBAA6C,CACvD;aAFUD,eAAe,GAAfA;aACAC,gBAAgB,GAAhBA;IACT;IAEH,MAAM,QAAQC,MAAmB,EAAmD;QAChF,IAAI,CAAC,IAAI,CAAC,gBAAgB,EACtB,OAAOC,OAAO,EAAE;QAGpB,MAAM,EAAEC,QAAQ,EAAEC,EAAE,EAAE,GAAGH;QAEzB,MAAM,EAAE,IAAII,OAAO,EAAE,GAAGC,gBAAgBF;QACxC,MAAMG,WAAW,IAAI,CAAC,eAAe,CAAC,WAAW;QAEjD,MAAM,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAC5B;YAAE,IAAIJ,SAAS,EAAE;QAAC,GAClB;YACI,QAAQ,CAAC,4BAA4B,EAAEE,SAAS;YAChD,MAAM;gBACF,QAAQJ,OAAO,QAAQ;gBACvB,MAAMM;YACV;QACJ;QAGJ,OAAOL,OAAO,EAAE;IACpB;AACJ;AAEO,MAAMM,sDAA4BC,0BAAAA,oBAAuC,CAAC;IAC7E,gBAAgBX;IAChB,cAAc;QAACY;QAAiB;YAACC;YAAkB;gBAAE,UAAU;YAAK;SAAE;KAAC;AAC3E"}
@@ -1,9 +1,5 @@
1
1
  import { createAbstraction } from "@webiny/feature/api";
2
-
3
- /**
4
- * KickOutCurrentUser Use Case - Sends websocket message to notify locked-out user
5
- */
6
-
7
- export const KickOutCurrentUserUseCase = createAbstraction("KickOutCurrentUserUseCase");
2
+ const KickOutCurrentUserUseCase = createAbstraction("KickOutCurrentUserUseCase");
3
+ export { KickOutCurrentUserUseCase };
8
4
 
9
5
  //# sourceMappingURL=abstractions.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["createAbstraction","KickOutCurrentUserUseCase"],"sources":["abstractions.ts"],"sourcesContent":["import { createAbstraction } from \"@webiny/feature/api\";\nimport { Result } from \"@webiny/feature/api\";\nimport type { ILockRecord } from \"~/domain/LockRecord.js\";\n\n/**\n * KickOutCurrentUser Use Case - Sends websocket message to notify locked-out user\n */\nexport interface IKickOutCurrentUserUseCase {\n execute(record: ILockRecord): Promise<Result<void, UseCaseError>>;\n}\n\nexport interface IKickOutCurrentUserUseCaseErrors {\n // This use case swallows errors and logs them, so no errors are exposed\n}\n\ntype UseCaseError = IKickOutCurrentUserUseCaseErrors[keyof IKickOutCurrentUserUseCaseErrors];\n\nexport const KickOutCurrentUserUseCase = createAbstraction<IKickOutCurrentUserUseCase>(\n \"KickOutCurrentUserUseCase\"\n);\n\nexport namespace KickOutCurrentUserUseCase {\n export type Interface = IKickOutCurrentUserUseCase;\n export type Error = UseCaseError;\n}\n"],"mappings":"AAAA,SAASA,iBAAiB,QAAQ,qBAAqB;;AAIvD;AACA;AACA;;AAWA,OAAO,MAAMC,yBAAyB,GAAGD,iBAAiB,CACtD,2BACJ,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"features/KickOutCurrentUser/abstractions.js","sources":["../../../src/features/KickOutCurrentUser/abstractions.ts"],"sourcesContent":["import { createAbstraction } from \"@webiny/feature/api\";\nimport { Result } from \"@webiny/feature/api\";\nimport type { ILockRecord } from \"~/domain/LockRecord.js\";\n\n/**\n * KickOutCurrentUser Use Case - Sends websocket message to notify locked-out user\n */\nexport interface IKickOutCurrentUserUseCase {\n execute(record: ILockRecord): Promise<Result<void, UseCaseError>>;\n}\n\nexport interface IKickOutCurrentUserUseCaseErrors {\n // This use case swallows errors and logs them, so no errors are exposed\n}\n\ntype UseCaseError = IKickOutCurrentUserUseCaseErrors[keyof IKickOutCurrentUserUseCaseErrors];\n\nexport const KickOutCurrentUserUseCase = createAbstraction<IKickOutCurrentUserUseCase>(\n \"KickOutCurrentUserUseCase\"\n);\n\nexport namespace KickOutCurrentUserUseCase {\n export type Interface = IKickOutCurrentUserUseCase;\n export type Error = UseCaseError;\n}\n"],"names":["KickOutCurrentUserUseCase","createAbstraction"],"mappings":";AAiBO,MAAMA,4BAA4BC,kBACrC"}
@@ -1 +1,4 @@
1
- export declare const KickOutCurrentUserFeature: import("@webiny/feature/api/createFeature.js").FeatureDefinition<unknown>;
1
+ export declare const KickOutCurrentUserFeature: {
2
+ name: string;
3
+ register(container: import("@webiny/di").Container): void;
4
+ };
@@ -1,10 +1,11 @@
1
1
  import { createFeature } from "@webiny/feature/api";
2
2
  import { KickOutCurrentUserUseCase } from "./KickOutCurrentUserUseCase.js";
3
- export const KickOutCurrentUserFeature = createFeature({
4
- name: "KickOutCurrentUser",
5
- register(container) {
6
- container.register(KickOutCurrentUserUseCase);
7
- }
3
+ const KickOutCurrentUserFeature = createFeature({
4
+ name: "KickOutCurrentUser",
5
+ register (container) {
6
+ container.register(KickOutCurrentUserUseCase);
7
+ }
8
8
  });
9
+ export { KickOutCurrentUserFeature };
9
10
 
10
11
  //# sourceMappingURL=feature.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["createFeature","KickOutCurrentUserUseCase","KickOutCurrentUserFeature","name","register","container"],"sources":["feature.ts"],"sourcesContent":["import { createFeature } from \"@webiny/feature/api\";\nimport { KickOutCurrentUserUseCase } from \"./KickOutCurrentUserUseCase.js\";\n\nexport const KickOutCurrentUserFeature = createFeature({\n name: \"KickOutCurrentUser\",\n register(container) {\n container.register(KickOutCurrentUserUseCase);\n }\n});\n"],"mappings":"AAAA,SAASA,aAAa,QAAQ,qBAAqB;AACnD,SAASC,yBAAyB;AAElC,OAAO,MAAMC,yBAAyB,GAAGF,aAAa,CAAC;EACnDG,IAAI,EAAE,oBAAoB;EAC1BC,QAAQA,CAACC,SAAS,EAAE;IAChBA,SAAS,CAACD,QAAQ,CAACH,yBAAyB,CAAC;EACjD;AACJ,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"features/KickOutCurrentUser/feature.js","sources":["../../../src/features/KickOutCurrentUser/feature.ts"],"sourcesContent":["import { createFeature } from \"@webiny/feature/api\";\nimport { KickOutCurrentUserUseCase } from \"./KickOutCurrentUserUseCase.js\";\n\nexport const KickOutCurrentUserFeature = createFeature({\n name: \"KickOutCurrentUser\",\n register(container) {\n container.register(KickOutCurrentUserUseCase);\n }\n});\n"],"names":["KickOutCurrentUserFeature","createFeature","container","KickOutCurrentUserUseCase"],"mappings":";;AAGO,MAAMA,4BAA4BC,cAAc;IACnD,MAAM;IACN,UAASC,SAAS;QACdA,UAAU,QAAQ,CAACC;IACvB;AACJ"}
@@ -1,3 +1 @@
1
1
  export * from "./abstractions.js";
2
-
3
- //# sourceMappingURL=index.js.map
@@ -1,43 +1,43 @@
1
1
  import { Result } from "@webiny/feature/api";
2
- import { ListAllLockRecordsRepository as RepositoryAbstraction } from "./abstractions.js";
2
+ import { ListAllLockRecordsRepository } from "./abstractions.js";
3
3
  import { ListLatestEntriesUseCase } from "@webiny/api-headless-cms/features/contentEntry/ListEntries";
4
4
  import { RecordLockingConfig, RecordLockingModel } from "../../domain/abstractions.js";
5
5
  import { LockRecordPersistenceError } from "../../domain/errors.js";
6
6
  import { convertWhereCondition } from "../../utils/convertWhereCondition.js";
7
7
  import { LockRecord } from "../../domain/LockRecord.js";
8
8
  class ListAllLockRecordsRepositoryImpl {
9
- constructor(config, listEntries, model) {
10
- this.config = config;
11
- this.listEntries = listEntries;
12
- this.model = model;
13
- }
14
- async execute(input) {
15
- try {
16
- const params = {
17
- ...input,
18
- where: convertWhereCondition(input?.where)
19
- };
20
- const result = await this.listEntries.execute(this.model, params);
21
- if (result.isFail()) {
22
- return Result.fail(new LockRecordPersistenceError(result.error));
23
- }
24
- const {
25
- entries,
26
- meta
27
- } = result.value;
28
- const items = entries.map(entry => new LockRecord(entry, this.config.timeout));
29
- return Result.ok({
30
- items,
31
- meta
32
- });
33
- } catch (error) {
34
- return Result.fail(new LockRecordPersistenceError(error));
9
+ constructor(config, listEntries, model){
10
+ this.config = config;
11
+ this.listEntries = listEntries;
12
+ this.model = model;
13
+ }
14
+ async execute(input) {
15
+ try {
16
+ const params = {
17
+ ...input,
18
+ where: convertWhereCondition(input?.where)
19
+ };
20
+ const result = await this.listEntries.execute(this.model, params);
21
+ if (result.isFail()) return Result.fail(new LockRecordPersistenceError(result.error));
22
+ const { entries, meta } = result.value;
23
+ const items = entries.map((entry)=>new LockRecord(entry, this.config.timeout));
24
+ return Result.ok({
25
+ items,
26
+ meta
27
+ });
28
+ } catch (error) {
29
+ return Result.fail(new LockRecordPersistenceError(error));
30
+ }
35
31
  }
36
- }
37
32
  }
38
- export const ListAllLockRecordsRepository = RepositoryAbstraction.createImplementation({
39
- implementation: ListAllLockRecordsRepositoryImpl,
40
- dependencies: [RecordLockingConfig, ListLatestEntriesUseCase, RecordLockingModel]
33
+ const ListAllLockRecordsRepository_ListAllLockRecordsRepository = ListAllLockRecordsRepository.createImplementation({
34
+ implementation: ListAllLockRecordsRepositoryImpl,
35
+ dependencies: [
36
+ RecordLockingConfig,
37
+ ListLatestEntriesUseCase,
38
+ RecordLockingModel
39
+ ]
41
40
  });
41
+ export { ListAllLockRecordsRepository_ListAllLockRecordsRepository as ListAllLockRecordsRepository };
42
42
 
43
43
  //# sourceMappingURL=ListAllLockRecordsRepository.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["Result","ListAllLockRecordsRepository","RepositoryAbstraction","ListLatestEntriesUseCase","RecordLockingConfig","RecordLockingModel","LockRecordPersistenceError","convertWhereCondition","LockRecord","ListAllLockRecordsRepositoryImpl","constructor","config","listEntries","model","execute","input","params","where","result","isFail","fail","error","entries","meta","value","items","map","entry","timeout","ok","createImplementation","implementation","dependencies"],"sources":["ListAllLockRecordsRepository.ts"],"sourcesContent":["import { Result } from \"@webiny/feature/api\";\nimport {\n ListAllLockRecordsRepository as RepositoryAbstraction,\n ListAllLockRecordsInput,\n ListAllLockRecordsOutput\n} from \"./abstractions.js\";\nimport { ListLatestEntriesUseCase } from \"@webiny/api-headless-cms/features/contentEntry/ListEntries\";\nimport { RecordLockingConfig, RecordLockingModel } from \"~/domain/abstractions.js\";\nimport type { CmsModel } from \"@webiny/api-headless-cms/types\";\nimport { LockRecordPersistenceError } from \"~/domain/errors.js\";\nimport { convertWhereCondition } from \"~/utils/convertWhereCondition.js\";\nimport { LockRecord } from \"~/domain/LockRecord.js\";\nimport type { LockRecordValues } from \"~/domain/index.js\";\n\nclass ListAllLockRecordsRepositoryImpl implements RepositoryAbstraction.Interface {\n constructor(\n private config: RecordLockingConfig.Interface,\n private listEntries: ListLatestEntriesUseCase.Interface,\n private model: CmsModel\n ) {}\n\n async execute(\n input?: ListAllLockRecordsInput\n ): Promise<Result<ListAllLockRecordsOutput, RepositoryAbstraction.Error>> {\n try {\n const params = {\n ...input,\n where: convertWhereCondition(input?.where)\n };\n\n const result = await this.listEntries.execute<LockRecordValues>(this.model, params);\n\n if (result.isFail()) {\n return Result.fail(new LockRecordPersistenceError(result.error));\n }\n\n const { entries, meta } = result.value;\n\n const items = entries.map(entry => new LockRecord(entry, this.config.timeout));\n\n return Result.ok({\n items,\n meta\n });\n } catch (error) {\n return Result.fail(new LockRecordPersistenceError(error as Error));\n }\n }\n}\n\nexport const ListAllLockRecordsRepository = RepositoryAbstraction.createImplementation({\n implementation: ListAllLockRecordsRepositoryImpl,\n dependencies: [RecordLockingConfig, ListLatestEntriesUseCase, RecordLockingModel]\n});\n"],"mappings":"AAAA,SAASA,MAAM,QAAQ,qBAAqB;AAC5C,SACIC,4BAA4B,IAAIC,qBAAqB;AAIzD,SAASC,wBAAwB,QAAQ,4DAA4D;AACrG,SAASC,mBAAmB,EAAEC,kBAAkB;AAEhD,SAASC,0BAA0B;AACnC,SAASC,qBAAqB;AAC9B,SAASC,UAAU;AAGnB,MAAMC,gCAAgC,CAA4C;EAC9EC,WAAWA,CACCC,MAAqC,EACrCC,WAA+C,EAC/CC,KAAe,EACzB;IAAA,KAHUF,MAAqC,GAArCA,MAAqC;IAAA,KACrCC,WAA+C,GAA/CA,WAA+C;IAAA,KAC/CC,KAAe,GAAfA,KAAe;EACxB;EAEH,MAAMC,OAAOA,CACTC,KAA+B,EACuC;IACtE,IAAI;MACA,MAAMC,MAAM,GAAG;QACX,GAAGD,KAAK;QACRE,KAAK,EAAEV,qBAAqB,CAACQ,KAAK,EAAEE,KAAK;MAC7C,CAAC;MAED,MAAMC,MAAM,GAAG,MAAM,IAAI,CAACN,WAAW,CAACE,OAAO,CAAmB,IAAI,CAACD,KAAK,EAAEG,MAAM,CAAC;MAEnF,IAAIE,MAAM,CAACC,MAAM,CAAC,CAAC,EAAE;QACjB,OAAOnB,MAAM,CAACoB,IAAI,CAAC,IAAId,0BAA0B,CAACY,MAAM,CAACG,KAAK,CAAC,CAAC;MACpE;MAEA,MAAM;QAAEC,OAAO;QAAEC;MAAK,CAAC,GAAGL,MAAM,CAACM,KAAK;MAEtC,MAAMC,KAAK,GAAGH,OAAO,CAACI,GAAG,CAACC,KAAK,IAAI,IAAInB,UAAU,CAACmB,KAAK,EAAE,IAAI,CAAChB,MAAM,CAACiB,OAAO,CAAC,CAAC;MAE9E,OAAO5B,MAAM,CAAC6B,EAAE,CAAC;QACbJ,KAAK;QACLF;MACJ,CAAC,CAAC;IACN,CAAC,CAAC,OAAOF,KAAK,EAAE;MACZ,OAAOrB,MAAM,CAACoB,IAAI,CAAC,IAAId,0BAA0B,CAACe,KAAc,CAAC,CAAC;IACtE;EACJ;AACJ;AAEA,OAAO,MAAMpB,4BAA4B,GAAGC,qBAAqB,CAAC4B,oBAAoB,CAAC;EACnFC,cAAc,EAAEtB,gCAAgC;EAChDuB,YAAY,EAAE,CAAC5B,mBAAmB,EAAED,wBAAwB,EAAEE,kBAAkB;AACpF,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"features/ListAllLockRecords/ListAllLockRecordsRepository.js","sources":["../../../src/features/ListAllLockRecords/ListAllLockRecordsRepository.ts"],"sourcesContent":["import { Result } from \"@webiny/feature/api\";\nimport {\n ListAllLockRecordsRepository as RepositoryAbstraction,\n ListAllLockRecordsInput,\n ListAllLockRecordsOutput\n} from \"./abstractions.js\";\nimport { ListLatestEntriesUseCase } from \"@webiny/api-headless-cms/features/contentEntry/ListEntries\";\nimport { RecordLockingConfig, RecordLockingModel } from \"~/domain/abstractions.js\";\nimport type { CmsModel } from \"@webiny/api-headless-cms/types\";\nimport { LockRecordPersistenceError } from \"~/domain/errors.js\";\nimport { convertWhereCondition } from \"~/utils/convertWhereCondition.js\";\nimport { LockRecord } from \"~/domain/LockRecord.js\";\nimport type { LockRecordValues } from \"~/domain/index.js\";\n\nclass ListAllLockRecordsRepositoryImpl implements RepositoryAbstraction.Interface {\n constructor(\n private config: RecordLockingConfig.Interface,\n private listEntries: ListLatestEntriesUseCase.Interface,\n private model: CmsModel\n ) {}\n\n async execute(\n input?: ListAllLockRecordsInput\n ): Promise<Result<ListAllLockRecordsOutput, RepositoryAbstraction.Error>> {\n try {\n const params = {\n ...input,\n where: convertWhereCondition(input?.where)\n };\n\n const result = await this.listEntries.execute<LockRecordValues>(this.model, params);\n\n if (result.isFail()) {\n return Result.fail(new LockRecordPersistenceError(result.error));\n }\n\n const { entries, meta } = result.value;\n\n const items = entries.map(entry => new LockRecord(entry, this.config.timeout));\n\n return Result.ok({\n items,\n meta\n });\n } catch (error) {\n return Result.fail(new LockRecordPersistenceError(error as Error));\n }\n }\n}\n\nexport const ListAllLockRecordsRepository = RepositoryAbstraction.createImplementation({\n implementation: ListAllLockRecordsRepositoryImpl,\n dependencies: [RecordLockingConfig, ListLatestEntriesUseCase, RecordLockingModel]\n});\n"],"names":["ListAllLockRecordsRepositoryImpl","config","listEntries","model","input","params","convertWhereCondition","result","Result","LockRecordPersistenceError","entries","meta","items","entry","LockRecord","error","ListAllLockRecordsRepository","RepositoryAbstraction","RecordLockingConfig","ListLatestEntriesUseCase","RecordLockingModel"],"mappings":";;;;;;;AAcA,MAAMA;IACF,YACYC,MAAqC,EACrCC,WAA+C,EAC/CC,KAAe,CACzB;aAHUF,MAAM,GAANA;aACAC,WAAW,GAAXA;aACAC,KAAK,GAALA;IACT;IAEH,MAAM,QACFC,KAA+B,EACuC;QACtE,IAAI;YACA,MAAMC,SAAS;gBACX,GAAGD,KAAK;gBACR,OAAOE,sBAAsBF,OAAO;YACxC;YAEA,MAAMG,SAAS,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAmB,IAAI,CAAC,KAAK,EAAEF;YAE5E,IAAIE,OAAO,MAAM,IACb,OAAOC,OAAO,IAAI,CAAC,IAAIC,2BAA2BF,OAAO,KAAK;YAGlE,MAAM,EAAEG,OAAO,EAAEC,IAAI,EAAE,GAAGJ,OAAO,KAAK;YAEtC,MAAMK,QAAQF,QAAQ,GAAG,CAACG,CAAAA,QAAS,IAAIC,WAAWD,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO;YAE5E,OAAOL,OAAO,EAAE,CAAC;gBACbI;gBACAD;YACJ;QACJ,EAAE,OAAOI,OAAO;YACZ,OAAOP,OAAO,IAAI,CAAC,IAAIC,2BAA2BM;QACtD;IACJ;AACJ;AAEO,MAAMC,4DAA+BC,6BAAAA,oBAA0C,CAAC;IACnF,gBAAgBjB;IAChB,cAAc;QAACkB;QAAqBC;QAA0BC;KAAmB;AACrF"}
@@ -1,15 +1,18 @@
1
- import { ListAllLockRecordsUseCase as UseCaseAbstraction, ListAllLockRecordsRepository } from "./abstractions.js";
1
+ import { ListAllLockRecordsRepository, ListAllLockRecordsUseCase } from "./abstractions.js";
2
2
  class ListAllLockRecordsUseCaseImpl {
3
- constructor(repository) {
4
- this.repository = repository;
5
- }
6
- async execute(input) {
7
- return await this.repository.execute(input);
8
- }
3
+ constructor(repository){
4
+ this.repository = repository;
5
+ }
6
+ async execute(input) {
7
+ return await this.repository.execute(input);
8
+ }
9
9
  }
10
- export const ListAllLockRecordsUseCase = UseCaseAbstraction.createImplementation({
11
- implementation: ListAllLockRecordsUseCaseImpl,
12
- dependencies: [ListAllLockRecordsRepository]
10
+ const ListAllLockRecordsUseCase_ListAllLockRecordsUseCase = ListAllLockRecordsUseCase.createImplementation({
11
+ implementation: ListAllLockRecordsUseCaseImpl,
12
+ dependencies: [
13
+ ListAllLockRecordsRepository
14
+ ]
13
15
  });
16
+ export { ListAllLockRecordsUseCase_ListAllLockRecordsUseCase as ListAllLockRecordsUseCase };
14
17
 
15
18
  //# sourceMappingURL=ListAllLockRecordsUseCase.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["ListAllLockRecordsUseCase","UseCaseAbstraction","ListAllLockRecordsRepository","ListAllLockRecordsUseCaseImpl","constructor","repository","execute","input","createImplementation","implementation","dependencies"],"sources":["ListAllLockRecordsUseCase.ts"],"sourcesContent":["import { Result } from \"@webiny/feature/api\";\nimport {\n ListAllLockRecordsUseCase as UseCaseAbstraction,\n ListAllLockRecordsRepository,\n ListAllLockRecordsInput,\n ListAllLockRecordsOutput\n} from \"./abstractions.js\";\n\nclass ListAllLockRecordsUseCaseImpl implements UseCaseAbstraction.Interface {\n constructor(private repository: ListAllLockRecordsRepository.Interface) {}\n\n async execute(\n input?: ListAllLockRecordsInput\n ): Promise<Result<ListAllLockRecordsOutput, UseCaseAbstraction.Error>> {\n return await this.repository.execute(input);\n }\n}\n\nexport const ListAllLockRecordsUseCase = UseCaseAbstraction.createImplementation({\n implementation: ListAllLockRecordsUseCaseImpl,\n dependencies: [ListAllLockRecordsRepository]\n});\n"],"mappings":"AACA,SACIA,yBAAyB,IAAIC,kBAAkB,EAC/CC,4BAA4B;AAKhC,MAAMC,6BAA6B,CAAyC;EACxEC,WAAWA,CAASC,UAAkD,EAAE;IAAA,KAApDA,UAAkD,GAAlDA,UAAkD;EAAG;EAEzE,MAAMC,OAAOA,CACTC,KAA+B,EACoC;IACnE,OAAO,MAAM,IAAI,CAACF,UAAU,CAACC,OAAO,CAACC,KAAK,CAAC;EAC/C;AACJ;AAEA,OAAO,MAAMP,yBAAyB,GAAGC,kBAAkB,CAACO,oBAAoB,CAAC;EAC7EC,cAAc,EAAEN,6BAA6B;EAC7CO,YAAY,EAAE,CAACR,4BAA4B;AAC/C,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"features/ListAllLockRecords/ListAllLockRecordsUseCase.js","sources":["../../../src/features/ListAllLockRecords/ListAllLockRecordsUseCase.ts"],"sourcesContent":["import { Result } from \"@webiny/feature/api\";\nimport {\n ListAllLockRecordsUseCase as UseCaseAbstraction,\n ListAllLockRecordsRepository,\n ListAllLockRecordsInput,\n ListAllLockRecordsOutput\n} from \"./abstractions.js\";\n\nclass ListAllLockRecordsUseCaseImpl implements UseCaseAbstraction.Interface {\n constructor(private repository: ListAllLockRecordsRepository.Interface) {}\n\n async execute(\n input?: ListAllLockRecordsInput\n ): Promise<Result<ListAllLockRecordsOutput, UseCaseAbstraction.Error>> {\n return await this.repository.execute(input);\n }\n}\n\nexport const ListAllLockRecordsUseCase = UseCaseAbstraction.createImplementation({\n implementation: ListAllLockRecordsUseCaseImpl,\n dependencies: [ListAllLockRecordsRepository]\n});\n"],"names":["ListAllLockRecordsUseCaseImpl","repository","input","ListAllLockRecordsUseCase","UseCaseAbstraction","ListAllLockRecordsRepository"],"mappings":";AAQA,MAAMA;IACF,YAAoBC,UAAkD,CAAE;aAApDA,UAAU,GAAVA;IAAqD;IAEzE,MAAM,QACFC,KAA+B,EACoC;QACnE,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,OAAO,CAACA;IACzC;AACJ;AAEO,MAAMC,sDAA4BC,0BAAAA,oBAAuC,CAAC;IAC7E,gBAAgBJ;IAChB,cAAc;QAACK;KAA6B;AAChD"}
@@ -1,17 +1,6 @@
1
1
  import { createAbstraction } from "@webiny/feature/api";
2
-
3
- // Input/Output types
4
-
5
- /**
6
- * ListAllLockRecords Use Case - Lists all lock records without filtering
7
- */
8
-
9
- export const ListAllLockRecordsUseCase = createAbstraction("ListAllLockRecordsUseCase");
10
-
11
- /**
12
- * ListAllLockRecordsRepository - Fetches all lock records from storage
13
- */
14
-
15
- export const ListAllLockRecordsRepository = createAbstraction("ListAllLockRecordsRepository");
2
+ const ListAllLockRecordsUseCase = createAbstraction("ListAllLockRecordsUseCase");
3
+ const ListAllLockRecordsRepository = createAbstraction("ListAllLockRecordsRepository");
4
+ export { ListAllLockRecordsRepository, ListAllLockRecordsUseCase };
16
5
 
17
6
  //# sourceMappingURL=abstractions.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["createAbstraction","ListAllLockRecordsUseCase","ListAllLockRecordsRepository"],"sources":["abstractions.ts"],"sourcesContent":["import { createAbstraction } from \"@webiny/feature/api\";\nimport { Result } from \"@webiny/feature/api\";\nimport type { ILockRecord } from \"~/domain/LockRecord.js\";\nimport type { LockRecordPersistenceError } from \"~/domain/errors.js\";\nimport type { CmsEntryListParams, CmsEntryMeta } from \"@webiny/api-headless-cms/types\";\n\n// Input/Output types\nexport type ListAllLockRecordsInput = Pick<\n CmsEntryListParams,\n \"where\" | \"limit\" | \"sort\" | \"after\"\n>;\n\nexport interface ListAllLockRecordsOutput {\n items: ILockRecord[];\n meta: CmsEntryMeta;\n}\n\n/**\n * ListAllLockRecords Use Case - Lists all lock records without filtering\n */\nexport interface IListAllLockRecordsUseCase {\n execute(\n input?: ListAllLockRecordsInput\n ): Promise<Result<ListAllLockRecordsOutput, UseCaseError>>;\n}\n\nexport interface IListAllLockRecordsUseCaseErrors {\n persistence: LockRecordPersistenceError;\n}\n\ntype UseCaseError = IListAllLockRecordsUseCaseErrors[keyof IListAllLockRecordsUseCaseErrors];\n\nexport const ListAllLockRecordsUseCase = createAbstraction<IListAllLockRecordsUseCase>(\n \"ListAllLockRecordsUseCase\"\n);\n\nexport namespace ListAllLockRecordsUseCase {\n export type Interface = IListAllLockRecordsUseCase;\n export type Error = UseCaseError;\n}\n\n/**\n * ListAllLockRecordsRepository - Fetches all lock records from storage\n */\nexport interface IListAllLockRecordsRepository {\n execute(\n input?: ListAllLockRecordsInput\n ): Promise<Result<ListAllLockRecordsOutput, RepositoryError>>;\n}\n\nexport interface IListAllLockRecordsRepositoryErrors {\n persistence: LockRecordPersistenceError;\n}\n\ntype RepositoryError =\n IListAllLockRecordsRepositoryErrors[keyof IListAllLockRecordsRepositoryErrors];\n\nexport const ListAllLockRecordsRepository = createAbstraction<IListAllLockRecordsRepository>(\n \"ListAllLockRecordsRepository\"\n);\n\nexport namespace ListAllLockRecordsRepository {\n export type Interface = IListAllLockRecordsRepository;\n export type Error = RepositoryError;\n}\n"],"mappings":"AAAA,SAASA,iBAAiB,QAAQ,qBAAqB;;AAMvD;;AAWA;AACA;AACA;;AAaA,OAAO,MAAMC,yBAAyB,GAAGD,iBAAiB,CACtD,2BACJ,CAAC;;AAOD;AACA;AACA;;AAcA,OAAO,MAAME,4BAA4B,GAAGF,iBAAiB,CACzD,8BACJ,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"features/ListAllLockRecords/abstractions.js","sources":["../../../src/features/ListAllLockRecords/abstractions.ts"],"sourcesContent":["import { createAbstraction } from \"@webiny/feature/api\";\nimport { Result } from \"@webiny/feature/api\";\nimport type { ILockRecord } from \"~/domain/LockRecord.js\";\nimport type { LockRecordPersistenceError } from \"~/domain/errors.js\";\nimport type { CmsEntryListParams, CmsEntryMeta } from \"@webiny/api-headless-cms/types\";\n\n// Input/Output types\nexport type ListAllLockRecordsInput = Pick<\n CmsEntryListParams,\n \"where\" | \"limit\" | \"sort\" | \"after\"\n>;\n\nexport interface ListAllLockRecordsOutput {\n items: ILockRecord[];\n meta: CmsEntryMeta;\n}\n\n/**\n * ListAllLockRecords Use Case - Lists all lock records without filtering\n */\nexport interface IListAllLockRecordsUseCase {\n execute(\n input?: ListAllLockRecordsInput\n ): Promise<Result<ListAllLockRecordsOutput, UseCaseError>>;\n}\n\nexport interface IListAllLockRecordsUseCaseErrors {\n persistence: LockRecordPersistenceError;\n}\n\ntype UseCaseError = IListAllLockRecordsUseCaseErrors[keyof IListAllLockRecordsUseCaseErrors];\n\nexport const ListAllLockRecordsUseCase = createAbstraction<IListAllLockRecordsUseCase>(\n \"ListAllLockRecordsUseCase\"\n);\n\nexport namespace ListAllLockRecordsUseCase {\n export type Interface = IListAllLockRecordsUseCase;\n export type Error = UseCaseError;\n}\n\n/**\n * ListAllLockRecordsRepository - Fetches all lock records from storage\n */\nexport interface IListAllLockRecordsRepository {\n execute(\n input?: ListAllLockRecordsInput\n ): Promise<Result<ListAllLockRecordsOutput, RepositoryError>>;\n}\n\nexport interface IListAllLockRecordsRepositoryErrors {\n persistence: LockRecordPersistenceError;\n}\n\ntype RepositoryError =\n IListAllLockRecordsRepositoryErrors[keyof IListAllLockRecordsRepositoryErrors];\n\nexport const ListAllLockRecordsRepository = createAbstraction<IListAllLockRecordsRepository>(\n \"ListAllLockRecordsRepository\"\n);\n\nexport namespace ListAllLockRecordsRepository {\n export type Interface = IListAllLockRecordsRepository;\n export type Error = RepositoryError;\n}\n"],"names":["ListAllLockRecordsUseCase","createAbstraction","ListAllLockRecordsRepository"],"mappings":";AAgCO,MAAMA,4BAA4BC,kBACrC;AAwBG,MAAMC,+BAA+BD,kBACxC"}
@@ -1 +1,4 @@
1
- export declare const ListAllLockRecordsFeature: import("@webiny/feature/api/createFeature.js").FeatureDefinition<unknown>;
1
+ export declare const ListAllLockRecordsFeature: {
2
+ name: string;
3
+ register(container: import("@webiny/di").Container): void;
4
+ };
@@ -1,12 +1,13 @@
1
1
  import { createFeature } from "@webiny/feature/api";
2
2
  import { ListAllLockRecordsUseCase } from "./ListAllLockRecordsUseCase.js";
3
3
  import { ListAllLockRecordsRepository } from "./ListAllLockRecordsRepository.js";
4
- export const ListAllLockRecordsFeature = createFeature({
5
- name: "ListAllLockRecords",
6
- register(container) {
7
- container.register(ListAllLockRecordsUseCase);
8
- container.register(ListAllLockRecordsRepository).inSingletonScope();
9
- }
4
+ const ListAllLockRecordsFeature = createFeature({
5
+ name: "ListAllLockRecords",
6
+ register (container) {
7
+ container.register(ListAllLockRecordsUseCase);
8
+ container.register(ListAllLockRecordsRepository).inSingletonScope();
9
+ }
10
10
  });
11
+ export { ListAllLockRecordsFeature };
11
12
 
12
13
  //# sourceMappingURL=feature.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["createFeature","ListAllLockRecordsUseCase","ListAllLockRecordsRepository","ListAllLockRecordsFeature","name","register","container","inSingletonScope"],"sources":["feature.ts"],"sourcesContent":["import { createFeature } from \"@webiny/feature/api\";\nimport { ListAllLockRecordsUseCase } from \"./ListAllLockRecordsUseCase.js\";\nimport { ListAllLockRecordsRepository } from \"./ListAllLockRecordsRepository.js\";\n\nexport const ListAllLockRecordsFeature = createFeature({\n name: \"ListAllLockRecords\",\n register(container) {\n container.register(ListAllLockRecordsUseCase);\n container.register(ListAllLockRecordsRepository).inSingletonScope();\n }\n});\n"],"mappings":"AAAA,SAASA,aAAa,QAAQ,qBAAqB;AACnD,SAASC,yBAAyB;AAClC,SAASC,4BAA4B;AAErC,OAAO,MAAMC,yBAAyB,GAAGH,aAAa,CAAC;EACnDI,IAAI,EAAE,oBAAoB;EAC1BC,QAAQA,CAACC,SAAS,EAAE;IAChBA,SAAS,CAACD,QAAQ,CAACJ,yBAAyB,CAAC;IAC7CK,SAAS,CAACD,QAAQ,CAACH,4BAA4B,CAAC,CAACK,gBAAgB,CAAC,CAAC;EACvE;AACJ,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"features/ListAllLockRecords/feature.js","sources":["../../../src/features/ListAllLockRecords/feature.ts"],"sourcesContent":["import { createFeature } from \"@webiny/feature/api\";\nimport { ListAllLockRecordsUseCase } from \"./ListAllLockRecordsUseCase.js\";\nimport { ListAllLockRecordsRepository } from \"./ListAllLockRecordsRepository.js\";\n\nexport const ListAllLockRecordsFeature = createFeature({\n name: \"ListAllLockRecords\",\n register(container) {\n container.register(ListAllLockRecordsUseCase);\n container.register(ListAllLockRecordsRepository).inSingletonScope();\n }\n});\n"],"names":["ListAllLockRecordsFeature","createFeature","container","ListAllLockRecordsUseCase","ListAllLockRecordsRepository"],"mappings":";;;AAIO,MAAMA,4BAA4BC,cAAc;IACnD,MAAM;IACN,UAASC,SAAS;QACdA,UAAU,QAAQ,CAACC;QACnBD,UAAU,QAAQ,CAACE,8BAA8B,gBAAgB;IACrE;AACJ"}
@@ -1,4 +1,2 @@
1
1
  export * from "./abstractions.js";
2
2
  export * from "./feature.js";
3
-
4
- //# sourceMappingURL=index.js.map
@@ -1,43 +1,43 @@
1
1
  import { Result } from "@webiny/feature/api";
2
2
  import { ListLatestEntriesUseCase } from "@webiny/api-headless-cms/features/contentEntry/ListEntries";
3
- import { ListLockRecordsRepository as RepositoryAbstraction } from "./abstractions.js";
3
+ import { ListLockRecordsRepository } from "./abstractions.js";
4
4
  import { RecordLockingConfig, RecordLockingModel } from "../../domain/abstractions.js";
5
5
  import { LockRecord } from "../../domain/LockRecord.js";
6
6
  import { LockRecordPersistenceError } from "../../domain/errors.js";
7
7
  import { convertWhereCondition } from "../../utils/convertWhereCondition.js";
8
8
  class ListLockRecordsRepositoryImpl {
9
- constructor(model, config, listEntries) {
10
- this.model = model;
11
- this.config = config;
12
- this.listEntries = listEntries;
13
- }
14
- async execute(input) {
15
- try {
16
- const params = {
17
- ...input,
18
- where: convertWhereCondition(input?.where || {})
19
- };
20
- const result = await this.listEntries.execute(this.model, params);
21
- if (result.isFail()) {
22
- return Result.fail(new LockRecordPersistenceError(result.error));
23
- }
24
- const {
25
- entries,
26
- meta
27
- } = result.value;
28
- const items = entries.map(entry => new LockRecord(entry, this.config.timeout));
29
- return Result.ok({
30
- items,
31
- meta
32
- });
33
- } catch (error) {
34
- return Result.fail(new LockRecordPersistenceError(error));
9
+ constructor(model, config, listEntries){
10
+ this.model = model;
11
+ this.config = config;
12
+ this.listEntries = listEntries;
13
+ }
14
+ async execute(input) {
15
+ try {
16
+ const params = {
17
+ ...input,
18
+ where: convertWhereCondition(input?.where || {})
19
+ };
20
+ const result = await this.listEntries.execute(this.model, params);
21
+ if (result.isFail()) return Result.fail(new LockRecordPersistenceError(result.error));
22
+ const { entries, meta } = result.value;
23
+ const items = entries.map((entry)=>new LockRecord(entry, this.config.timeout));
24
+ return Result.ok({
25
+ items,
26
+ meta
27
+ });
28
+ } catch (error) {
29
+ return Result.fail(new LockRecordPersistenceError(error));
30
+ }
35
31
  }
36
- }
37
32
  }
38
- export const ListLockRecordsRepository = RepositoryAbstraction.createImplementation({
39
- implementation: ListLockRecordsRepositoryImpl,
40
- dependencies: [RecordLockingModel, RecordLockingConfig, ListLatestEntriesUseCase]
33
+ const ListLockRecordsRepository_ListLockRecordsRepository = ListLockRecordsRepository.createImplementation({
34
+ implementation: ListLockRecordsRepositoryImpl,
35
+ dependencies: [
36
+ RecordLockingModel,
37
+ RecordLockingConfig,
38
+ ListLatestEntriesUseCase
39
+ ]
41
40
  });
41
+ export { ListLockRecordsRepository_ListLockRecordsRepository as ListLockRecordsRepository };
42
42
 
43
43
  //# sourceMappingURL=ListLockRecordsRepository.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["Result","ListLatestEntriesUseCase","ListLockRecordsRepository","RepositoryAbstraction","RecordLockingConfig","RecordLockingModel","LockRecord","LockRecordPersistenceError","convertWhereCondition","ListLockRecordsRepositoryImpl","constructor","model","config","listEntries","execute","input","params","where","result","isFail","fail","error","entries","meta","value","items","map","entry","timeout","ok","createImplementation","implementation","dependencies"],"sources":["ListLockRecordsRepository.ts"],"sourcesContent":["import { Result } from \"@webiny/feature/api\";\nimport { ListLatestEntriesUseCase } from \"@webiny/api-headless-cms/features/contentEntry/ListEntries\";\nimport {\n ListLockRecordsRepository as RepositoryAbstraction,\n ListLockRecordsInput,\n ListLockRecordsOutput\n} from \"./abstractions.js\";\nimport { RecordLockingConfig, RecordLockingModel } from \"~/domain/abstractions.js\";\nimport { LockRecord } from \"~/domain/LockRecord.js\";\nimport type { LockRecordValues } from \"~/domain/types.js\";\nimport { LockRecordPersistenceError } from \"~/domain/errors.js\";\nimport { convertWhereCondition } from \"~/utils/convertWhereCondition.js\";\n\nclass ListLockRecordsRepositoryImpl implements RepositoryAbstraction.Interface {\n constructor(\n private model: RecordLockingModel.Interface,\n private config: RecordLockingConfig.Interface,\n private listEntries: ListLatestEntriesUseCase.Interface\n ) {}\n\n async execute(\n input?: ListLockRecordsInput\n ): Promise<Result<ListLockRecordsOutput, RepositoryAbstraction.Error>> {\n try {\n const params = {\n ...input,\n where: convertWhereCondition(input?.where || {})\n };\n\n const result = await this.listEntries.execute<LockRecordValues>(this.model, params);\n\n if (result.isFail()) {\n return Result.fail(new LockRecordPersistenceError(result.error));\n }\n\n const { entries, meta } = result.value;\n\n const items = entries.map(entry => new LockRecord(entry, this.config.timeout));\n\n return Result.ok({\n items,\n meta\n });\n } catch (error) {\n return Result.fail(new LockRecordPersistenceError(error as Error));\n }\n }\n}\n\nexport const ListLockRecordsRepository = RepositoryAbstraction.createImplementation({\n implementation: ListLockRecordsRepositoryImpl,\n dependencies: [RecordLockingModel, RecordLockingConfig, ListLatestEntriesUseCase]\n});\n"],"mappings":"AAAA,SAASA,MAAM,QAAQ,qBAAqB;AAC5C,SAASC,wBAAwB,QAAQ,4DAA4D;AACrG,SACIC,yBAAyB,IAAIC,qBAAqB;AAItD,SAASC,mBAAmB,EAAEC,kBAAkB;AAChD,SAASC,UAAU;AAEnB,SAASC,0BAA0B;AACnC,SAASC,qBAAqB;AAE9B,MAAMC,6BAA6B,CAA4C;EAC3EC,WAAWA,CACCC,KAAmC,EACnCC,MAAqC,EACrCC,WAA+C,EACzD;IAAA,KAHUF,KAAmC,GAAnCA,KAAmC;IAAA,KACnCC,MAAqC,GAArCA,MAAqC;IAAA,KACrCC,WAA+C,GAA/CA,WAA+C;EACxD;EAEH,MAAMC,OAAOA,CACTC,KAA4B,EACuC;IACnE,IAAI;MACA,MAAMC,MAAM,GAAG;QACX,GAAGD,KAAK;QACRE,KAAK,EAAET,qBAAqB,CAACO,KAAK,EAAEE,KAAK,IAAI,CAAC,CAAC;MACnD,CAAC;MAED,MAAMC,MAAM,GAAG,MAAM,IAAI,CAACL,WAAW,CAACC,OAAO,CAAmB,IAAI,CAACH,KAAK,EAAEK,MAAM,CAAC;MAEnF,IAAIE,MAAM,CAACC,MAAM,CAAC,CAAC,EAAE;QACjB,OAAOnB,MAAM,CAACoB,IAAI,CAAC,IAAIb,0BAA0B,CAACW,MAAM,CAACG,KAAK,CAAC,CAAC;MACpE;MAEA,MAAM;QAAEC,OAAO;QAAEC;MAAK,CAAC,GAAGL,MAAM,CAACM,KAAK;MAEtC,MAAMC,KAAK,GAAGH,OAAO,CAACI,GAAG,CAACC,KAAK,IAAI,IAAIrB,UAAU,CAACqB,KAAK,EAAE,IAAI,CAACf,MAAM,CAACgB,OAAO,CAAC,CAAC;MAE9E,OAAO5B,MAAM,CAAC6B,EAAE,CAAC;QACbJ,KAAK;QACLF;MACJ,CAAC,CAAC;IACN,CAAC,CAAC,OAAOF,KAAK,EAAE;MACZ,OAAOrB,MAAM,CAACoB,IAAI,CAAC,IAAIb,0BAA0B,CAACc,KAAc,CAAC,CAAC;IACtE;EACJ;AACJ;AAEA,OAAO,MAAMnB,yBAAyB,GAAGC,qBAAqB,CAAC2B,oBAAoB,CAAC;EAChFC,cAAc,EAAEtB,6BAA6B;EAC7CuB,YAAY,EAAE,CAAC3B,kBAAkB,EAAED,mBAAmB,EAAEH,wBAAwB;AACpF,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"features/ListLockRecords/ListLockRecordsRepository.js","sources":["../../../src/features/ListLockRecords/ListLockRecordsRepository.ts"],"sourcesContent":["import { Result } from \"@webiny/feature/api\";\nimport { ListLatestEntriesUseCase } from \"@webiny/api-headless-cms/features/contentEntry/ListEntries\";\nimport {\n ListLockRecordsRepository as RepositoryAbstraction,\n ListLockRecordsInput,\n ListLockRecordsOutput\n} from \"./abstractions.js\";\nimport { RecordLockingConfig, RecordLockingModel } from \"~/domain/abstractions.js\";\nimport { LockRecord } from \"~/domain/LockRecord.js\";\nimport type { LockRecordValues } from \"~/domain/types.js\";\nimport { LockRecordPersistenceError } from \"~/domain/errors.js\";\nimport { convertWhereCondition } from \"~/utils/convertWhereCondition.js\";\n\nclass ListLockRecordsRepositoryImpl implements RepositoryAbstraction.Interface {\n constructor(\n private model: RecordLockingModel.Interface,\n private config: RecordLockingConfig.Interface,\n private listEntries: ListLatestEntriesUseCase.Interface\n ) {}\n\n async execute(\n input?: ListLockRecordsInput\n ): Promise<Result<ListLockRecordsOutput, RepositoryAbstraction.Error>> {\n try {\n const params = {\n ...input,\n where: convertWhereCondition(input?.where || {})\n };\n\n const result = await this.listEntries.execute<LockRecordValues>(this.model, params);\n\n if (result.isFail()) {\n return Result.fail(new LockRecordPersistenceError(result.error));\n }\n\n const { entries, meta } = result.value;\n\n const items = entries.map(entry => new LockRecord(entry, this.config.timeout));\n\n return Result.ok({\n items,\n meta\n });\n } catch (error) {\n return Result.fail(new LockRecordPersistenceError(error as Error));\n }\n }\n}\n\nexport const ListLockRecordsRepository = RepositoryAbstraction.createImplementation({\n implementation: ListLockRecordsRepositoryImpl,\n dependencies: [RecordLockingModel, RecordLockingConfig, ListLatestEntriesUseCase]\n});\n"],"names":["ListLockRecordsRepositoryImpl","model","config","listEntries","input","params","convertWhereCondition","result","Result","LockRecordPersistenceError","entries","meta","items","entry","LockRecord","error","ListLockRecordsRepository","RepositoryAbstraction","RecordLockingModel","RecordLockingConfig","ListLatestEntriesUseCase"],"mappings":";;;;;;;AAaA,MAAMA;IACF,YACYC,KAAmC,EACnCC,MAAqC,EACrCC,WAA+C,CACzD;aAHUF,KAAK,GAALA;aACAC,MAAM,GAANA;aACAC,WAAW,GAAXA;IACT;IAEH,MAAM,QACFC,KAA4B,EACuC;QACnE,IAAI;YACA,MAAMC,SAAS;gBACX,GAAGD,KAAK;gBACR,OAAOE,sBAAsBF,OAAO,SAAS,CAAC;YAClD;YAEA,MAAMG,SAAS,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAmB,IAAI,CAAC,KAAK,EAAEF;YAE5E,IAAIE,OAAO,MAAM,IACb,OAAOC,OAAO,IAAI,CAAC,IAAIC,2BAA2BF,OAAO,KAAK;YAGlE,MAAM,EAAEG,OAAO,EAAEC,IAAI,EAAE,GAAGJ,OAAO,KAAK;YAEtC,MAAMK,QAAQF,QAAQ,GAAG,CAACG,CAAAA,QAAS,IAAIC,WAAWD,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO;YAE5E,OAAOL,OAAO,EAAE,CAAC;gBACbI;gBACAD;YACJ;QACJ,EAAE,OAAOI,OAAO;YACZ,OAAOP,OAAO,IAAI,CAAC,IAAIC,2BAA2BM;QACtD;IACJ;AACJ;AAEO,MAAMC,sDAA4BC,0BAAAA,oBAA0C,CAAC;IAChF,gBAAgBjB;IAChB,cAAc;QAACkB;QAAoBC;QAAqBC;KAAyB;AACrF"}
@@ -1,6 +1,6 @@
1
1
  import { Result } from "@webiny/feature/api";
2
2
  import { ListLockRecordsInput, ListLockRecordsOutput, ListLockRecordsRepository, ListLockRecordsUseCase as UseCaseAbstraction } from "./abstractions.js";
3
- import { IdentityContext } from "@webiny/api-core/features/IdentityContext";
3
+ import { IdentityContext } from "@webiny/api-core/features/security/IdentityContext/index.js";
4
4
  import { RecordLockingConfig } from "../../domain/abstractions.js";
5
5
  declare class ListLockRecordsUseCaseImpl implements UseCaseAbstraction.Interface {
6
6
  private repository;
@@ -1,30 +1,33 @@
1
- import { ListLockRecordsRepository, ListLockRecordsUseCase as UseCaseAbstraction } from "./abstractions.js";
2
- import { IdentityContext } from "@webiny/api-core/features/IdentityContext";
1
+ import { ListLockRecordsRepository, ListLockRecordsUseCase } from "./abstractions.js";
2
+ import { IdentityContext } from "@webiny/api-core/features/security/IdentityContext/index.js";
3
3
  import { RecordLockingConfig } from "../../domain/abstractions.js";
4
4
  class ListLockRecordsUseCaseImpl {
5
- constructor(repository, identityContext, config) {
6
- this.repository = repository;
7
- this.identityContext = identityContext;
8
- this.config = config;
9
- }
10
- async execute(input) {
11
- const identity = this.identityContext.getIdentity();
12
-
13
- // Filter out expired locks and exclude current user's locks
14
- const enhancedInput = {
15
- ...input,
16
- where: {
17
- ...input?.where,
18
- createdBy_not: identity.id,
19
- savedOn_gte: new Date(new Date().getTime() - this.config.timeout).toISOString()
20
- }
21
- };
22
- return await this.repository.execute(enhancedInput);
23
- }
5
+ constructor(repository, identityContext, config){
6
+ this.repository = repository;
7
+ this.identityContext = identityContext;
8
+ this.config = config;
9
+ }
10
+ async execute(input) {
11
+ const identity = this.identityContext.getIdentity();
12
+ const enhancedInput = {
13
+ ...input,
14
+ where: {
15
+ ...input?.where,
16
+ createdBy_not: identity.id,
17
+ savedOn_gte: new Date(new Date().getTime() - this.config.timeout).toISOString()
18
+ }
19
+ };
20
+ return await this.repository.execute(enhancedInput);
21
+ }
24
22
  }
25
- export const ListLockRecordsUseCase = UseCaseAbstraction.createImplementation({
26
- implementation: ListLockRecordsUseCaseImpl,
27
- dependencies: [ListLockRecordsRepository, IdentityContext, RecordLockingConfig]
23
+ const ListLockRecordsUseCase_ListLockRecordsUseCase = ListLockRecordsUseCase.createImplementation({
24
+ implementation: ListLockRecordsUseCaseImpl,
25
+ dependencies: [
26
+ ListLockRecordsRepository,
27
+ IdentityContext,
28
+ RecordLockingConfig
29
+ ]
28
30
  });
31
+ export { ListLockRecordsUseCase_ListLockRecordsUseCase as ListLockRecordsUseCase };
29
32
 
30
33
  //# sourceMappingURL=ListLockRecordsUseCase.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["ListLockRecordsRepository","ListLockRecordsUseCase","UseCaseAbstraction","IdentityContext","RecordLockingConfig","ListLockRecordsUseCaseImpl","constructor","repository","identityContext","config","execute","input","identity","getIdentity","enhancedInput","where","createdBy_not","id","savedOn_gte","Date","getTime","timeout","toISOString","createImplementation","implementation","dependencies"],"sources":["ListLockRecordsUseCase.ts"],"sourcesContent":["import { Result } from \"@webiny/feature/api\";\nimport {\n ListLockRecordsInput,\n ListLockRecordsOutput,\n ListLockRecordsRepository,\n ListLockRecordsUseCase as UseCaseAbstraction\n} from \"./abstractions.js\";\nimport { IdentityContext } from \"@webiny/api-core/features/IdentityContext\";\nimport { RecordLockingConfig } from \"~/domain/abstractions.js\";\n\nclass ListLockRecordsUseCaseImpl implements UseCaseAbstraction.Interface {\n constructor(\n private repository: ListLockRecordsRepository.Interface,\n private identityContext: IdentityContext.Interface,\n private config: RecordLockingConfig.Interface\n ) {}\n\n async execute(\n input?: ListLockRecordsInput\n ): Promise<Result<ListLockRecordsOutput, UseCaseAbstraction.Error>> {\n const identity = this.identityContext.getIdentity();\n\n // Filter out expired locks and exclude current user's locks\n const enhancedInput: ListLockRecordsInput = {\n ...input,\n where: {\n ...input?.where,\n createdBy_not: identity.id,\n savedOn_gte: new Date(new Date().getTime() - this.config.timeout).toISOString()\n }\n };\n\n return await this.repository.execute(enhancedInput);\n }\n}\n\nexport const ListLockRecordsUseCase = UseCaseAbstraction.createImplementation({\n implementation: ListLockRecordsUseCaseImpl,\n dependencies: [ListLockRecordsRepository, IdentityContext, RecordLockingConfig]\n});\n"],"mappings":"AACA,SAGIA,yBAAyB,EACzBC,sBAAsB,IAAIC,kBAAkB;AAEhD,SAASC,eAAe,QAAQ,2CAA2C;AAC3E,SAASC,mBAAmB;AAE5B,MAAMC,0BAA0B,CAAyC;EACrEC,WAAWA,CACCC,UAA+C,EAC/CC,eAA0C,EAC1CC,MAAqC,EAC/C;IAAA,KAHUF,UAA+C,GAA/CA,UAA+C;IAAA,KAC/CC,eAA0C,GAA1CA,eAA0C;IAAA,KAC1CC,MAAqC,GAArCA,MAAqC;EAC9C;EAEH,MAAMC,OAAOA,CACTC,KAA4B,EACoC;IAChE,MAAMC,QAAQ,GAAG,IAAI,CAACJ,eAAe,CAACK,WAAW,CAAC,CAAC;;IAEnD;IACA,MAAMC,aAAmC,GAAG;MACxC,GAAGH,KAAK;MACRI,KAAK,EAAE;QACH,GAAGJ,KAAK,EAAEI,KAAK;QACfC,aAAa,EAAEJ,QAAQ,CAACK,EAAE;QAC1BC,WAAW,EAAE,IAAIC,IAAI,CAAC,IAAIA,IAAI,CAAC,CAAC,CAACC,OAAO,CAAC,CAAC,GAAG,IAAI,CAACX,MAAM,CAACY,OAAO,CAAC,CAACC,WAAW,CAAC;MAClF;IACJ,CAAC;IAED,OAAO,MAAM,IAAI,CAACf,UAAU,CAACG,OAAO,CAACI,aAAa,CAAC;EACvD;AACJ;AAEA,OAAO,MAAMb,sBAAsB,GAAGC,kBAAkB,CAACqB,oBAAoB,CAAC;EAC1EC,cAAc,EAAEnB,0BAA0B;EAC1CoB,YAAY,EAAE,CAACzB,yBAAyB,EAAEG,eAAe,EAAEC,mBAAmB;AAClF,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"features/ListLockRecords/ListLockRecordsUseCase.js","sources":["../../../src/features/ListLockRecords/ListLockRecordsUseCase.ts"],"sourcesContent":["import { Result } from \"@webiny/feature/api\";\nimport {\n ListLockRecordsInput,\n ListLockRecordsOutput,\n ListLockRecordsRepository,\n ListLockRecordsUseCase as UseCaseAbstraction\n} from \"./abstractions.js\";\nimport { IdentityContext } from \"@webiny/api-core/features/security/IdentityContext/index.js\";\nimport { RecordLockingConfig } from \"~/domain/abstractions.js\";\n\nclass ListLockRecordsUseCaseImpl implements UseCaseAbstraction.Interface {\n constructor(\n private repository: ListLockRecordsRepository.Interface,\n private identityContext: IdentityContext.Interface,\n private config: RecordLockingConfig.Interface\n ) {}\n\n async execute(\n input?: ListLockRecordsInput\n ): Promise<Result<ListLockRecordsOutput, UseCaseAbstraction.Error>> {\n const identity = this.identityContext.getIdentity();\n\n // Filter out expired locks and exclude current user's locks\n const enhancedInput: ListLockRecordsInput = {\n ...input,\n where: {\n ...input?.where,\n createdBy_not: identity.id,\n savedOn_gte: new Date(new Date().getTime() - this.config.timeout).toISOString()\n }\n };\n\n return await this.repository.execute(enhancedInput);\n }\n}\n\nexport const ListLockRecordsUseCase = UseCaseAbstraction.createImplementation({\n implementation: ListLockRecordsUseCaseImpl,\n dependencies: [ListLockRecordsRepository, IdentityContext, RecordLockingConfig]\n});\n"],"names":["ListLockRecordsUseCaseImpl","repository","identityContext","config","input","identity","enhancedInput","Date","ListLockRecordsUseCase","UseCaseAbstraction","ListLockRecordsRepository","IdentityContext","RecordLockingConfig"],"mappings":";;;AAUA,MAAMA;IACF,YACYC,UAA+C,EAC/CC,eAA0C,EAC1CC,MAAqC,CAC/C;aAHUF,UAAU,GAAVA;aACAC,eAAe,GAAfA;aACAC,MAAM,GAANA;IACT;IAEH,MAAM,QACFC,KAA4B,EACoC;QAChE,MAAMC,WAAW,IAAI,CAAC,eAAe,CAAC,WAAW;QAGjD,MAAMC,gBAAsC;YACxC,GAAGF,KAAK;YACR,OAAO;gBACH,GAAGA,OAAO,KAAK;gBACf,eAAeC,SAAS,EAAE;gBAC1B,aAAa,IAAIE,KAAK,IAAIA,OAAO,OAAO,KAAK,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,WAAW;YACjF;QACJ;QAEA,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,OAAO,CAACD;IACzC;AACJ;AAEO,MAAME,gDAAyBC,uBAAAA,oBAAuC,CAAC;IAC1E,gBAAgBT;IAChB,cAAc;QAACU;QAA2BC;QAAiBC;KAAoB;AACnF"}
@@ -1,17 +1,6 @@
1
1
  import { createAbstraction } from "@webiny/feature/api";
2
-
3
- // Input/Output types
4
-
5
- /**
6
- * ListLockRecords Use Case - Lists active lock records (filters out expired, excludes current user)
7
- */
8
-
9
- export const ListLockRecordsUseCase = createAbstraction("ListLockRecordsUseCase");
10
-
11
- /**
12
- * ListLockRecordsRepository - Fetches lock records from storage with filtering
13
- */
14
-
15
- export const ListLockRecordsRepository = createAbstraction("ListLockRecordsRepository");
2
+ const ListLockRecordsUseCase = createAbstraction("ListLockRecordsUseCase");
3
+ const ListLockRecordsRepository = createAbstraction("ListLockRecordsRepository");
4
+ export { ListLockRecordsRepository, ListLockRecordsUseCase };
16
5
 
17
6
  //# sourceMappingURL=abstractions.js.map