@chevre/domain 22.11.0-alpha.3 → 22.11.0-alpha.31

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 (155) hide show
  1. package/example/src/chevre/aggregation/aggregateTasks.ts +41 -0
  2. package/example/src/chevre/assetTransaction/processReserve.ts +0 -1
  3. package/example/src/chevre/notifyAbortedTasksByEmail.ts +1 -1
  4. package/example/src/chevre/reIndex.ts +1 -1
  5. package/example/src/chevre/roles/addAdminPermissionIfNotExists.ts +132 -0
  6. package/example/src/chevre/roles/addDefaultPermissionIfNotExists.ts +37 -0
  7. package/example/src/chevre/roles/addEventOfferPermissionIfNotExists.ts +27 -0
  8. package/example/src/chevre/roles/addPermissionIfNotExists.ts +39 -6
  9. package/example/src/chevre/roles/addProjectCreatorRole.ts +48 -0
  10. package/example/src/chevre/roles/assignGlobalRoles.ts +72 -0
  11. package/example/src/chevre/roles/findPermissions.ts +84 -0
  12. package/example/src/chevre/roles/findRoleNames.ts +117 -0
  13. package/example/src/chevre/roles/removeConsolePermissionIfExists.ts +38 -0
  14. package/example/src/chevre/roles/removePermissionFromAPIRoles.ts +46 -0
  15. package/example/src/chevre/roles/removePermissionIfExists.ts +39 -0
  16. package/example/src/chevre/settings/addSettings.ts +31 -17
  17. package/example/src/chevre/stockHolder/checkRedisKeyCount.ts +11 -20
  18. package/example/src/chevre/task/countPotentiallyRunning.ts +41 -0
  19. package/example/src/chevre/task/countTasks.ts +51 -0
  20. package/example/src/chevre/unsetUnnecessaryFields.ts +8 -5
  21. package/example/src/idaas/auth0/adminApplications.ts +183 -0
  22. package/example/src/idaas/auth0/getToken.ts +55 -0
  23. package/example/src/idaas/auth0/getTokenByPrivateKeyJWT.ts +84 -0
  24. package/example/src/regex.ts +31 -0
  25. package/lib/chevre/eventEmitter/task.d.ts +29 -6
  26. package/lib/chevre/index.d.ts +0 -2
  27. package/lib/chevre/index.js +0 -10
  28. package/lib/chevre/repo/confirmationNumber.d.ts +0 -11
  29. package/lib/chevre/repo/confirmationNumber.js +15 -54
  30. package/lib/chevre/repo/identity.d.ts +11 -33
  31. package/lib/chevre/repo/identity.js +10 -15
  32. package/lib/chevre/repo/member.d.ts +22 -4
  33. package/lib/chevre/repo/member.js +81 -27
  34. package/lib/chevre/repo/mongoose/schemas/identity.d.ts +1 -1
  35. package/lib/chevre/repo/mongoose/schemas/member/global.d.ts +14 -0
  36. package/lib/chevre/repo/mongoose/schemas/member/global.js +82 -0
  37. package/lib/chevre/repo/mongoose/schemas/setting.d.ts +15 -0
  38. package/lib/chevre/repo/mongoose/schemas/setting.js +1 -0
  39. package/lib/chevre/repo/mongoose/schemas/task.js +9 -0
  40. package/lib/chevre/repo/orderNumber.d.ts +0 -11
  41. package/lib/chevre/repo/orderNumber.js +13 -51
  42. package/lib/chevre/repo/role.d.ts +16 -4
  43. package/lib/chevre/repo/role.js +71 -32
  44. package/lib/chevre/repo/serviceOutputIdentifier.d.ts +0 -4
  45. package/lib/chevre/repo/serviceOutputIdentifier.js +13 -38
  46. package/lib/chevre/repo/setting.d.ts +5 -10
  47. package/lib/chevre/repo/setting.js +4 -7
  48. package/lib/chevre/repo/stockHolder.js +0 -11
  49. package/lib/chevre/repo/task.d.ts +47 -34
  50. package/lib/chevre/repo/task.js +114 -292
  51. package/lib/chevre/repo/transaction.js +10 -10
  52. package/lib/chevre/repo/transactionNumber.d.ts +0 -11
  53. package/lib/chevre/repo/transactionNumber.js +13 -51
  54. package/lib/chevre/repo/transactionNumberCounter.d.ts +0 -10
  55. package/lib/chevre/repo/transactionNumberCounter.js +34 -29
  56. package/lib/chevre/service/assetTransaction/cancelReservation/start.d.ts +1 -1
  57. package/lib/chevre/service/code.d.ts +5 -28
  58. package/lib/chevre/service/code.js +3 -79
  59. package/lib/chevre/service/iam.d.ts +17 -7
  60. package/lib/chevre/service/iam.js +26 -6
  61. package/lib/chevre/service/notification/notifyAbortedTasksByEmail.d.ts +15 -0
  62. package/lib/chevre/service/notification/notifyAbortedTasksByEmail.js +38 -0
  63. package/lib/chevre/service/notification.d.ts +2 -1
  64. package/lib/chevre/service/notification.js +3 -1
  65. package/lib/chevre/service/task/acceptCOAOffer.d.ts +1 -1
  66. package/lib/chevre/service/task/acceptCOAOffer.js +6 -5
  67. package/lib/chevre/service/task/aggregateOffers.d.ts +1 -1
  68. package/lib/chevre/service/task/aggregateOnSystem.d.ts +4 -2
  69. package/lib/chevre/service/task/aggregateScreeningEvent.d.ts +1 -1
  70. package/lib/chevre/service/task/authorizePayment.d.ts +1 -1
  71. package/lib/chevre/service/task/authorizePayment.js +7 -6
  72. package/lib/chevre/service/task/cancelMoneyTransfer.d.ts +1 -1
  73. package/lib/chevre/service/task/cancelPendingReservation.d.ts +1 -1
  74. package/lib/chevre/service/task/cancelReservation.d.ts +1 -1
  75. package/lib/chevre/service/task/checkMovieTicket.d.ts +1 -1
  76. package/lib/chevre/service/task/checkMovieTicket.js +4 -3
  77. package/lib/chevre/service/task/checkResource.d.ts +1 -1
  78. package/lib/chevre/service/task/confirmMoneyTransfer.d.ts +1 -1
  79. package/lib/chevre/service/task/confirmPayTransaction.d.ts +1 -1
  80. package/lib/chevre/service/task/confirmRegisterService.d.ts +1 -1
  81. package/lib/chevre/service/task/confirmRegisterServiceTransaction.d.ts +1 -1
  82. package/lib/chevre/service/task/confirmReserveTransaction.d.ts +1 -1
  83. package/lib/chevre/service/task/createAccountingReport.d.ts +1 -1
  84. package/lib/chevre/service/task/createEvent.d.ts +1 -1
  85. package/lib/chevre/service/task/deletePerson.d.ts +1 -1
  86. package/lib/chevre/service/task/deleteTransaction.d.ts +1 -1
  87. package/lib/chevre/service/task/givePointAward.d.ts +1 -1
  88. package/lib/chevre/service/task/givePointAward.js +1 -1
  89. package/lib/chevre/service/task/handleNotification.d.ts +4 -2
  90. package/lib/chevre/service/task/importEventCapacitiesFromCOA.d.ts +1 -1
  91. package/lib/chevre/service/task/importEventsFromCOA.d.ts +1 -1
  92. package/lib/chevre/service/task/importOffersFromCOA.d.ts +1 -1
  93. package/lib/chevre/service/task/invalidatePaymentUrl.d.ts +1 -1
  94. package/lib/chevre/service/task/moneyTransfer.d.ts +1 -1
  95. package/lib/chevre/service/task/moneyTransfer.js +1 -1
  96. package/lib/chevre/service/task/onAssetTransactionStatusChanged.d.ts +1 -1
  97. package/lib/chevre/service/task/onAuthorizationCreated.d.ts +1 -1
  98. package/lib/chevre/service/task/onEventChanged.d.ts +1 -1
  99. package/lib/chevre/service/task/onOrderPaymentCompleted.d.ts +1 -1
  100. package/lib/chevre/service/task/onResourceUpdated.d.ts +1 -1
  101. package/lib/chevre/service/task/pay.d.ts +1 -1
  102. package/lib/chevre/service/task/placeOrder.d.ts +1 -1
  103. package/lib/chevre/service/task/publishPaymentUrl.d.ts +1 -1
  104. package/lib/chevre/service/task/publishPaymentUrl.js +6 -7
  105. package/lib/chevre/service/task/refund.d.ts +1 -1
  106. package/lib/chevre/service/task/refund.js +1 -1
  107. package/lib/chevre/service/task/registerService.d.ts +1 -1
  108. package/lib/chevre/service/task/reserve.d.ts +1 -1
  109. package/lib/chevre/service/task/returnMoneyTransfer.d.ts +1 -1
  110. package/lib/chevre/service/task/returnMoneyTransfer.js +1 -1
  111. package/lib/chevre/service/task/returnOrder.d.ts +1 -1
  112. package/lib/chevre/service/task/returnPayTransaction.d.ts +1 -1
  113. package/lib/chevre/service/task/returnPayTransaction.js +1 -1
  114. package/lib/chevre/service/task/returnPointAward.d.ts +1 -1
  115. package/lib/chevre/service/task/returnPointAward.js +1 -1
  116. package/lib/chevre/service/task/returnReserveTransaction.d.ts +1 -1
  117. package/lib/chevre/service/task/returnReserveTransaction.js +1 -1
  118. package/lib/chevre/service/task/sendEmailMessage.d.ts +1 -1
  119. package/lib/chevre/service/task/sendOrder.d.ts +1 -1
  120. package/lib/chevre/service/task/triggerWebhook.d.ts +1 -1
  121. package/lib/chevre/service/task/useReservation.d.ts +1 -1
  122. package/lib/chevre/service/task/voidMoneyTransferTransaction.d.ts +1 -1
  123. package/lib/chevre/service/task/voidPayTransaction.d.ts +1 -1
  124. package/lib/chevre/service/task/voidPayment.d.ts +1 -1
  125. package/lib/chevre/service/task/voidRegisterServiceTransaction.d.ts +1 -1
  126. package/lib/chevre/service/task/voidReserveTransaction.d.ts +1 -1
  127. package/lib/chevre/service/task/voidReserveTransaction.js +4 -3
  128. package/lib/chevre/service/task.d.ts +7 -29
  129. package/lib/chevre/service/task.js +9 -114
  130. package/lib/chevre/service/taskHandler/onOperationFailed/informTaskIfNeeded.d.ts +11 -0
  131. package/lib/chevre/service/taskHandler/onOperationFailed/informTaskIfNeeded.js +105 -0
  132. package/lib/chevre/service/taskHandler/onOperationFailed.d.ts +17 -0
  133. package/lib/chevre/service/taskHandler/onOperationFailed.js +70 -0
  134. package/lib/chevre/service/taskHandler.d.ts +26 -0
  135. package/lib/chevre/service/taskHandler.js +96 -0
  136. package/lib/chevre/service/validation/validateOrder.js +55 -37
  137. package/lib/chevre/service.d.ts +0 -4
  138. package/lib/chevre/service.js +10 -14
  139. package/lib/chevre/settings/aggregation.d.ts +6 -1
  140. package/lib/chevre/settings/aggregation.js +2 -1
  141. package/package.json +5 -3
  142. package/example/src/chevre/adminAuth/adminIdentity.ts +0 -38
  143. package/example/src/chevre/executeOneTask.ts +0 -41
  144. package/example/src/chevre/executeTaskIfExists.ts +0 -80
  145. package/example/src/chevre/findExecutableTask.ts +0 -50
  146. package/example/src/chevre/findSetting.ts +0 -79
  147. package/example/src/chevre/roles/addRoleMembers.ts +0 -75
  148. package/example/src/chevre/searchPermissions.ts +0 -46
  149. package/example/src/chevre/transactionNumber/publishConfimationNumber.ts +0 -37
  150. package/example/src/chevre/transactionNumber/publishOrderNumber.ts +0 -40
  151. package/example/src/chevre/transactionNumber/setUseMongo4confirmationNumberFrom.ts +0 -45
  152. package/example/src/chevre/transactionNumber/setUseMongo4orderNumberFrom.ts +0 -41
  153. package/example/src/chevre/transactionNumber/setUseMongo4transactionNumberFrom.ts +0 -41
  154. package/lib/chevre/adminAuth.d.ts +0 -2
  155. package/lib/chevre/adminAuth.js +0 -6
