@chevre/domain
Version:
Chevre Domain Library for Node.js
100 lines (99 loc) • 5.11 kB
JavaScript
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.onReservationCanceled = onReservationCanceled;
/**
* 予約取消時アクション
*/
const factory = require("../../../factory");
// import { Settings } from '../../../settings';
const factory_1 = require("../factory");
// tslint:disable-next-line:max-func-body-length
function onReservationCanceled(
/**
* ステータス変更された予約リスト
*/
canceledReservations,
// useInformReservation: boolean,
/**
* 集計対象イベント
*/
reservationFor, cancelAction) {
return (repos
// settings: Settings
) => __awaiter(this, void 0, void 0, function* () {
var _a;
const setting = yield repos.setting.findOne({ project: { id: { $eq: '*' } } }, ['onReservationStatusChanged']);
// const informReservations = settings.onReservationStatusChanged.informReservation;
const informReservations = (_a = setting === null || setting === void 0 ? void 0 : setting.onReservationStatusChanged) === null || _a === void 0 ? void 0 : _a.informReservation;
let orderAsAbout;
if (Array.isArray(cancelAction.instrument)) {
for (const eachInstrument of cancelAction.instrument) {
if (eachInstrument.typeOf === factory.order.OrderType.Order && typeof eachInstrument.orderNumber === 'string') {
orderAsAbout = { orderNumber: eachInstrument.orderNumber, typeOf: factory.order.OrderType.Order };
break;
}
}
}
if (Array.isArray(canceledReservations) && canceledReservations.length > 0) {
const now = new Date();
const project = canceledReservations[0].project;
const taskAttributes = [];
// inform galobally
const informTaskRunsAt = now;
const reservations4inform = canceledReservations.map((r) => {
return {
typeOf: r.typeOf,
project: r.project,
id: r.id,
reservationStatus: factory.reservationStatusType.ReservationCancelled,
modifiedTime: r.modifiedTime
};
});
if (Array.isArray(informReservations)) {
taskAttributes.push(...informReservations.map((informReservation) => {
var _a, _b;
const informUrl = String((_a = informReservation.recipient) === null || _a === void 0 ? void 0 : _a.url);
const recipientName = (_b = informReservation.recipient) === null || _b === void 0 ? void 0 : _b.name;
const informReservationAttributes = Object.assign({ object: reservations4inform, recipient: {
id: '',
name: (typeof recipientName === 'string') ? recipientName : 'unknown', // redefine name(2025-02-17~)
typeOf: factory.creativeWorkType.WebApplication
// url: informUrl // discontinue(2025-02-13~)
}, target: {
httpMethod: 'POST',
encodingType: factory.encodingFormat.Application.json,
typeOf: 'EntryPoint',
urlTemplate: informUrl
} }, (orderAsAbout !== undefined) ? { about: orderAsAbout } : undefined // add about(2025-02-19~)
);
return {
project,
name: factory.taskName.TriggerWebhook,
status: factory.taskStatus.Ready,
runsAt: informTaskRunsAt,
remainingNumberOfTries: factory_1.NUM_TRY_INFORM_RESERVATION,
numberOfTried: 0,
executionResults: [],
data: informReservationAttributes
};
}));
}
// タスク保管
if (taskAttributes.length > 0) {
yield repos.task.saveMany(taskAttributes, { emitImmediately: true });
}
}
if (typeof (reservationFor === null || reservationFor === void 0 ? void 0 : reservationFor.id) === 'string') {
// create AggregateScreeningEvent task -> migrate to agg(2024-10-29~)
}
});
}
;