@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.
- package/README.md +0 -2
- package/lib/chevre/repo/acceptedOffer.d.ts +22 -11
- package/lib/chevre/repo/acceptedOffer.js +199 -50
- package/lib/chevre/repo/accountingReport.d.ts +9 -2
- package/lib/chevre/repo/accountingReport.js +6 -34
- package/lib/chevre/repo/action/actionProcess.d.ts +1 -1
- package/lib/chevre/repo/aggregateReservation.d.ts +6 -0
- package/lib/chevre/repo/aggregateReservation.js +9 -0
- package/lib/chevre/repo/assetTransaction/reserve.d.ts +3 -1
- package/lib/chevre/repo/assetTransaction/reserve.js +3 -1
- package/lib/chevre/repo/event.js +12 -8
- package/lib/chevre/repo/factory/acceptedOffer/reserveTransaction2itemOffered.d.ts +9 -0
- package/lib/chevre/repo/factory/acceptedOffer/reserveTransaction2itemOffered.js +72 -0
- package/lib/chevre/repo/factory/reservation/createMongoConditions.js +155 -180
- package/lib/chevre/repo/mongoose/schemas/accountingReport.js +42 -42
- package/lib/chevre/repo/mongoose/schemas/order.js +108 -108
- package/lib/chevre/repo/mongoose/schemas/reservation.d.ts +3 -1
- package/lib/chevre/repo/mongoose/schemas/reservation.js +128 -146
- package/lib/chevre/repo/order.d.ts +2 -1
- package/lib/chevre/repo/order.js +171 -170
- package/lib/chevre/repo/orderInTransaction.d.ts +32 -2
- package/lib/chevre/repo/orderInTransaction.js +77 -0
- package/lib/chevre/repo/reservation.d.ts +20 -7
- package/lib/chevre/repo/reservation.js +14 -10
- package/lib/chevre/repo/role.d.ts +1 -15
- package/lib/chevre/repo/role.js +7 -14
- package/lib/chevre/repo/transaction.d.ts +6 -6
- package/lib/chevre/service/aggregation/event/aggregateOffers.js +22 -26
- package/lib/chevre/service/assetTransaction/cancelReservation/factory.js +14 -11
- package/lib/chevre/service/assetTransaction/cancelReservation/start.d.ts +1 -1
- package/lib/chevre/service/assetTransaction/cancelReservation/start.js +1 -1
- package/lib/chevre/service/assetTransaction/reserve/start/factory/createReservation.js +0 -12
- package/lib/chevre/service/assetTransaction/reserve/start/factory/price.d.ts +1 -1
- package/lib/chevre/service/offer/any.d.ts +3 -1
- package/lib/chevre/service/offer/event/authorize/factory.d.ts +2 -1
- package/lib/chevre/service/offer/event/authorize/factory.js +4 -7
- package/lib/chevre/service/offer/eventServiceByCOA/authorize/factory.d.ts +1 -0
- package/lib/chevre/service/order/createAccountingReportIfNotExist.d.ts +1 -3
- package/lib/chevre/service/order/createAccountingReportIfNotExist.js +67 -72
- package/lib/chevre/service/order/deleteOrder.js +21 -44
- package/lib/chevre/service/order/onAssetTransactionStatusChanged/paymentDue2Processing.js +9 -11
- package/lib/chevre/service/order/placeOrder/factory/orderedItem.d.ts +1 -1
- package/lib/chevre/service/order/placeOrder/factory/orderedItem.js +0 -5
- package/lib/chevre/service/order/placeOrder/factory.d.ts +1 -1
- package/lib/chevre/service/order/sendOrder.js +2 -4
- package/lib/chevre/service/reserve/confirmReservation.js +7 -7
- package/lib/chevre/service/reserve/factory.js +2 -1
- package/lib/chevre/service/reserve/findByCode.d.ts +1 -1
- package/lib/chevre/service/reserve/findByCode.js +2 -1
- package/lib/chevre/service/reserve/findReservations.d.ts +5 -2
- package/lib/chevre/service/reserve/findReservations.js +15 -9
- package/lib/chevre/service/reserve/potentialActions/onReservationConfirmed.d.ts +4 -3
- package/lib/chevre/service/reserve/potentialActions/onReservationConfirmed.js +1 -9
- package/lib/chevre/service/reserve/searchByOrder.js +8 -3
- package/lib/chevre/service/reserve/useReservation.d.ts +1 -1
- package/lib/chevre/service/reserve/useReservation.js +20 -24
- package/lib/chevre/service/task/confirmReserveTransaction.js +2 -1
- package/lib/chevre/service/task/createAccountingReport.js +7 -9
- package/lib/chevre/service/task/payment/payByTask.js +3 -2
- package/lib/chevre/service/task/useReservation.d.ts +2 -2
- package/lib/chevre/service/task/useReservation.js +6 -18
- package/lib/chevre/service/taskHandler.js +1 -0
- package/lib/chevre/service/transaction/placeOrder/confirm/validation/validateInvoiceReferencesOrder.d.ts +1 -1
- package/lib/chevre/service/transaction/placeOrder/confirm/validation/validateMovieTicket.d.ts +1 -1
- package/lib/chevre/service/transaction/placeOrder/confirm/validation.d.ts +2 -2
- package/lib/chevre/service/transaction/placeOrder/confirm.js +5 -2
- package/lib/chevre/service/transaction/returnOrder/preStart.js +2 -4
- package/lib/chevre/service/validation/validateOrder.js +5 -79
- 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
|
[](https://www.npmjs.com/package/@chevre/domain)
|
|
4
|
-
[](https://circleci.com/gh/chevre-jp/domain)
|
|
5
|
-
[](https://coveralls.io/github/chevre-jp/domain?branch=master)
|
|
6
4
|
[](https://snyk.io/test/github/chevre-jp/domain)
|
|
7
5
|
[](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
|
-
|
|
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
|
-
|
|
25
|
-
|
|
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
|
-
},
|
|
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 {
|
|
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
|
-
|
|
41
|
-
|
|
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
|
-
|
|
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,
|
|
85
|
-
|
|
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
|
-
|
|
97
|
-
|
|
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
|
-
|
|
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
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
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
|
-
|
|
152
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
43
|
+
findAccountingReports(params: factory.report.accountingReport.ISearchConditions & {
|
|
39
44
|
seller?: {
|
|
40
45
|
id?: string;
|
|
41
46
|
};
|
|
42
|
-
|
|
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
|
|
141
|
-
const
|
|
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
|
-
|
|
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
|
|
163
|
-
.limit(limit * page)
|
|
135
|
+
return aggregate
|
|
164
136
|
.skip(limit * (page - 1))
|
|
165
|
-
|
|
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.
|
|
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
|
-
|
|
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
|
]);
|
package/lib/chevre/repo/event.js
CHANGED
|
@@ -798,22 +798,26 @@ class EventRepo {
|
|
|
798
798
|
.sort({ startDate: factory_1.factory.sortType.Descending })
|
|
799
799
|
.cursor();
|
|
800
800
|
}
|
|
801
|
-
//
|
|
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
|
-
// })
|
|
809
|
-
//
|
|
811
|
+
// }) {
|
|
812
|
+
// return this.eventModel.updateOne(
|
|
810
813
|
// { _id: { $eq: params.id } },
|
|
811
814
|
// {
|
|
812
|
-
// $
|
|
813
|
-
// '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 };
|