@@ -0,0 +1,41 @@
1
+ // tslint:disable:no-console
2
+ import * as moment from 'moment';
3
+ import * as mongoose from 'mongoose';
4
+
5
+ import { chevre } from '../../../../lib/index';
6
+
7
+ // tslint:disable-next-line:max-func-body-length
8
+ async function main() {
9
+ await mongoose.connect(<string>process.env.MONGOLAB_URI, { autoIndex: false });
10
+
11
+ const taskRepo = await chevre.repository.Task.createInstance(mongoose.connection);
12
+
13
+ const aggregateDate = new Date();
14
+ const runsFrom: Date = moment(aggregateDate)
15
+ .utc()
16
+ // .tz('Asia/Tokyo')
17
+ .add(-1, 'days')
18
+ .startOf('days')
19
+ .toDate();
20
+ const runsThrough: Date = moment(aggregateDate)
21
+ .utc()
22
+ // .tz('Asia/Tokyo')
23
+ .add(-1, 'days')
24
+ .endOf('days')
25
+ .toDate();
26
+
27
+ const result = await taskRepo.aggregateTask({
28
+ project: {
29
+ id: { $ne: 'sskts-development' }
30
+ },
31
+ runsFrom,
32
+ runsThrough
33
+ });
34
+ console.dir(result, { depth: null });
35
+ }
36
+
37
+ main()
38
+ .then(() => {
39
+ console.log('success!');
40
+ })
41
+ .catch(console.error);
@@ -19,7 +19,6 @@ async function main() {
19
19
  await mongoose.connect(<string>process.env.MONGOLAB_URI, { autoIndex: false });
20
20
 
21
21
  const transactionNumberRepo = await chevre.repository.TransactionNumber.createInstance({
22
- redisClient,
23
22
  connection: mongoose.connection
24
23
  });
25
24
  const assetTransactionRepo = await chevre.repository.AssetTransaction.createInstance(mongoose.connection);
@@ -30,7 +30,7 @@ async function main() {
30
30
  ]
31
31
  });
