@chevre/domain 24.1.0-alpha.2 → 24.1.0-alpha.21

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 (69) hide show
  1. package/README.md +0 -2
  2. package/lib/chevre/repo/acceptedOffer.d.ts +22 -11
  3. package/lib/chevre/repo/acceptedOffer.js +199 -50
  4. package/lib/chevre/repo/accountingReport.d.ts +9 -2
  5. package/lib/chevre/repo/accountingReport.js +6 -34
  6. package/lib/chevre/repo/action/actionProcess.d.ts +1 -1
  7. package/lib/chevre/repo/aggregateReservation.d.ts +6 -0
  8. package/lib/chevre/repo/aggregateReservation.js +9 -0
  9. package/lib/chevre/repo/assetTransaction/reserve.d.ts +3 -1
  10. package/lib/chevre/repo/assetTransaction/reserve.js +3 -1
  11. package/lib/chevre/repo/event.js +12 -8
  12. package/lib/chevre/repo/factory/acceptedOffer/reserveTransaction2itemOffered.d.ts +9 -0
  13. package/lib/chevre/repo/factory/acceptedOffer/reserveTransaction2itemOffered.js +72 -0
  14. package/lib/chevre/repo/factory/reservation/createMongoConditions.js +155 -180
  15. package/lib/chevre/repo/mongoose/schemas/accountingReport.js +42 -42
  16. package/lib/chevre/repo/mongoose/schemas/order.js +108 -108
  17. package/lib/chevre/repo/mongoose/schemas/reservation.d.ts +3 -1
  18. package/lib/chevre/repo/mongoose/schemas/reservation.js +128 -146
  19. package/lib/chevre/repo/order.d.ts +2 -1
  20. package/lib/chevre/repo/order.js +171 -170
  21. package/lib/chevre/repo/orderInTransaction.d.ts +32 -2
  22. package/lib/chevre/repo/orderInTransaction.js +77 -0
  23. package/lib/chevre/repo/reservation.d.ts +20 -7
  24. package/lib/chevre/repo/reservation.js +14 -10
  25. package/lib/chevre/repo/role.d.ts +1 -15
  26. package/lib/chevre/repo/role.js +7 -14
  27. package/lib/chevre/repo/transaction.d.ts +6 -6
  28. package/lib/chevre/service/aggregation/event/aggregateOffers.js +22 -26
  29. package/lib/chevre/service/assetTransaction/cancelReservation/factory.js +14 -11
  30. package/lib/chevre/service/assetTransaction/cancelReservation/start.d.ts +1 -1
  31. package/lib/chevre/service/assetTransaction/cancelReservation/start.js +1 -1
  32. package/lib/chevre/service/assetTransaction/reserve/start/factory/createReservation.js +0 -12
  33. package/lib/chevre/service/assetTransaction/reserve/start/factory/price.d.ts +1 -1
  34. package/lib/chevre/service/offer/any.d.ts +3 -1
  35. package/lib/chevre/service/offer/event/authorize/factory.d.ts +2 -1
  36. package/lib/chevre/service/offer/event/authorize/factory.js +4 -7
  37. package/lib/chevre/service/offer/eventServiceByCOA/authorize/factory.d.ts +1 -0
  38. package/lib/chevre/service/order/createAccountingReportIfNotExist.d.ts +1 -3
  39. package/lib/chevre/service/order/createAccountingReportIfNotExist.js +67 -72
  40. package/lib/chevre/service/order/deleteOrder.js +21 -44
  41. package/lib/chevre/service/order/onAssetTransactionStatusChanged/paymentDue2Processing.js +9 -11
  42. package/lib/chevre/service/order/placeOrder/factory/orderedItem.d.ts +1 -1
  43. package/lib/chevre/service/order/placeOrder/factory/orderedItem.js +0 -5
  44. package/lib/chevre/service/order/placeOrder/factory.d.ts +1 -1
  45. package/lib/chevre/service/order/sendOrder.js +2 -4
  46. package/lib/chevre/service/reserve/confirmReservation.js +7 -7
  47. package/lib/chevre/service/reserve/factory.js +2 -1
  48. package/lib/chevre/service/reserve/findByCode.d.ts +1 -1
  49. package/lib/chevre/service/reserve/findByCode.js +2 -1
  50. package/lib/chevre/service/reserve/findReservations.d.ts +5 -2
  51. package/lib/chevre/service/reserve/findReservations.js +15 -9
  52. package/lib/chevre/service/reserve/potentialActions/onReservationConfirmed.d.ts +4 -3
  53. package/lib/chevre/service/reserve/potentialActions/onReservationConfirmed.js +1 -9
  54. package/lib/chevre/service/reserve/searchByOrder.js +8 -3
  55. package/lib/chevre/service/reserve/useReservation.d.ts +1 -1
  56. package/lib/chevre/service/reserve/useReservation.js +20 -24
  57. package/lib/chevre/service/task/confirmReserveTransaction.js +2 -1
  58. package/lib/chevre/service/task/createAccountingReport.js +7 -9
  59. package/lib/chevre/service/task/payment/payByTask.js +3 -2
  60. package/lib/chevre/service/task/useReservation.d.ts +2 -2
  61. package/lib/chevre/service/task/useReservation.js +6 -18
  62. package/lib/chevre/service/taskHandler.js +1 -0
  63. package/lib/chevre/service/transaction/placeOrder/confirm/validation/validateInvoiceReferencesOrder.d.ts +1 -1
  64. package/lib/chevre/service/transaction/placeOrder/confirm/validation/validateMovieTicket.d.ts +1 -1
  65. package/lib/chevre/service/transaction/placeOrder/confirm/validation.d.ts +2 -2
  66. package/lib/chevre/service/transaction/placeOrder/confirm.js +5 -2
  67. package/lib/chevre/service/transaction/returnOrder/preStart.js +2 -4
  68. package/lib/chevre/service/validation/validateOrder.js +5 -79
  69. package/package.json +2 -2