32
32
 
33
- const result = await (await chevre.service.task.createService()).notifyAbortedTasksByEmail({
33
+ const result = await (await chevre.service.notification.createService()).notifyAbortedTasksByEmail({
34
34
  dateAbortedGte: moment()
35
35
  // tslint:disable-next-line:no-magic-numbers
36
36
  .add(-10, 'days')
@@ -11,7 +11,7 @@ mongoose.Model.on('index', (...args) => {
11
11
  async function main() {
12
12
  await mongoose.connect(<string>process.env.MONGOLAB_URI, { autoIndex: false });
13
13
 
14
- await chevre.repository.Member.createInstance(mongoose.connection);
14
+ await chevre.repository.Task.createInstance(mongoose.connection);
15
15
  console.log('success!');
16
16
  }
17
17
 
@@ -0,0 +1,132 @@
1
+ // tslint:disable:no-console
2
+ import * as mongoose from 'mongoose';
3
+
4
+ import { chevre } from '../../../../lib/index';
5
+
6
+ // tslint:disable-next-line:max-func-body-length
7
+ async function main() {
8
+ await mongoose.connect(<string>process.env.MONGOLAB_URI, { autoIndex: false });
9
+
10
+ const roleRepo = await chevre.repository.Role.createInstance(mongoose.connection);
11
+
12
+ let roleNames = [
13
+ chevre.factory.role.organizationRole.RoleName.InventoryManager
14
+ ];
15
+ let permissions = [
16
+ 'admin.creativeWorks.*',
17
+ 'admin.sellers.eventSeries.*',
18
+ 'admin.customers.read',
19
+ 'admin.offers.read',
20
+ 'admin.offers.create',
21
+ 'admin.offerCatalogs.create',
22
+ 'admin.offerCatalogItems.read',
23
+ 'admin.offerCatalogItems.create',
24
+ 'admin.products.create',
25
+ 'admin.sellers.events.create',
26
+ 'admin.sellers.events.update'
27
+ ];
28
+ for (const roleName of roleNames) {
29
+ for (const permission of permissions) {
30
+ const result = await roleRepo.addPermissionIfNotExists({
31
+ roleName: { $eq: roleName },
32
+ permission
33
+ });
34
+ console.log('permission added.', result, roleName);
35
+ }
36
+ }
37
+
38
+ roleNames = [
39
+ chevre.factory.role.organizationRole.RoleName.SellersOwner
40
+ ];
41
+ permissions = [
42
+ 'admin.sellers.eventSeries.*',
43
+ 'admin.customers.read',
44
+ 'admin.offers.read',
45
+ 'admin.offerCatalogItems.read',
46
+ 'admin.sellers.events.create',
47
+ 'admin.sellers.events.update',
48
+ 'admin.sellers.orders.read',
49
+ 'admin.sellers.reservations.read',
50
+ 'admin.sellers.reservations.useActions.read',
51
+ 'admin.sellers.assetTransactions.cancelReservation.write'
52
+ ];
53
+ for (const roleName of roleNames) {
54
+ for (const permission of permissions) {
55
+ const result = await roleRepo.addPermissionIfNotExists({
56
+ roleName: { $eq: roleName },
57
+ permission
58
+ });
59
+ console.log('permission added.', result, roleName);
60
+ }
61
+ }
62
+
63
+ roleNames = [
64
+ chevre.factory.role.organizationRole.RoleName.SellersInventoryManager
65
+ ];
66
+ permissions = [
67
+ 'admin.sellers.eventSeries.*',
68
+ 'admin.customers.read',
69
+ 'admin.offers.read',
70
+ 'admin.offerCatalogItems.read',
71
+ 'admin.sellers.events.create',
72
+ 'admin.sellers.events.update'
73
+ ];
74
+ for (const roleName of roleNames) {
75
+ for (const permission of permissions) {
76
+ const result = await roleRepo.addPermissionIfNotExists({
77
+ roleName: { $eq: roleName },
78
+ permission
79
+ });
80
+ console.log('permission added.', result, roleName);
81
+ }
82
+ }
83
+
84
+ roleNames = [
85
+ chevre.factory.role.organizationRole.RoleName.TicketClerk
86
+ ];
87
+ permissions = [
88
+ 'admin.customers.read',
89
+ 'admin.offers.read',
90
+ 'admin.sellers.notes.create',
91
+ 'admin.sellers.notes.read',
92
+ 'admin.sellers.notes.update',
93
+ 'admin.sellers.orders.read',
94
+ 'admin.sellers.orders.update',
95
+ 'admin.sellers.reservations.read',
96
+ 'admin.sellers.reservations.useActions.read',
97
+ 'admin.sellers.reservations.useActions.create',
98
+ 'admin.sellers.assetTransactions.cancelReservation.write'
99
+ ];
100
+ for (const roleName of roleNames) {
101
+ for (const permission of permissions) {
102
+ const result = await roleRepo.addPermissionIfNotExists({
103
+ roleName: { $eq: roleName },
104
+ permission
105
+ });
106
+ console.log('permission added.', result, roleName);
107
+ }
108
+ }
109
+
110
+ roleNames = [
111
+ chevre.factory.role.organizationRole.RoleName.TicketCollector
112
+ ];
113
+ permissions = [
114
+ 'admin.sellers.reservations.read',
115
+ 'admin.sellers.reservations.useActions.read',
116
+ 'admin.sellers.reservations.useActions.create'
117
+ ];
118
+ for (const roleName of roleNames) {
119
+ for (const permission of permissions) {
120
+ const result = await roleRepo.addPermissionIfNotExists({
121
+ roleName: { $eq: roleName },
122
+ permission
123
+ });
124
+ console.log('permission added.', result, roleName);
125
+ }
126
+ }
127
+
128
+ }
129
+
130
+ main()
131
+ .then()
132
+ .catch(console.error);
@@ -0,0 +1,37 @@
1
+ // tslint:disable:no-console
2
+ import * as mongoose from 'mongoose';
3
+
4
+ import { chevre } from '../../../../lib/index';
5
+
6
+ // tslint:disable-next-line:max-func-body-length
7
+ async function main() {
8
+ await mongoose.connect(<string>process.env.MONGOLAB_URI, { autoIndex: false });
9
+
10
+ const roleRepo = await chevre.repository.Role.createInstance(mongoose.connection);
11
+
12
+ const roleNames = [
13
+ chevre.factory.role.organizationRole.RoleName.Customer,
14
+ chevre.factory.role.organizationRole.RoleName.InventoryManager,
15
+ chevre.factory.role.organizationRole.RoleName.POS,
16
+ chevre.factory.role.organizationRole.RoleName.SellersInventoryManager,
17
+ chevre.factory.role.organizationRole.RoleName.SellersOwner,
18
+ chevre.factory.role.organizationRole.RoleName.TicketClerk,
19
+ chevre.factory.role.organizationRole.RoleName.User
20
+ ];
21
+ const permissions = [
22
+ 'db.primary.read'
23
+ ];
24
+ for (const roleName of roleNames) {
25
+ for (const permission of permissions) {
26
+ const result = await roleRepo.addPermissionIfNotExists({
27
+ roleName: { $eq: roleName },
28
+ permission
29
+ });
30
+ console.log('permission added.', result, roleName);
31
+ }
32
+ }
33
+ }
34
+
35
+ main()
36
+ .then()
37
+ .catch(console.error);
@@ -0,0 +1,27 @@
1
+ // tslint:disable:no-console
2
+ import * as mongoose from 'mongoose';
3
+
4
+ import { chevre } from '../../../../lib/index';
5
+
6
+ async function main() {
7
+ await mongoose.connect(<string>process.env.MONGOLAB_URI, { autoIndex: false });
8
+
9
+ const roleRepo = await chevre.repository.Role.createInstance(mongoose.connection);
10
+
11
+ const roleNames = [
12
+ chevre.factory.role.organizationRole.RoleName.InventoryManager,
13
+ chevre.factory.role.organizationRole.RoleName.SellersOwner,
14
+ chevre.factory.role.organizationRole.RoleName.SellersInventoryManager
15
+ ];
16
+ for (const roleName of roleNames) {
17
+ const result = await roleRepo.addPermissionIfNotExists({
18
+ roleName: { $eq: roleName },
19
+ permission: 'eventOffers.*'
20
+ });
21
+ console.log(result, roleName);
22
+ }
23
+ }
24
+
25
+ main()
26
+ .then()
27
+ .catch(console.error);
@@ -8,17 +8,50 @@ async function main() {
8
8
 
9
9
  const roleRepo = await chevre.repository.Role.createInstance(mongoose.connection);
10
10
 
11
- const roleNames = [
11
+ // const roleNames = [
12
+ // chevre.factory.role.organizationRole.RoleName.InventoryManager,
13
+ // chevre.factory.role.organizationRole.RoleName.SellersOwner,
14
+ // chevre.factory.role.organizationRole.RoleName.SellersInventoryManager
15
+ // ];
16
+ // for (const roleName of roleNames) {
17
+ // const result = await roleRepo.addPermissionIfNotExists({
18
+ // roleName: { $eq: roleName },
19
+ // permission: 'eventOffers.*'
20
+ // });
21
+ // console.log(result, roleName);
22
+ // }
23
+ let roleNames = [
24
+ chevre.factory.role.organizationRole.RoleName.InventoryManager
25
+ ];
26
+ let permissions = [
27
+ 'admin.creativeWorks.*'
28
+ ];
29
+ for (const roleName of roleNames) {
30
+ for (const permission of permissions) {
31
+ const result = await roleRepo.addPermissionIfNotExists({
32
+ roleName: { $eq: roleName },
33
+ permission
34
+ });
35
+ console.log('permission added.', result, roleName);
36
+ }
37
+ }
38
+
39
+ roleNames = [
12
40
  chevre.factory.role.organizationRole.RoleName.InventoryManager,
13
41
  chevre.factory.role.organizationRole.RoleName.SellersOwner,
14
42
  chevre.factory.role.organizationRole.RoleName.SellersInventoryManager
15
43
  ];
44
+ permissions = [
45
+ 'admin.sellers.eventSeries.*'
46
+ ];
16
47
  for (const roleName of roleNames) {
17
- const result = await roleRepo.addPermissionIfNotExists({
18
- roleName: { $eq: roleName },
19
- permission: 'eventOffers.*'
20
- });
21
- console.log(result, roleName);
48
+ for (const permission of permissions) {
49
+ const result = await roleRepo.addPermissionIfNotExists({
50
+ roleName: { $eq: roleName },
51
+ permission
52
+ });
53
+ console.log('permission added.', result, roleName);
54
+ }
22
55
  }
23
56
  }
24
57
 
@@ -0,0 +1,48 @@
1
+ // tslint:disable:no-console
2
+ import * as mongoose from 'mongoose';
3
+
4
+ import { chevre } from '../../../../lib/index';
5
+
6
+ async function main() {
7
+ await mongoose.connect(<string>process.env.MONGOLAB_URI, { autoIndex: false });
8
+
9
+ const roleRepo = await chevre.repository.Role.createInstance(mongoose.connection);
10
+
11
+ const roleNames = [
12
+ 'projectCreator'
13
+ ];
14
+ const permissions = [
15
+ 'aggregations.read',
16
+ 'projects.create'
17
+ ];
18
+ for (const roleName of roleNames) {
19
+ const existingRoles = await roleRepo.projectFields(
20
+ {
21
+ roleName: { $eq: roleName }
22
+ },
23
+ ['roleName']
24
+ );
25
+ if (existingRoles.length === 0) {
26
+ const createResult = await roleRepo.create({
27
+ roleName: <any>roleName,
28
+ member: { typeOf: chevre.factory.personType.Person },
29
+ memberOf: { typeOf: chevre.factory.organizationType.Project },
30
+ permissions: []
31
+ });
32
+ console.log('role created.', createResult);
33
+ }
34
+ for (const permission of permissions) {
35
+ const result = await roleRepo.addPermissionIfNotExists({
36
+ roleName: { $eq: <any>roleName },
37
+ permission
38
+ });
39
+ console.log('permission added.', result, roleName);
40
+ }
41
+ }
42
+ }
43
+
44
+ main()
45
+ .then(() => {
46
+ console.log('success!');
47
+ })
48
+ .catch(console.error);
@@ -0,0 +1,72 @@
1
+ // tslint:disable:no-console
2
+ import type { CognitoIdentityProvider as CognitoIdentityServiceProvider } from '@aws-sdk/client-cognito-identity-provider';
3
+ import * as mongoose from 'mongoose';
4
+
5
+ import { IGlobalMember } from '../../../../lib/chevre/repo/mongoose/schemas/member/global';
6
+ import { chevre } from '../../../../lib/index';
7
+
8
+ const { PROJECT_CREATOR_SUB } = process.env;
9
+
10
+ let cognitoIdentityServiceProvider: CognitoIdentityServiceProvider | undefined;
11
+
12
+ async function main() {
13
+ if (typeof PROJECT_CREATOR_SUB !== 'string') {
14
+ throw new Error('PROJECT_CREATOR_SUB setting required');
15
+ }
16
+
17
+ await mongoose.connect(<string>process.env.MONGOLAB_URI, { autoIndex: false });
18
+
19
+ const memberRepo = await chevre.repository.Member.createInstance(mongoose.connection);
20
+ const settingRepo = await chevre.repository.Setting.createInstance(mongoose.connection);
21
+ const setting = await settingRepo.findOne({ project: { id: { $eq: '*' } } }, ['userPoolIdNew']);
22
+ if (typeof setting?.userPoolIdNew !== 'string') {
23
+ throw new chevre.factory.errors.NotFound('setting.userPoolIdNew');
24
+ }
25
+
26
+ let globalMember: IGlobalMember;
27
+
28
+ if (cognitoIdentityServiceProvider === undefined) {
29
+ const { CognitoIdentityProvider } = await import('@aws-sdk/client-cognito-identity-provider');
30
+ const { fromEnv } = await import('@aws-sdk/credential-providers');
31
+ cognitoIdentityServiceProvider = new CognitoIdentityProvider({
32
+ apiVersion: 'latest',
33
+ region: 'ap-northeast-1',
34
+ credentials: fromEnv()
35
+ });
36
+ }
37
+ const personRepo = await chevre.repository.Person.createInstance({
38
+ userPoolId: setting.userPoolIdNew,
39
+ cognitoIdentityServiceProvider
40
+ });
41
+ const profile = await personRepo.findById({ userId: PROJECT_CREATOR_SUB });
42
+ const memberName = (typeof profile.givenName === 'string' && typeof profile.familyName === 'string')
43
+ ? `${profile.givenName} ${profile.familyName}`
44
+ : profile.memberOf?.membershipNumber;
45
+
46
+ globalMember = {
47
+ typeOf: chevre.factory.role.RoleType.OrganizationRole,
48
+ member: {
49
+ typeOf: chevre.factory.personType.Person,
50
+ id: profile.id,
51
+ name: memberName,
52
+ username: profile.memberOf?.membershipNumber,
53
+ hasRole: [{
54
+ typeOf: chevre.factory.role.RoleType.OrganizationRole,
55
+ roleName: <any>'projectCreator'
56
+ }]
57
+ }
58
+ };
59
+ console.log(profile, globalMember);
60
+
61
+ const existingGlobalMemberRoles = await memberRepo.findGlobalRoleNamesByMember({ member: { id: { $eq: globalMember.member.id } } });
62
+ console.log('existingGlobalMemberRoles:', existingGlobalMemberRoles);
63
+
64
+ // 権限作成
65
+ await memberRepo.createGlobalMember([globalMember]);
66
+ }
67
+
68
+ main()
69
+ .then(() => {
70
+ console.log('success!');
71
+ })
72
+ .catch(console.error);
@@ -0,0 +1,84 @@
1
+ // tslint:disable:no-console
2
+ // import * as moment from 'moment';
3
+ import * as mongoose from 'mongoose';
4
+
5
+ import { chevre } from '../../../../lib/index';
6
+
7
+ const formatter = new Intl.NumberFormat('ja-JP');
8
+
9
+ const PROJECT_ID = String(process.env.PROJECT_ID);
10
+ const memberId = 'b3640a78-babd-4da4-81d3-7dcf4881a4a5';
11
+
12
+ async function main() {
13
+ await mongoose.connect(<string>process.env.MONGOLAB_URI);
14
+
15
+ const memberRepo = await chevre.repository.Member.createInstance(mongoose.connection);
16
+ const roleRepo = await chevre.repository.Role.createInstance(mongoose.connection);
17
+
18
+ let startTime: [number, number] = process.hrtime();
19
+ let diff: [number, number] = process.hrtime(startTime);
20
+ let result: any;
21
+
22
+ startTime = process.hrtime();
23
+ result = await (await chevre.service.iam.createService()).findProjectPermissionsByMember({
24
+ project: { id: PROJECT_ID },
25
+ member: {
26
+ id: memberId,
27
+ memberOf: {
28
+ id: PROJECT_ID,
29
+ typeOf: chevre.factory.organizationType.Project
30
+ }
31
+ }
32
+ })({
33
+ member: memberRepo,
34
+ role: roleRepo
35
+ });
36
+ diff = process.hrtime(startTime);
37
+ console.log('diff:', [diff[0], formatter.format(diff[1])]);
38
+ console.log(result.roleNames.length, 'roleNames found');
39
+ console.log(result.permissions.length, 'permissions found');
40
+
41
+ startTime = process.hrtime();
42
+ result = await (await chevre.service.iam.createService()).findProjectPermissionsByMember({
43
+ project: { id: PROJECT_ID },
44
+ member: {
45
+ id: memberId,
46
+ memberOf: {
47
+ id: PROJECT_ID,
48
+ typeOf: chevre.factory.organizationType.Project
49
+ }
50
+ }
51
+ })({
52
+ member: memberRepo,
53
+ role: roleRepo
54
+ });
55
+ diff = process.hrtime(startTime);
56
+ console.log('diff:', [diff[0], formatter.format(diff[1])]);
57
+ console.log(result.roleNames.length, 'roleNames found');
58
+ console.log(result.permissions.length, 'permissions found');
59
+
60
+ startTime = process.hrtime();
61
+ result = await (await chevre.service.iam.createService()).findProjectPermissionsByMember({
62
+ project: { id: PROJECT_ID },
63
+ member: {
64
+ id: memberId,
65
+ memberOf: {
66
+ id: PROJECT_ID,
67
+ typeOf: chevre.factory.organizationType.Project
68
+ }
69
+ }
70
+ })({
71
+ member: memberRepo,
72
+ role: roleRepo
73
+ });
74
+ diff = process.hrtime(startTime);
75
+ console.log('diff:', [diff[0], formatter.format(diff[1])]);
76
+ console.log(result.roleNames.length, 'roleNames found');
77
+ console.log(result.permissions.length, 'permissions found');
78
+
79
+ console.log(result);
80
+ }
81
+
82
+ main()
83
+ .then(console.log)
84
+ .catch(console.error);
@@ -0,0 +1,117 @@
1
+ // tslint:disable:no-console
2
+ // import * as moment from 'moment';
3
+ import * as mongoose from 'mongoose';
4
+
5
+ import { chevre } from '../../../../lib/index';
6
+
7
+ const formatter = new Intl.NumberFormat('ja-JP');
8
+
9
+ const PROJECT_ID = String(process.env.PROJECT_ID);
10
+ const memberId = 'xxx';
11
+
12
+ // tslint:disable-next-line:max-func-body-length
13
+ async function main() {
14
+ await mongoose.connect(<string>process.env.MONGOLAB_URI);
15
+
16
+ const memberRepo = await chevre.repository.Member.createInstance(mongoose.connection);
17
+
18
+ let startTime: [number, number] = process.hrtime();
19
+ let diff: [number, number] = process.hrtime(startTime);
20
+ let result: any;
21
+
22
+ // startTime = process.hrtime();
23
+ // result = await memberRepo.aggregateRoleNames({
24
+ // project: { id: { $eq: PROJECT_ID } },
25
+ // member: {
26
+ // id: { $eq: memberId },
27
+ // memberOf: {
28
+ // id: { $eq: PROJECT_ID },
29
+ // typeOf: { $eq: chevre.factory.organizationType.Project }
30
+ // }
31
+ // }
32
+ // });
33
+ // diff = process.hrtime(startTime);
34
+ // console.log('diff:', [diff[0], formatter.format(diff[1])]);
35
+ // console.log(result.length, 'result found');
36
+
37
+ // startTime = process.hrtime();
38
+ // result = await memberRepo.aggregateRoleNames({
39
+ // project: { id: { $eq: PROJECT_ID } },
40
+ // member: {
41
+ // id: { $eq: memberId },
42
+ // memberOf: {
43
+ // id: { $eq: PROJECT_ID },
44
+ // typeOf: { $eq: chevre.factory.organizationType.Project }
45
+ // }
46
+ // }
47
+ // });
48
+ // diff = process.hrtime(startTime);
49
+ // console.log('diff:', [diff[0], formatter.format(diff[1])]);
50
+ // console.log(result.length, 'result found');
51
+
52
+ // startTime = process.hrtime();
53
+ // result = await memberRepo.aggregateRoleNames({
54
+ // project: { id: { $eq: PROJECT_ID } },
55
+ // member: {
56
+ // id: { $eq: memberId },
57
+ // memberOf: {
58
+ // id: { $eq: PROJECT_ID },
59
+ // typeOf: { $eq: chevre.factory.organizationType.Project }
60
+ // }
61
+ // }
62
+ // });
63
+ // diff = process.hrtime(startTime);
64
+ // console.log('diff:', [diff[0], formatter.format(diff[1])]);
65
+ // console.log(result.length, 'result found');
66
+ // console.log(result);
67
+
68
+ startTime = process.hrtime();
69
+ result = await memberRepo.findRoleNamesByMember({
70
+ project: { id: { $eq: PROJECT_ID } },
71
+ member: {
72
+ id: { $eq: memberId },
73
+ memberOf: {
74
+ id: { $eq: PROJECT_ID },
75
+ typeOf: { $eq: chevre.factory.organizationType.Project }
76
+ }
77
+ }
78
+ });
79
+ diff = process.hrtime(startTime);
80
+ console.log('diff:', [diff[0], formatter.format(diff[1])]);
81
+ console.log(result.length, 'result found');
82
+
83
+ startTime = process.hrtime();
84
+ result = await memberRepo.findRoleNamesByMember({
85
+ project: { id: { $eq: PROJECT_ID } },
86
+ member: {
87
+ id: { $eq: memberId },
88
+ memberOf: {
89
+ id: { $eq: PROJECT_ID },
90
+ typeOf: { $eq: chevre.factory.organizationType.Project }
91
+ }
92
+ }
93
+ });
94
+ diff = process.hrtime(startTime);
95
+ console.log('diff:', [diff[0], formatter.format(diff[1])]);
96
+ console.log(result.length, 'result found');
97
+
98
+ startTime = process.hrtime();
99
+ result = await memberRepo.findRoleNamesByMember({
100
+ project: { id: { $eq: PROJECT_ID } },
101
+ member: {
102
+ id: { $eq: memberId },
103
+ memberOf: {
104
+ id: { $eq: PROJECT_ID },
105
+ typeOf: { $eq: chevre.factory.organizationType.Project }
106
+ }
107
+ }
108
+ });
109
+ diff = process.hrtime(startTime);
110
+ console.log('diff:', [diff[0], formatter.format(diff[1])]);
111
+ console.log(result.length, 'result found');
112
+ console.log(result);
113
+ }
114
+
115
+ main()
116
+ .then(console.log)
117
+ .catch(console.error);
@@ -0,0 +1,38 @@
1
+ // tslint:disable:no-console
2
+ import * as mongoose from 'mongoose';
3
+
4
+ import { chevre } from '../../../../lib/index';
5
+
6
+ async function main() {
7
+ await mongoose.connect(<string>process.env.MONGOLAB_URI, { autoIndex: false });
8
+
9
+ const roleRepo = await chevre.repository.Role.createInstance(mongoose.connection);
10
+
11
+ const permissions = [
12
+ 'assetTransactions.cancelReservation.write',
13
+ 'orders.read',
14
+ 'orders.update',
15
+ 'reservations.attended',
16
+ 'reservations.read'
17
+ ];
18
+ for (const permission of permissions) {
19
+ const roles = await roleRepo.projectFields(
20
+ {
21
+ permissions: { $eq: permission }
22
+ },
23
+ ['roleName']
24
+ );
25
+ console.log(roles, permission);
26
+ for (const { roleName } of roles) {
27
+ const result = await roleRepo.removePermissionIfExists({
28
+ roleName: { $eq: roleName },
29
+ permission
30
+ });
31
+ console.log('permission removed.', permission, result, roleName);
32
+ }
33
+ }
34
+ }
35
+
36
+ main()
37
+ .then()
38
+ .catch(console.error);