package/README.md CHANGED
@@ -1,8 +1,6 @@
1
1
  # Chevre Domain Library for Node.js
2
2
 
3
3
  [![npm (scoped)](https://img.shields.io/npm/v/@chevre/domain.svg)](https://www.npmjs.com/package/@chevre/domain)
4
- [![CircleCI](https://circleci.com/gh/chevre-jp/domain.svg?style=svg)](https://circleci.com/gh/chevre-jp/domain)
5
- [![Coverage Status](https://coveralls.io/repos/github/chevre-jp/domain/badge.svg?branch=master)](https://coveralls.io/github/chevre-jp/domain?branch=master)
6
4
  [![Known Vulnerabilities](https://snyk.io/test/github/chevre-jp/domain/badge.svg)](https://snyk.io/test/github/chevre-jp/domain)
7
5
  [![npm](https://img.shields.io/npm/dm/@chevre/domain.svg)](https://nodei.co/npm/@chevre/domain/)
8
6
 
@@ -2,10 +2,8 @@ import type { Connection } from 'mongoose';
2
2
  import { factory } from '../factory';
3
3
  type IProjection4searchWithUnwoundAcceptedOffers = {
4
4
  [key in keyof factory.order.IOrder]?: 1;
5
- } & {
6
- _id?: 0 | 1;
7
- };
8
- type IDistinctField = 'acceptedOffers.id' | 'acceptedOffers.itemOffered.reservationNumber' | 'acceptedOffers.itemOffered.reservationFor.id' | 'acceptedOffers.itemOffered.issuedThrough.id' | 'acceptedOffers.itemOffered.typeOf' | 'acceptedOffers.serialNumber' | 'acceptedOffers.offeredThrough.identifier' | 'acceptedOffers.itemOffered.reservationFor.superEvent.location.branchCode' | 'acceptedOffers.itemOffered.object.pendingTransaction.transactionNumber';
5
+ } & {};
6
+ type IDistinctField = 'acceptedOffers.id' | 'acceptedOffers.itemOffered.reservationNumber' | 'acceptedOffers.itemOffered.reservationFor.id' | 'acceptedOffers.serialNumber' | 'acceptedOffers.offeredThrough.identifier' | 'acceptedOffers.itemOffered.reservationFor.superEvent.location.branchCode';
9
7
  type IAcceptedOffer = factory.order.IAcceptedOffer;
10
8
  interface ISearchSlicedAcceptedOffersResult {
11
9
  acceptedOffers: IAcceptedOffer[];
@@ -16,13 +14,26 @@ interface ISearchSlicedAcceptedOffersResult {
16
14
  */
17
15
  export declare class AcceptedOfferRepo {
18
16
  private readonly orderModel;
17
+ private readonly reserveTransactionModel;
19
18
  constructor(connection: Connection);
19
+ /**
20
+ * 予約番号指定で予約取引からitemOfferedを生成する
21
+ */
22
+ private findSubReservationsByReservationNumbers;
23
+ /**
24
+ * 予約取引からオファー詳細情報を付加する
25
+ */
26
+ private addAcceptedOffersDetails;
20
27
  /**
21
28
  * オファー展開の注文検索
22
29
  */
23
30
  searchWithUnwoundAcceptedOffers(params: factory.order.ISearchConditions, projection: IProjection4searchWithUnwoundAcceptedOffers, options: {
24
- useLimitAfterSkip: boolean;
25
- }): Promise<factory.order.IOrder[]>;
31
+ useMatchBeforeUnwind: boolean;
32
+ useReserveTransaction: boolean;
33
+ }): Promise<(factory.order.IOrder & {
34
+ acceptedOffers: [factory.order.IAcceptedOffer];
35
+ _id?: never;
36
+ })[]>;
26
37
  aggreateOwnershipInfosByOrder(filter: {
27
38
  orderNumber: {
28
39
  $eq: string;
@@ -36,7 +47,6 @@ export declare class AcceptedOfferRepo {
36
47
  searchAcceptedOffersByOrderNumber(filter: {
37
48
  limit?: number;
38
49
  page?: number;
39
- $slice?: [number, number];
40
50
  orderNumber: {
41
51
  $eq: string;
42
52
  };
@@ -53,9 +63,6 @@ export declare class AcceptedOfferRepo {
53
63
  id?: {
54
64
  $eq?: string;
55
65
  };
56
- typeOf?: {
57
- $in?: factory.order.IItemOffered['typeOf'][];
58
- };
59
66
  reservationFor?: {
60
67
  id?: {
61
68
  $in?: string[];
@@ -70,7 +77,9 @@ export declare class AcceptedOfferRepo {
70
77
  };
71
78
  };
72
79
  };
73
- }, inclusion?: (keyof IAcceptedOffer)[]): Promise<IAcceptedOffer[]>;
80
+ }, options: {
81
+ useReserveTransaction: boolean;
82
+ }): Promise<IAcceptedOffer[]>;
74
83
  /**
75
84
  * 注文オファーをsliceして検索する(2024-01-10~)
76
85
  */
@@ -84,6 +93,8 @@ export declare class AcceptedOfferRepo {
84
93
  $eq: string;
85
94
  };
86
95
  };
96
+ }, options: {
97
+ useReserveTransaction: boolean;
87
98
  }): Promise<ISearchSlicedAcceptedOffersResult>;
88
99
  countByOrderNumber(filter: {
89
100
  orderNumber: {
@@ -1,25 +1,97 @@
1
1
  "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
2
5
  Object.defineProperty(exports, "__esModule", { value: true });
3
6
  exports.AcceptedOfferRepo = void 0;
7
+ const debug_1 = __importDefault(require("debug"));
4
8
  const factory_1 = require("../factory");
5
9
  const order_1 = require("./mongoose/schemas/order");
10
+ const assetTransaction_1 = require("./mongoose/schemas/assetTransaction");
11
+ const reserveTransaction2itemOffered_1 = require("./factory/acceptedOffer/reserveTransaction2itemOffered");
6
12
  const order_2 = require("./order");
7
13
  const settings_1 = require("../settings");
14
+ const debug = (0, debug_1.default)('chevre-domain:repo:acceptedOffer');
8
15
  /**
9
16
  * 注文オファーリポジトリ
10
17
  */
11
18
  class AcceptedOfferRepo {
12
19
  orderModel;
20
+ reserveTransactionModel;
13
21
  constructor(connection) {
14
22
  this.orderModel = connection.model(order_1.modelName, (0, order_1.createSchema)());
23
+ this.reserveTransactionModel = connection.model(assetTransaction_1.modelName, (0, assetTransaction_1.createSchema)());
24
+ }
25
+ /**
26
+ * 予約番号指定で予約取引からitemOfferedを生成する
27
+ */
28
+ async findSubReservationsByReservationNumbers(params) {
29
+ const { reservationNumbers } = params;
30
+ if (!Array.isArray(reservationNumbers) || reservationNumbers.length === 0) {
31
+ throw new factory_1.factory.errors.ArgumentNull('reservationNumbers');
32
+ }
33
+ const reserveTransactions = await this.reserveTransactionModel.find({
34
+ transactionNumber: { $in: reservationNumbers },
35
+ typeOf: { $eq: factory_1.factory.assetTransactionType.Reserve }
36
+ }, {
37
+ object: 1
38
+ })
39
+ .lean()
40
+ .exec();
41
+ return reserveTransactions.reduce((a, b) => {
42
+ return [...a, ...(0, reserveTransaction2itemOffered_1.reserveTransaction2itemOffered)(b)];
43
+ }, []);
44
+ }
45
+ /**
46
+ * 予約取引からオファー詳細情報を付加する
47
+ */
48
+ async addAcceptedOffersDetails(acceptedOffers) {
49
+ const offeredThroughIdentifier = acceptedOffers.at(0)?.offeredThrough?.identifier;
50
+ if (offeredThroughIdentifier === factory_1.factory.service.webAPI.Identifier.COA) {
51
+ // COAでは予約取引を参照しない
52
+ return acceptedOffers;
53
+ }
54
+ const reservationNumbers = [...new Set(acceptedOffers.map((acceptedOffer) => String(acceptedOffer.serialNumber)))];
55
+ debug('addAcceptedOffersDetails:', reservationNumbers.length, 'reservationNumbers found.');
56
+ let subReservations = [];
57
+ if (reservationNumbers.length > 0) {
58
+ subReservations = await this.findSubReservationsByReservationNumbers({ reservationNumbers });
59
+ }
60
+ debug('addAcceptedOffersDetails: reservationNumbers.length === subReservations.length?', reservationNumbers.length === subReservations.length);
61
+ return acceptedOffers.map((acceptedOffer) => {
62
+ const subReservation = subReservations.find(((reservation) => reservation.id === acceptedOffer.itemOffered.id));
63
+ // 予約は必ず存在するはず
64
+ if (subReservation === undefined) {
65
+ console.error('addAcceptedOffersDetails: subReservation: undefined!!!', acceptedOffer.itemOffered.id);
66
+ }
67
+ const priceSpecByReserveTransaction = subReservation?.price;
68
+ // 予約の価格は必ず存在するはず
69
+ if (priceSpecByReserveTransaction === undefined) {
70
+ console.error('addAcceptedOffersDetails: priceSpecByReserveTransaction: undefined!!!', acceptedOffer.itemOffered.id);
71
+ }
72
+ const { priceSpecification, ...acceptedOfferWithoutPrice } = acceptedOffer;
73
+ return {
74
+ ...acceptedOfferWithoutPrice,
75
+ ...(priceSpecByReserveTransaction !== undefined)
76
+ ? { priceSpecification: priceSpecByReserveTransaction } // 予約取引参照の値で上書き
77
+ : { priceSpecification } // 万が一予約取引に存在しなければ注文ドキュメントの値を採用
78
+ };
79
+ });
15
80
  }
16
81
  /**
17
82
  * オファー展開の注文検索
18
83
  */
19
84
  async searchWithUnwoundAcceptedOffers(params, projection, options) {
20
- const { useLimitAfterSkip } = options;
85
+ const { useMatchBeforeUnwind } = options;
21
86
  const conditions = order_2.OrderRepo.CREATE_MONGO_CONDITIONS(params);
22
87
  const aggregate = this.orderModel.aggregate();
88
+ if (useMatchBeforeUnwind) {
89
+ // unwind->matchでは遅い?
90
+ // match->unwind->matchにする(2026-05-08~)
91
+ conditions.forEach((c) => {
92
+ aggregate.match(c);
93
+ });
94
+ }
23
95
  // pipelineの順序に注意
24
96
  // @see https://docs.mongodb.com/manual/reference/operator/aggregation/sort/
25
97
  /* istanbul ignore else */
@@ -32,35 +104,70 @@ class AcceptedOfferRepo {
32
104
  });
33
105
  aggregate.project({
34
106
  ...projection,
107
+ _id: 0, // hide _id(2026-05-16~)
35
108
  acceptedOffers: ['$acceptedOffers']
36
109
  });
37
110
  if (typeof params.limit === 'number' && params.limit > 0) {
38
111
  const page = (typeof params.page === 'number' && params.page > 0) ? params.page : 1;
39
112
  // support skip -> limit(2025-07-09~)
40
- if (useLimitAfterSkip) {
41
- aggregate.skip(params.limit * (page - 1))
42
- .limit(params.limit);
43
- }
44
- else {
45
- aggregate.limit(params.limit * page)
46
- .skip(params.limit * (page - 1));
47
- }
113
+ aggregate.skip(params.limit * (page - 1))
114
+ .limit(params.limit);
48
115
  }
49
- return aggregate
50
- // .allowDiskUse(true) // false化(2023-11-30~)
116
+ const orders = await aggregate
51
117
  .option({ maxTimeMS: settings_1.MONGO_MAX_TIME_MS })
52
118
  .exec();
119
+ // 予約取引を参照(2026-05-17~)
120
+ const offeredThroughIdentifier = orders.at(0)?.acceptedOffers[0].offeredThrough?.identifier;
121
+ const useReserveTransaction = options.useReserveTransaction === true
122
+ && offeredThroughIdentifier !== factory_1.factory.service.webAPI.Identifier.COA; // COAでは予約取引を参照しない
123
+ if (useReserveTransaction) {
124
+ const reservationNumbers = [...new Set(orders.map((order) => String(order.acceptedOffers[0].serialNumber)))];
125
+ debug('searchWithUnwoundAcceptedOffers:', reservationNumbers.length, 'reservationNumbers found.');
126
+ let subReservations = [];
127
+ if (reservationNumbers.length > 0) {
128
+ subReservations = await this.findSubReservationsByReservationNumbers({ reservationNumbers });
129
+ }
130
+ debug('searchWithUnwoundAcceptedOffers: reservationNumbers.length === subReservations.length?', reservationNumbers.length === subReservations.length);
131
+ return orders.map((order) => {
132
+ const acceptedOffer = order.acceptedOffers[0];
133
+ const subReservation = subReservations.find(((reservation) => reservation.id === acceptedOffer.itemOffered.id));
134
+ // 予約は必ず存在するはず
135
+ if (subReservation === undefined) {
136
+ console.error('searchWithUnwoundAcceptedOffers: subReservation: undefined!!!', acceptedOffer.itemOffered.id);
137
+ }
138
+ const priceSpecByReserveTransaction = subReservation?.price;
139
+ // 予約の価格は必ず存在するはず
140
+ if (priceSpecByReserveTransaction === undefined) {
141
+ console.error('searchWithUnwoundAcceptedOffers: priceSpecByReserveTransaction: undefined!!!', acceptedOffer.itemOffered.id);
142
+ }
143
+ const { priceSpecification, ...acceptedOfferWithoutPrice } = acceptedOffer;
144
+ return {
145
+ ...order,
146
+ acceptedOffers: [
147
+ {
148
+ ...acceptedOfferWithoutPrice,
149
+ ...(priceSpecByReserveTransaction !== undefined)
150
+ ? { priceSpecification: priceSpecByReserveTransaction } // 予約取引参照の値で上書き
151
+ : { priceSpecification } // 万が一予約取引に存在しなければ注文ドキュメントの値を採用
152
+ }
153
+ ]
154
+ };
155
+ });
156
+ }
157
+ else {
158
+ return orders;
159
+ }
53
160
  }
54
161
  async aggreateOwnershipInfosByOrder(filter) {
55
162
  const aggregate = this.orderModel.aggregate([
163
+ { $match: { orderNumber: { $eq: filter.orderNumber.$eq } } },
164
+ { $match: { typeOf: { $eq: factory_1.factory.order.OrderType.Order } } },
56
165
  {
57
166
  $unwind: {
58
167
  path: '$acceptedOffers',
59
168
  includeArrayIndex: 'acceptedOfferIndex'
60
169
  }
61
170
  },
62
- { $match: { orderNumber: { $eq: filter.orderNumber.$eq } } },
63
- { $match: { typeOf: { $eq: factory_1.factory.order.OrderType.Order } } },
64
171
  {
65
172
  $project: {
66
173
  _id: 0,
@@ -81,22 +188,35 @@ class AcceptedOfferRepo {
81
188
  /**
82
189
  * 注文オファーを展開して検索する
83
190
  */
84
- async searchAcceptedOffersByOrderNumber(filter, inclusion) {
85
- const matchStages = [
191
+ async searchAcceptedOffersByOrderNumber(filter,
192
+ // inclusion?: (keyof IAcceptedOffer)[], // 分かりにくいので廃止(2026-05-17~)
193
+ options) {
194
+ /**
195
+ * unwind前に1ドキュメントを特定するためのstage
196
+ */
197
+ const matchStagesOneDocument = [
86
198
  { $match: { orderNumber: { $eq: filter.orderNumber.$eq } } },
87
199
  { $match: { 'project.id': { $eq: filter.project.id.$eq } } },
88
200
  { $match: { typeOf: { $eq: factory_1.factory.order.OrderType.Order } } }
89
201
  ];
202
+ /**
203
+ * unwind後にオファー内容で絞るstage
204
+ */
205
+ const matchStages = [
206
+ // { $match: { orderNumber: { $eq: filter.orderNumber.$eq } } }, // matchStagesOneDocumentへ移行(2026-05-12~)
207
+ // { $match: { 'project.id': { $eq: filter.project.id.$eq } } }, // matchStagesOneDocumentへ移行(2026-05-12~)
208
+ // { $match: { typeOf: { $eq: factory.order.OrderType.Order } } } // matchStagesOneDocumentへ移行(2026-05-12~)
209
+ ];
90
210
  const itemOfferedIdEq = filter.acceptedOffers?.itemOffered?.id?.$eq;
91
211
  if (typeof itemOfferedIdEq === 'string') {
92
212
  matchStages.push({ $match: { 'acceptedOffers.itemOffered.id': { $exists: true, $eq: itemOfferedIdEq } } });
93
213
  }
94
- const itemOfferedTypeOfIn = filter.acceptedOffers?.itemOffered?.typeOf?.$in;
95
- if (Array.isArray(itemOfferedTypeOfIn)) {
96
- matchStages.push({
97
- $match: { 'acceptedOffers.itemOffered.typeOf': { $exists: true, $in: itemOfferedTypeOfIn } }
98
- });
99
- }
214
+ // const itemOfferedTypeOfIn = filter.acceptedOffers?.itemOffered?.typeOf?.$in;
215
+ // if (Array.isArray(itemOfferedTypeOfIn)) {
216
+ // matchStages.push({
217
+ // $match: { 'acceptedOffers.itemOffered.typeOf': { $exists: true, $in: itemOfferedTypeOfIn } }
218
+ // });
219
+ // }
100
220
  const resevationForIdIn = filter.acceptedOffers?.itemOffered?.reservationFor?.id?.$in;
101
221
  if (Array.isArray(resevationForIdIn)) {
102
222
  matchStages.push({
@@ -114,9 +234,7 @@ class AcceptedOfferRepo {
114
234
  });
115
235
  }
116
236
  const aggregate = this.orderModel.aggregate([
117
- // if (typeof params.sort?.orderDate === 'number') {
118
- // aggregate.sort({ orderDate: params.sort.orderDate });
119
- // }
237
+ ...matchStagesOneDocument,
120
238
  {
121
239
  $unwind: {
122
240
  path: '$acceptedOffers'
@@ -125,40 +243,60 @@ class AcceptedOfferRepo {
125
243
  },
126
244
  ...matchStages
127
245
  ]);
128
- if (Array.isArray(inclusion) && inclusion.length > 0) {
129
- const specifiedProjection = {
130
- _id: 0
131
- };
132
- inclusion.forEach((key) => {
133
- specifiedProjection[key] = `$acceptedOffers.${key}`;
134
- });
135
- aggregate.project(specifiedProjection);
136
- }
137
- else {
138
- aggregate.project({
139
- _id: 0,
140
- itemOffered: '$acceptedOffers.itemOffered',
141
- priceSpecification: '$acceptedOffers.priceSpecification',
142
- typeOf: '$acceptedOffers.typeOf',
143
- id: '$acceptedOffers.id',
144
- offeredThrough: '$acceptedOffers.offeredThrough',
145
- name: '$acceptedOffers.name',
146
- serialNumber: '$acceptedOffers.serialNumber'
147
- });
148
- }
246
+ // if (Array.isArray(inclusion) && inclusion.length > 0) {
247
+ // const specifiedProjection: Record<string, string | 0> = {
248
+ // _id: 0
249
+ // };
250
+ // inclusion.forEach((key) => {
251
+ // specifiedProjection[key] = `$acceptedOffers.${key}`;
252
+ // });
253
+ // aggregate.project(specifiedProjection);
254
+ // } else {
255
+ // aggregate.project({
256
+ // _id: 0,
257
+ // itemOffered: '$acceptedOffers.itemOffered',
258
+ // priceSpecification: '$acceptedOffers.priceSpecification',
259
+ // typeOf: '$acceptedOffers.typeOf',
260
+ // id: '$acceptedOffers.id',
261
+ // offeredThrough: '$acceptedOffers.offeredThrough',
262
+ // name: '$acceptedOffers.name',
263
+ // serialNumber: '$acceptedOffers.serialNumber'
264
+ // });
265
+ // }
266
+ aggregate.project({
267
+ _id: 0,
268
+ itemOffered: '$acceptedOffers.itemOffered',
269
+ priceSpecification: '$acceptedOffers.priceSpecification',
270
+ typeOf: '$acceptedOffers.typeOf',
271
+ id: '$acceptedOffers.id',
272
+ offeredThrough: '$acceptedOffers.offeredThrough',
273
+ name: '$acceptedOffers.name',
274
+ serialNumber: '$acceptedOffers.serialNumber'
275
+ });
149
276
  if (typeof filter.limit === 'number' && filter.limit > 0) {
150
277
  const page = (typeof filter.page === 'number' && filter.page > 0) ? filter.page : 1;
151
- aggregate.limit(filter.limit * page)
152
- .skip(filter.limit * (page - 1));
278
+ // support skip -> limit(2026-05-12~)
279
+ // aggregate.limit(filter.limit * page)
280
+ // .skip(filter.limit * (page - 1));
281
+ aggregate.skip(filter.limit * (page - 1))
282
+ .limit(filter.limit);
153
283
  }
154
- return aggregate
284
+ const acceptedOffers = await aggregate
155
285
  .option({ maxTimeMS: settings_1.MONGO_MAX_TIME_MS })
156
286
  .exec();
287
+ // 予約取引を参照(2026-05-18~)
288
+ const useReserveTransaction = options?.useReserveTransaction === true;
289
+ if (useReserveTransaction) {
290
+ return this.addAcceptedOffersDetails(acceptedOffers);
291
+ }
292
+ else {
293
+ return acceptedOffers;
294
+ }
157
295
  }
158
296
  /**
159
297
  * 注文オファーをsliceして検索する(2024-01-10~)
160
298
  */
161
- async searchSlicedAcceptedOffersByOrderNumber(filter) {
299
+ async searchSlicedAcceptedOffersByOrderNumber(filter, options) {
162
300
  const aggregate = this.orderModel.aggregate([
163
301
  { $match: { orderNumber: { $eq: filter.orderNumber.$eq } } },
164
302
  { $match: { 'project.id': { $eq: filter.project.id.$eq } } },
@@ -177,7 +315,18 @@ class AcceptedOfferRepo {
177
315
  if (result === undefined) {
178
316
  throw new factory_1.factory.errors.NotFound(factory_1.factory.order.OrderType.Order);
179
317
  }
180
- return result;
318
+ const { acceptedOffers, numAcceptedOffers } = result;
319
+ // 予約取引を参照(2026-05-18~)
320
+ const useReserveTransaction = options?.useReserveTransaction === true;
321
+ if (useReserveTransaction) {
322
+ return {
323
+ acceptedOffers: await this.addAcceptedOffersDetails(acceptedOffers),
324
+ numAcceptedOffers
325
+ };
326
+ }
327
+ else {
328
+ return result;
329
+ }
181
330
  }
182
331
  async countByOrderNumber(filter) {
183
332
  const aggregate = this.orderModel.aggregate([
@@ -2,6 +2,11 @@ import type { Connection, PipelineStage } from 'mongoose';
2
2
  import { factory } from '../factory';
3
3
  import { IDocType } from './mongoose/schemas/accountingReport';
4
4
  type IMatchStage = PipelineStage.Match;
5
+ type IReportAsFindResult = Pick<factory.report.accountingReport.IReport, 'mainEntity'> & {
6
+ isPartOf: {
7
+ mainEntity: factory.report.accountingReport.IOrderAsMainEntity;
8
+ };
9
+ };
5
10
  /**
6
11
  * 経理レポートリポジトリ
7
12
  */
@@ -35,11 +40,13 @@ export declare class AccountingReportRepo {
35
40
  };
36
41
  hasPart: factory.report.accountingReport.IChildReport;
37
42
  }): Promise<void>;
38
- search(params: factory.report.accountingReport.ISearchConditions & {
43
+ findAccountingReports(params: factory.report.accountingReport.ISearchConditions & {
39
44
  seller?: {
40
45
  id?: string;
41
46
  };
42
- }): Promise<any[]>;
47
+ limit: number;
48
+ page: number;
49
+ }): Promise<IReportAsFindResult[]>;
43
50
  unsetUnnecessaryFields(params: {
44
51
  filter: any;
45
52
  $unset: any;
@@ -4,7 +4,6 @@ exports.AccountingReportRepo = void 0;
4
4
  const errorHandler_1 = require("../errorHandler");
5
5
  const factory_1 = require("../factory");
6
6
  const accountingReport_1 = require("./mongoose/schemas/accountingReport");
7
- const DEFAULT_SEARCH_LIMIT = 100;
8
7
  /**
9
8
  * 経理レポートリポジトリ
10
9
  */
@@ -49,30 +48,6 @@ class AccountingReportRepo {
49
48
  $match: { 'mainEntity.orderDate': { $lte: orderDateLte } }
50
49
  });
51
50
  }
52
- // discontinue(2026-05-01~)
53
- // const reservationForStartDateGte = params.order?.acceptedOffers?.itemOffered?.reservationFor?.startDate?.$gte;
54
- // if (reservationForStartDateGte instanceof Date) {
55
- // matchStages.push({
56
- // $match: {
57
- // 'mainEntity.acceptedOffers.itemOffered.reservationFor.startDate': {
58
- // $exists: true,
59
- // $gte: reservationForStartDateGte
60
- // }
61
- // }
62
- // });
63
- // }
64
- // discontinue(2026-05-01~)
65
- // const reservationForStartDateLte = params.order?.acceptedOffers?.itemOffered?.reservationFor?.startDate?.$lte;
66
- // if (reservationForStartDateLte instanceof Date) {
67
- // matchStages.push({
68
- // $match: {
69
- // 'mainEntity.acceptedOffers.itemOffered.reservationFor.startDate': {
70
- // $exists: true,
71
- // $lte: reservationForStartDateLte
72
- // }
73
- // }
74
- // });
75
- // }
76
51
  return matchStages;
77
52
  }
78
53
  async syncMainEntity(params) {
@@ -137,18 +112,16 @@ class AccountingReportRepo {
137
112
  throw new factory_1.factory.errors.NotFound(this.accountingReportModel.modelName);
138
113
  }
139
114
  }
140
- async search(params) {
141
- const limit = (typeof params.limit === 'number') ? Math.min(params.limit, DEFAULT_SEARCH_LIMIT) : DEFAULT_SEARCH_LIMIT;
142
- const page = (typeof params.page === 'number') ? Math.max(params.page, 1) : 1;
143
- const unwindAcceptedOffers = params.$unwindAcceptedOffers === '1';
115
+ async findAccountingReports(params) {
116
+ const { limit, page } = params;
144
117
  const matchStages = AccountingReportRepo.CREATE_MONGO_CONDITIONS(params);
145
118
  const aggregate = this.accountingReportModel.aggregate([
119
+ ...matchStages,
146
120
  // pipelineの順序に注意
147
121
  // @see https://docs.mongodb.com/manual/reference/operator/aggregation/sort/
148
122
  { $sort: { 'mainEntity.orderDate': factory_1.factory.sortType.Descending } },
149
123
  { $unwind: '$hasPart' },
150
- ...(unwindAcceptedOffers) ? [{ $unwind: '$mainEntity.acceptedOffers' }] : [],
151
- ...matchStages,
124
+ // hasPart内に対する検索条件は存在しないため、unwind後のmatchは不要
152
125
  {
153
126
  $project: {
154
127
  _id: 0,
@@ -159,10 +132,9 @@ class AccountingReportRepo {
159
132
  }
160
133
  }
161
134
  ]);
162
- return aggregate.allowDiskUse(true)
163
- .limit(limit * page)
135
+ return aggregate
164
136
  .skip(limit * (page - 1))
165
- // .setOptions({ maxTimeMS: 10000 })
137
+ .limit(limit)
166
138
  .exec();
167
139
  }
168
140
  async unsetUnnecessaryFields(params) {
@@ -30,7 +30,7 @@ export type IRecipeAsActionAttributes<T extends factory.recipe.RecipeCategory> =
30
30
  export type IMinimizedPurchaseNumberAuthResult = Pick<factory.action.check.paymentMethod.movieTicket.IPurchaseNumberAuthResult, 'mkknmiNumSum' | 'resultInfo' | 'ykknmiNumSum'> & {
31
31
  knyknrNoInfoOut: Omit<factory.action.check.paymentMethod.movieTicket.IPurchaseNumberInfo, 'ykknInfo' | 'mkknInfo'>[] | null;
32
32
  };
33
- export type IKeyOfProjection = keyof IAction<factory.actionType> | keyof IAction<factory.actionType.AuthorizeAction> | keyof IAction<factory.actionType.MoneyTransfer> | keyof IAction<factory.actionType.ReplaceAction> | 'identifier';
33
+ export type IKeyOfProjection = keyof IAction<factory.actionType> | keyof IAction<factory.actionType.AuthorizeAction> | keyof IAction<factory.actionType.ReplaceAction> | 'identifier';
34
34
  export declare const AVAILABLE_PROJECT_FIELDS: IKeyOfProjection[];
35
35
  /**
36
36
  * アクション状態管理リポジトリ
@@ -54,5 +54,11 @@ export declare class AggregateReservationRepo {
54
54
  filter: any;
55
55
  $unset: any;
56
56
  }): Promise<import("mongoose").UpdateWriteOpResult>;
57
+ /**
58
+ * イベント開始日時が指定以前の集計を削除する
59
+ */
60
+ deleteManyByEventStartDate(params: {
61
+ reservationForStartDateLte: Date;
62
+ }): Promise<import("mongodb").DeleteResult>;
57
63
  }
58
64
  export {};
@@ -132,5 +132,14 @@ class AggregateReservationRepo {
132
132
  return this.aggregateReservationModel.updateMany(params.filter, { $unset: params.$unset }, { timestamps: false })
133
133
  .exec();
134
134
  }
135
+ /**
136
+ * イベント開始日時が指定以前の集計を削除する
137
+ */
138
+ async deleteManyByEventStartDate(params) {
139
+ return this.aggregateReservationModel.deleteMany({
140
+ 'reservationFor.startDate': { $lte: params.reservationForStartDateLte }
141
+ })
142
+ .exec();
143
+ }
135
144
  }
136
145
  exports.AggregateReservationRepo = AggregateReservationRepo;
@@ -1,9 +1,11 @@
1
1
  import type { Connection } from 'mongoose';
2
2
  import { factory } from '../../factory';
3
3
  type ISubReservationAsFindResult = Pick<factory.reservation.eventReservation.IReservation, 'underName' | 'id'> & {
4
- price?: factory.reservation.eventReservation.IPrice;
4
+ numSeats?: number;
5
+ price?: factory.assetTransaction.reserve.IPrice;
5
6
  reservedTicket?: Pick<factory.reservation.eventReservation.IReservedTicket, 'ticketType'>;
6
7
  reservationFor?: factory.assetTransaction.reserve.IReservationFor;
8
+ issuedThrough?: factory.assetTransaction.reserve.IIssuedThrough;
7
9
  };
8
10
  /**
9
11
  * 予約取引リポジトリ
@@ -91,12 +91,14 @@ class ReserveTransactionRepo {
91
91
  $project: {
92
92
  _id: 0,
93
93
  id: '$object.subReservation.id',
94
+ numSeats: '$object.subReservation.numSeats',
94
95
  price: '$object.subReservation.price',
95
96
  underName: '$object.underName',
96
97
  reservationFor: '$object.reservationFor',
97
98
  reservedTicket: {
98
99
  ticketType: '$object.subReservation.reservedTicket.ticketType',
99
- }
100
+ },
101
+ issuedThrough: '$object.issuedThrough',
100
102
  }
101
103
  }
102
104
  ]);
@@ -798,22 +798,26 @@ class EventRepo {
798
798
  .sort({ startDate: factory_1.factory.sortType.Descending })
799
799
  .cursor();
800
800
  }
801
- // public async addAvailableAtOrFrom(params: {
801
+ // /**
802
+ // * アプリケーションオファー廃止用のメソッド
803
+ // */
804
+ // public async removeAvailableAtOrFrom(params: {
802
805
  // id: string;
803
806
  // offers: {
804
807
  // seller: {
805
- // makesOffer: factory.event.screeningEvent.ISellerMakesOffer;
808
+ // makesOffer: Pick<factory.event.screeningEvent.ISellerMakesOffer, 'availableAtOrFrom'>;
806
809
  // };
807
810
  // };
808
- // }): Promise<void> {
809
- // await this.eventModel.updateOne(
811
+ // }) {
812
+ // return this.eventModel.updateOne(
810
813
  // { _id: { $eq: params.id } },
811
814
  // {
812
- // $push: {
813
- // 'offers.seller.makesOffer': params.offers.seller.makesOffer
815
+ // $pull: {
816
+ // 'offers.seller.makesOffer': {
817
+ // 'availableAtOrFrom.id': { $eq: params.offers.seller.makesOffer.availableAtOrFrom.id }
818
+ // }
814
819
  // }
815
- // },
816
- // { includeResultMetadata: true }
820
+ // }
817
821
  // )
818
822
  // .exec();
819
823
  // }
@@ -0,0 +1,9 @@
1
+ import { factory } from '../../../factory';
2
+ type IItemOfferedByReserveTransaction = factory.order.IEventReservation & {
3
+ price?: factory.assetTransaction.reserve.IPrice;
4
+ };
5
+ /**
6
+ * 予約取引を注文のitemOfferedへ変換する
7
+ */
8
+ declare function reserveTransaction2itemOffered(params: Pick<factory.assetTransaction.reserve.ITransaction, 'object'>): IItemOfferedByReserveTransaction[];
9
+ export { IItemOfferedByReserveTransaction, reserveTransaction2itemOffered };