@k-msg/channel 0.1.1 → 0.1.2
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/dist/index.d.ts +8 -837
- package/dist/index.js +20 -2413
- package/dist/index.js.map +80 -1
- package/dist/index.mjs +24 -0
- package/dist/index.mjs.map +80 -0
- package/dist/kakao/channel.d.ts +25 -0
- package/dist/kakao/sender-number.d.ts +31 -0
- package/dist/management/crud.d.ts +88 -0
- package/dist/management/permissions.d.ts +124 -0
- package/dist/services/channel.service.d.ts +22 -0
- package/dist/types/channel.types.d.ts +228 -0
- package/dist/verification/business.verify.d.ts +131 -0
- package/dist/verification/number.verify.d.ts +183 -0
- package/package.json +17 -12
- package/dist/index.cjs +0 -2466
- package/dist/index.cjs.map +0 -1
- package/dist/index.d.cts +0 -837
package/dist/index.js
CHANGED
|
@@ -1,2417 +1,24 @@
|
|
|
1
|
-
// src/types/channel.types.ts
|
|
2
|
-
import { z } from "zod";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
ChannelStatus2["SUSPENDED"] = "SUSPENDED";
|
|
16
|
-
ChannelStatus2["BLOCKED"] = "BLOCKED";
|
|
17
|
-
ChannelStatus2["DELETED"] = "DELETED";
|
|
18
|
-
return ChannelStatus2;
|
|
19
|
-
})(ChannelStatus || {});
|
|
20
|
-
var SenderNumberStatus = /* @__PURE__ */ ((SenderNumberStatus2) => {
|
|
21
|
-
SenderNumberStatus2["PENDING"] = "PENDING";
|
|
22
|
-
SenderNumberStatus2["VERIFYING"] = "VERIFYING";
|
|
23
|
-
SenderNumberStatus2["VERIFIED"] = "VERIFIED";
|
|
24
|
-
SenderNumberStatus2["REJECTED"] = "REJECTED";
|
|
25
|
-
SenderNumberStatus2["BLOCKED"] = "BLOCKED";
|
|
26
|
-
return SenderNumberStatus2;
|
|
27
|
-
})(SenderNumberStatus || {});
|
|
28
|
-
var SenderNumberCategory = /* @__PURE__ */ ((SenderNumberCategory3) => {
|
|
29
|
-
SenderNumberCategory3["BUSINESS"] = "BUSINESS";
|
|
30
|
-
SenderNumberCategory3["PERSONAL"] = "PERSONAL";
|
|
31
|
-
SenderNumberCategory3["GOVERNMENT"] = "GOVERNMENT";
|
|
32
|
-
SenderNumberCategory3["NON_PROFIT"] = "NON_PROFIT";
|
|
33
|
-
return SenderNumberCategory3;
|
|
34
|
-
})(SenderNumberCategory || {});
|
|
35
|
-
var VerificationStatus = /* @__PURE__ */ ((VerificationStatus2) => {
|
|
36
|
-
VerificationStatus2["NOT_REQUIRED"] = "NOT_REQUIRED";
|
|
37
|
-
VerificationStatus2["PENDING"] = "PENDING";
|
|
38
|
-
VerificationStatus2["UNDER_REVIEW"] = "UNDER_REVIEW";
|
|
39
|
-
VerificationStatus2["VERIFIED"] = "VERIFIED";
|
|
40
|
-
VerificationStatus2["REJECTED"] = "REJECTED";
|
|
41
|
-
return VerificationStatus2;
|
|
42
|
-
})(VerificationStatus || {});
|
|
43
|
-
var DocumentType = /* @__PURE__ */ ((DocumentType2) => {
|
|
44
|
-
DocumentType2["BUSINESS_REGISTRATION"] = "BUSINESS_REGISTRATION";
|
|
45
|
-
DocumentType2["BUSINESS_LICENSE"] = "BUSINESS_LICENSE";
|
|
46
|
-
DocumentType2["ID_CARD"] = "ID_CARD";
|
|
47
|
-
DocumentType2["AUTHORIZATION_LETTER"] = "AUTHORIZATION_LETTER";
|
|
48
|
-
DocumentType2["OTHER"] = "OTHER";
|
|
49
|
-
return DocumentType2;
|
|
50
|
-
})(DocumentType || {});
|
|
51
|
-
var DocumentStatus = /* @__PURE__ */ ((DocumentStatus2) => {
|
|
52
|
-
DocumentStatus2["UPLOADED"] = "UPLOADED";
|
|
53
|
-
DocumentStatus2["VERIFIED"] = "VERIFIED";
|
|
54
|
-
DocumentStatus2["REJECTED"] = "REJECTED";
|
|
55
|
-
return DocumentStatus2;
|
|
56
|
-
})(DocumentStatus || {});
|
|
57
|
-
var ChannelCreateRequestSchema = z.object({
|
|
58
|
-
name: z.string().min(1).max(100),
|
|
59
|
-
type: z.nativeEnum(ChannelType),
|
|
60
|
-
provider: z.string().min(1),
|
|
61
|
-
profileKey: z.string().min(1),
|
|
62
|
-
businessInfo: z.object({
|
|
63
|
-
name: z.string().min(1),
|
|
64
|
-
registrationNumber: z.string().min(1),
|
|
65
|
-
category: z.string().min(1),
|
|
66
|
-
contactPerson: z.string().min(1),
|
|
67
|
-
contactEmail: z.string().email(),
|
|
68
|
-
contactPhone: z.string().regex(/^[0-9-+\s()]+$/)
|
|
69
|
-
}).optional(),
|
|
70
|
-
kakaoInfo: z.object({
|
|
71
|
-
plusFriendId: z.string().min(1),
|
|
72
|
-
brandName: z.string().min(1),
|
|
73
|
-
logoUrl: z.string().url().optional(),
|
|
74
|
-
description: z.string().max(500).optional()
|
|
75
|
-
}).optional()
|
|
76
|
-
});
|
|
77
|
-
var SenderNumberCreateRequestSchema = z.object({
|
|
78
|
-
phoneNumber: z.string().regex(/^[0-9]{10,11}$/),
|
|
79
|
-
category: z.nativeEnum(SenderNumberCategory),
|
|
80
|
-
businessInfo: z.object({
|
|
81
|
-
businessName: z.string().min(1),
|
|
82
|
-
businessRegistrationNumber: z.string().min(1),
|
|
83
|
-
contactPerson: z.string().min(1),
|
|
84
|
-
contactEmail: z.string().email()
|
|
85
|
-
}).optional()
|
|
86
|
-
});
|
|
87
|
-
var ChannelFiltersSchema = z.object({
|
|
88
|
-
provider: z.string().optional(),
|
|
89
|
-
type: z.nativeEnum(ChannelType).optional(),
|
|
90
|
-
status: z.nativeEnum(ChannelStatus).optional(),
|
|
91
|
-
verified: z.boolean().optional(),
|
|
92
|
-
createdAfter: z.date().optional(),
|
|
93
|
-
createdBefore: z.date().optional()
|
|
94
|
-
});
|
|
95
|
-
var SenderNumberFiltersSchema = z.object({
|
|
96
|
-
channelId: z.string().optional(),
|
|
97
|
-
status: z.nativeEnum(SenderNumberStatus).optional(),
|
|
98
|
-
category: z.nativeEnum(SenderNumberCategory).optional(),
|
|
99
|
-
verified: z.boolean().optional()
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
// src/kakao/channel.ts
|
|
103
|
-
var KakaoChannelManager = class {
|
|
104
|
-
constructor() {
|
|
105
|
-
this.channels = /* @__PURE__ */ new Map();
|
|
106
|
-
}
|
|
107
|
-
async createChannel(request) {
|
|
108
|
-
this.validateKakaoChannelRequest(request);
|
|
109
|
-
const channelId = this.generateChannelId();
|
|
110
|
-
const channel = {
|
|
111
|
-
id: channelId,
|
|
112
|
-
name: request.name,
|
|
113
|
-
provider: request.provider,
|
|
114
|
-
type: request.type,
|
|
115
|
-
status: "PENDING" /* PENDING */,
|
|
116
|
-
profileKey: request.profileKey,
|
|
117
|
-
senderNumbers: [],
|
|
118
|
-
metadata: {
|
|
119
|
-
businessInfo: request.businessInfo,
|
|
120
|
-
kakaoInfo: request.kakaoInfo,
|
|
121
|
-
limits: {
|
|
122
|
-
dailyMessageLimit: 1e4,
|
|
123
|
-
monthlyMessageLimit: 3e5,
|
|
124
|
-
rateLimit: 10
|
|
125
|
-
// 10 messages per second
|
|
126
|
-
},
|
|
127
|
-
features: {
|
|
128
|
-
supportsBulkSending: true,
|
|
129
|
-
supportsScheduling: true,
|
|
130
|
-
supportsButtons: true,
|
|
131
|
-
maxButtonCount: 5
|
|
132
|
-
}
|
|
133
|
-
},
|
|
134
|
-
verification: {
|
|
135
|
-
status: request.businessInfo ? "PENDING" /* PENDING */ : "NOT_REQUIRED" /* NOT_REQUIRED */,
|
|
136
|
-
documents: []
|
|
137
|
-
},
|
|
138
|
-
createdAt: /* @__PURE__ */ new Date(),
|
|
139
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
140
|
-
};
|
|
141
|
-
this.channels.set(channelId, channel);
|
|
142
|
-
if (request.businessInfo) {
|
|
143
|
-
await this.initiateBusinessVerification(channel);
|
|
144
|
-
}
|
|
145
|
-
return channel;
|
|
146
|
-
}
|
|
147
|
-
validateKakaoChannelRequest(request) {
|
|
148
|
-
if (request.type !== "KAKAO_ALIMTALK" /* KAKAO_ALIMTALK */ && request.type !== "KAKAO_FRIENDTALK" /* KAKAO_FRIENDTALK */) {
|
|
149
|
-
throw new Error("Invalid channel type for Kakao channel");
|
|
150
|
-
}
|
|
151
|
-
if (!request.kakaoInfo?.plusFriendId) {
|
|
152
|
-
throw new Error("Plus Friend ID is required for Kakao channels");
|
|
153
|
-
}
|
|
154
|
-
if (!request.kakaoInfo?.brandName) {
|
|
155
|
-
throw new Error("Brand name is required for Kakao channels");
|
|
156
|
-
}
|
|
157
|
-
if (!this.isValidPlusFriendId(request.kakaoInfo.plusFriendId)) {
|
|
158
|
-
throw new Error("Invalid Plus Friend ID format");
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
isValidPlusFriendId(plusFriendId) {
|
|
162
|
-
const regex = /^@[a-zA-Z0-9_-]{3,30}$/;
|
|
163
|
-
return regex.test(plusFriendId);
|
|
164
|
-
}
|
|
165
|
-
async initiateBusinessVerification(channel) {
|
|
166
|
-
channel.verification.status = "UNDER_REVIEW" /* UNDER_REVIEW */;
|
|
167
|
-
channel.status = "VERIFYING" /* VERIFYING */;
|
|
168
|
-
channel.updatedAt = /* @__PURE__ */ new Date();
|
|
169
|
-
setTimeout(() => {
|
|
170
|
-
this.completeVerification(channel.id, true);
|
|
171
|
-
}, 5e3);
|
|
172
|
-
}
|
|
173
|
-
async completeVerification(channelId, approved, rejectionReason) {
|
|
174
|
-
const channel = this.channels.get(channelId);
|
|
175
|
-
if (!channel) {
|
|
176
|
-
throw new Error("Channel not found");
|
|
177
|
-
}
|
|
178
|
-
if (approved) {
|
|
179
|
-
channel.verification.status = "VERIFIED" /* VERIFIED */;
|
|
180
|
-
channel.verification.verifiedAt = /* @__PURE__ */ new Date();
|
|
181
|
-
channel.status = "ACTIVE" /* ACTIVE */;
|
|
182
|
-
} else {
|
|
183
|
-
channel.verification.status = "REJECTED" /* REJECTED */;
|
|
184
|
-
channel.verification.rejectedAt = /* @__PURE__ */ new Date();
|
|
185
|
-
channel.verification.rejectionReason = rejectionReason || "Verification failed";
|
|
186
|
-
channel.status = "SUSPENDED" /* SUSPENDED */;
|
|
187
|
-
}
|
|
188
|
-
channel.updatedAt = /* @__PURE__ */ new Date();
|
|
189
|
-
}
|
|
190
|
-
async getChannel(channelId) {
|
|
191
|
-
return this.channels.get(channelId) || null;
|
|
192
|
-
}
|
|
193
|
-
async updateChannel(channelId, updates) {
|
|
194
|
-
const channel = this.channels.get(channelId);
|
|
195
|
-
if (!channel) {
|
|
196
|
-
throw new Error("Channel not found");
|
|
197
|
-
}
|
|
198
|
-
if (updates.metadata?.kakaoInfo?.plusFriendId && !this.isValidPlusFriendId(updates.metadata.kakaoInfo.plusFriendId)) {
|
|
199
|
-
throw new Error("Invalid Plus Friend ID format");
|
|
200
|
-
}
|
|
201
|
-
Object.assign(channel, updates, { updatedAt: /* @__PURE__ */ new Date() });
|
|
202
|
-
return channel;
|
|
203
|
-
}
|
|
204
|
-
async deleteChannel(channelId) {
|
|
205
|
-
const channel = this.channels.get(channelId);
|
|
206
|
-
if (!channel) {
|
|
207
|
-
return false;
|
|
208
|
-
}
|
|
209
|
-
channel.status = "DELETED" /* DELETED */;
|
|
210
|
-
channel.updatedAt = /* @__PURE__ */ new Date();
|
|
211
|
-
return true;
|
|
212
|
-
}
|
|
213
|
-
async listChannels(filters) {
|
|
214
|
-
let channels = Array.from(this.channels.values());
|
|
215
|
-
if (filters) {
|
|
216
|
-
if (filters.status) {
|
|
217
|
-
channels = channels.filter((c) => c.status === filters.status);
|
|
218
|
-
}
|
|
219
|
-
if (filters.type) {
|
|
220
|
-
channels = channels.filter((c) => c.type === filters.type);
|
|
221
|
-
}
|
|
222
|
-
if (filters.verified !== void 0) {
|
|
223
|
-
const verifiedStatus = filters.verified ? "VERIFIED" /* VERIFIED */ : "PENDING" /* PENDING */;
|
|
224
|
-
channels = channels.filter((c) => c.verification.status === verifiedStatus);
|
|
225
|
-
}
|
|
226
|
-
}
|
|
227
|
-
return channels.filter((c) => c.status !== "DELETED" /* DELETED */);
|
|
228
|
-
}
|
|
229
|
-
async suspendChannel(channelId, reason) {
|
|
230
|
-
const channel = this.channels.get(channelId);
|
|
231
|
-
if (!channel) {
|
|
232
|
-
throw new Error("Channel not found");
|
|
233
|
-
}
|
|
234
|
-
channel.status = "SUSPENDED" /* SUSPENDED */;
|
|
235
|
-
channel.updatedAt = /* @__PURE__ */ new Date();
|
|
236
|
-
console.log(`Channel ${channelId} suspended: ${reason}`);
|
|
237
|
-
}
|
|
238
|
-
async reactivateChannel(channelId) {
|
|
239
|
-
const channel = this.channels.get(channelId);
|
|
240
|
-
if (!channel) {
|
|
241
|
-
throw new Error("Channel not found");
|
|
242
|
-
}
|
|
243
|
-
if (channel.verification.status !== "VERIFIED" /* VERIFIED */) {
|
|
244
|
-
throw new Error("Channel must be verified before reactivation");
|
|
245
|
-
}
|
|
246
|
-
channel.status = "ACTIVE" /* ACTIVE */;
|
|
247
|
-
channel.updatedAt = /* @__PURE__ */ new Date();
|
|
248
|
-
}
|
|
249
|
-
async checkChannelHealth(channelId) {
|
|
250
|
-
const channel = this.channels.get(channelId);
|
|
251
|
-
if (!channel) {
|
|
252
|
-
throw new Error("Channel not found");
|
|
253
|
-
}
|
|
254
|
-
const issues = [];
|
|
255
|
-
const recommendations = [];
|
|
256
|
-
if (channel.status !== "ACTIVE" /* ACTIVE */) {
|
|
257
|
-
issues.push(`Channel status is ${channel.status}`);
|
|
258
|
-
}
|
|
259
|
-
if (channel.verification.status !== "VERIFIED" /* VERIFIED */ && channel.verification.status !== "NOT_REQUIRED" /* NOT_REQUIRED */) {
|
|
260
|
-
issues.push(`Channel verification is ${channel.verification.status}`);
|
|
261
|
-
}
|
|
262
|
-
if (channel.senderNumbers.length === 0) {
|
|
263
|
-
recommendations.push("Add at least one verified sender number");
|
|
264
|
-
}
|
|
265
|
-
if (!channel.metadata.businessInfo) {
|
|
266
|
-
recommendations.push("Complete business information for better deliverability");
|
|
267
|
-
}
|
|
268
|
-
return {
|
|
269
|
-
isHealthy: issues.length === 0,
|
|
270
|
-
issues,
|
|
271
|
-
recommendations
|
|
272
|
-
};
|
|
273
|
-
}
|
|
274
|
-
generateChannelId() {
|
|
275
|
-
return `kakao_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
|
|
276
|
-
}
|
|
277
|
-
};
|
|
278
|
-
|
|
279
|
-
// src/kakao/sender-number.ts
|
|
280
|
-
var KakaoSenderNumberManager = class {
|
|
281
|
-
constructor() {
|
|
282
|
-
this.senderNumbers = /* @__PURE__ */ new Map();
|
|
283
|
-
this.verificationCodes = /* @__PURE__ */ new Map();
|
|
284
|
-
}
|
|
285
|
-
async addSenderNumber(channelId, request) {
|
|
286
|
-
this.validatePhoneNumber(request.phoneNumber);
|
|
287
|
-
const existingNumber = this.findSenderNumberByPhone(request.phoneNumber);
|
|
288
|
-
if (existingNumber) {
|
|
289
|
-
throw new Error("Phone number is already registered");
|
|
290
|
-
}
|
|
291
|
-
const senderNumberId = this.generateSenderNumberId();
|
|
292
|
-
const senderNumber = {
|
|
293
|
-
id: senderNumberId,
|
|
294
|
-
phoneNumber: request.phoneNumber,
|
|
295
|
-
status: "PENDING" /* PENDING */,
|
|
296
|
-
category: request.category,
|
|
297
|
-
metadata: {
|
|
298
|
-
businessName: request.businessInfo?.businessName,
|
|
299
|
-
businessRegistrationNumber: request.businessInfo?.businessRegistrationNumber,
|
|
300
|
-
contactPerson: request.businessInfo?.contactPerson,
|
|
301
|
-
contactEmail: request.businessInfo?.contactEmail
|
|
302
|
-
},
|
|
303
|
-
createdAt: /* @__PURE__ */ new Date(),
|
|
304
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
305
|
-
};
|
|
306
|
-
this.senderNumbers.set(senderNumberId, senderNumber);
|
|
307
|
-
await this.initiateVerification(senderNumber);
|
|
308
|
-
return senderNumber;
|
|
309
|
-
}
|
|
310
|
-
validatePhoneNumber(phoneNumber) {
|
|
311
|
-
const regex = /^(010|011|016|017|018|019)[0-9]{7,8}$/;
|
|
312
|
-
if (!regex.test(phoneNumber)) {
|
|
313
|
-
throw new Error("Invalid Korean phone number format");
|
|
314
|
-
}
|
|
315
|
-
}
|
|
316
|
-
findSenderNumberByPhone(phoneNumber) {
|
|
317
|
-
return Array.from(this.senderNumbers.values()).find((sn) => sn.phoneNumber === phoneNumber);
|
|
318
|
-
}
|
|
319
|
-
async initiateVerification(senderNumber) {
|
|
320
|
-
const verificationCode = this.generateVerificationCode();
|
|
321
|
-
const expiresAt = new Date(Date.now() + 5 * 60 * 1e3);
|
|
322
|
-
this.verificationCodes.set(senderNumber.id, {
|
|
323
|
-
code: verificationCode,
|
|
324
|
-
expiresAt
|
|
325
|
-
});
|
|
326
|
-
senderNumber.status = "VERIFYING" /* VERIFYING */;
|
|
327
|
-
senderNumber.verificationCode = verificationCode;
|
|
328
|
-
senderNumber.updatedAt = /* @__PURE__ */ new Date();
|
|
329
|
-
console.log(`Verification code for ${senderNumber.phoneNumber}: ${verificationCode}`);
|
|
330
|
-
await this.sendVerificationSMS(senderNumber.phoneNumber, verificationCode);
|
|
331
|
-
}
|
|
332
|
-
async sendVerificationSMS(phoneNumber, code) {
|
|
333
|
-
console.log(`Sending SMS to ${phoneNumber}: Your verification code is ${code}`);
|
|
334
|
-
}
|
|
335
|
-
async verifySenderNumber(senderNumberId, code) {
|
|
336
|
-
const senderNumber = this.senderNumbers.get(senderNumberId);
|
|
337
|
-
if (!senderNumber) {
|
|
338
|
-
throw new Error("Sender number not found");
|
|
339
|
-
}
|
|
340
|
-
const verification = this.verificationCodes.get(senderNumberId);
|
|
341
|
-
if (!verification) {
|
|
342
|
-
throw new Error("No verification code found");
|
|
343
|
-
}
|
|
344
|
-
if (/* @__PURE__ */ new Date() > verification.expiresAt) {
|
|
345
|
-
throw new Error("Verification code has expired");
|
|
346
|
-
}
|
|
347
|
-
if (verification.code !== code) {
|
|
348
|
-
return false;
|
|
349
|
-
}
|
|
350
|
-
senderNumber.status = "VERIFIED" /* VERIFIED */;
|
|
351
|
-
senderNumber.verifiedAt = /* @__PURE__ */ new Date();
|
|
352
|
-
senderNumber.updatedAt = /* @__PURE__ */ new Date();
|
|
353
|
-
delete senderNumber.verificationCode;
|
|
354
|
-
this.verificationCodes.delete(senderNumberId);
|
|
355
|
-
return true;
|
|
356
|
-
}
|
|
357
|
-
async resendVerificationCode(senderNumberId) {
|
|
358
|
-
const senderNumber = this.senderNumbers.get(senderNumberId);
|
|
359
|
-
if (!senderNumber) {
|
|
360
|
-
throw new Error("Sender number not found");
|
|
361
|
-
}
|
|
362
|
-
if (senderNumber.status !== "VERIFYING" /* VERIFYING */) {
|
|
363
|
-
throw new Error("Sender number is not in verifying status");
|
|
364
|
-
}
|
|
365
|
-
const lastVerification = this.verificationCodes.get(senderNumberId);
|
|
366
|
-
if (lastVerification) {
|
|
367
|
-
const timeSinceLastCode = Date.now() - (lastVerification.expiresAt.getTime() - 5 * 60 * 1e3);
|
|
368
|
-
if (timeSinceLastCode < 60 * 1e3) {
|
|
369
|
-
throw new Error("Please wait before requesting a new verification code");
|
|
370
|
-
}
|
|
371
|
-
}
|
|
372
|
-
await this.initiateVerification(senderNumber);
|
|
373
|
-
}
|
|
374
|
-
async getSenderNumber(senderNumberId) {
|
|
375
|
-
return this.senderNumbers.get(senderNumberId) || null;
|
|
376
|
-
}
|
|
377
|
-
async listSenderNumbers(filters) {
|
|
378
|
-
let senderNumbers = Array.from(this.senderNumbers.values());
|
|
379
|
-
if (filters) {
|
|
380
|
-
if (filters.status) {
|
|
381
|
-
senderNumbers = senderNumbers.filter((sn) => sn.status === filters.status);
|
|
382
|
-
}
|
|
383
|
-
if (filters.category) {
|
|
384
|
-
senderNumbers = senderNumbers.filter((sn) => sn.category === filters.category);
|
|
385
|
-
}
|
|
386
|
-
if (filters.verified !== void 0) {
|
|
387
|
-
if (filters.verified) {
|
|
388
|
-
senderNumbers = senderNumbers.filter((sn) => sn.status === "VERIFIED" /* VERIFIED */);
|
|
389
|
-
} else {
|
|
390
|
-
senderNumbers = senderNumbers.filter((sn) => sn.status !== "VERIFIED" /* VERIFIED */);
|
|
391
|
-
}
|
|
392
|
-
}
|
|
393
|
-
}
|
|
394
|
-
return senderNumbers;
|
|
395
|
-
}
|
|
396
|
-
async updateSenderNumber(senderNumberId, updates) {
|
|
397
|
-
const senderNumber = this.senderNumbers.get(senderNumberId);
|
|
398
|
-
if (!senderNumber) {
|
|
399
|
-
throw new Error("Sender number not found");
|
|
400
|
-
}
|
|
401
|
-
const allowedUpdates = { ...updates };
|
|
402
|
-
delete allowedUpdates.id;
|
|
403
|
-
delete allowedUpdates.phoneNumber;
|
|
404
|
-
delete allowedUpdates.verifiedAt;
|
|
405
|
-
delete allowedUpdates.createdAt;
|
|
406
|
-
Object.assign(senderNumber, allowedUpdates, { updatedAt: /* @__PURE__ */ new Date() });
|
|
407
|
-
return senderNumber;
|
|
408
|
-
}
|
|
409
|
-
async deleteSenderNumber(senderNumberId) {
|
|
410
|
-
const senderNumber = this.senderNumbers.get(senderNumberId);
|
|
411
|
-
if (!senderNumber) {
|
|
412
|
-
return false;
|
|
413
|
-
}
|
|
414
|
-
if (await this.isSenderNumberInUse(senderNumberId)) {
|
|
415
|
-
throw new Error("Cannot delete sender number that is currently in use");
|
|
416
|
-
}
|
|
417
|
-
this.senderNumbers.delete(senderNumberId);
|
|
418
|
-
this.verificationCodes.delete(senderNumberId);
|
|
419
|
-
return true;
|
|
420
|
-
}
|
|
421
|
-
async isSenderNumberInUse(senderNumberId) {
|
|
422
|
-
return false;
|
|
423
|
-
}
|
|
424
|
-
async blockSenderNumber(senderNumberId, reason) {
|
|
425
|
-
const senderNumber = this.senderNumbers.get(senderNumberId);
|
|
426
|
-
if (!senderNumber) {
|
|
427
|
-
throw new Error("Sender number not found");
|
|
428
|
-
}
|
|
429
|
-
senderNumber.status = "BLOCKED" /* BLOCKED */;
|
|
430
|
-
senderNumber.updatedAt = /* @__PURE__ */ new Date();
|
|
431
|
-
console.log(`Sender number ${senderNumberId} blocked: ${reason}`);
|
|
432
|
-
}
|
|
433
|
-
async unblockSenderNumber(senderNumberId) {
|
|
434
|
-
const senderNumber = this.senderNumbers.get(senderNumberId);
|
|
435
|
-
if (!senderNumber) {
|
|
436
|
-
throw new Error("Sender number not found");
|
|
437
|
-
}
|
|
438
|
-
if (senderNumber.status !== "BLOCKED" /* BLOCKED */) {
|
|
439
|
-
throw new Error("Sender number is not blocked");
|
|
440
|
-
}
|
|
441
|
-
senderNumber.status = senderNumber.verifiedAt ? "VERIFIED" /* VERIFIED */ : "PENDING" /* PENDING */;
|
|
442
|
-
senderNumber.updatedAt = /* @__PURE__ */ new Date();
|
|
443
|
-
}
|
|
444
|
-
async validateSenderNumberForSending(senderNumberId) {
|
|
445
|
-
const senderNumber = this.senderNumbers.get(senderNumberId);
|
|
446
|
-
const errors = [];
|
|
447
|
-
if (!senderNumber) {
|
|
448
|
-
errors.push("Sender number not found");
|
|
449
|
-
return { isValid: false, errors };
|
|
450
|
-
}
|
|
451
|
-
if (senderNumber.status !== "VERIFIED" /* VERIFIED */) {
|
|
452
|
-
errors.push(`Sender number status is ${senderNumber.status}, must be verified`);
|
|
453
|
-
}
|
|
454
|
-
if (!senderNumber.verifiedAt) {
|
|
455
|
-
errors.push("Sender number has not been verified");
|
|
456
|
-
}
|
|
457
|
-
if (senderNumber.verifiedAt) {
|
|
458
|
-
const oneYearAgo = new Date(Date.now() - 365 * 24 * 60 * 60 * 1e3);
|
|
459
|
-
if (senderNumber.verifiedAt < oneYearAgo) {
|
|
460
|
-
errors.push("Sender number verification has expired");
|
|
461
|
-
}
|
|
462
|
-
}
|
|
463
|
-
return {
|
|
464
|
-
isValid: errors.length === 0,
|
|
465
|
-
errors
|
|
466
|
-
};
|
|
467
|
-
}
|
|
468
|
-
generateSenderNumberId() {
|
|
469
|
-
return `sn_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
|
|
470
|
-
}
|
|
471
|
-
generateVerificationCode() {
|
|
472
|
-
return Math.floor(1e5 + Math.random() * 9e5).toString();
|
|
473
|
-
}
|
|
474
|
-
// Cleanup expired verification codes
|
|
475
|
-
cleanup() {
|
|
476
|
-
const now = /* @__PURE__ */ new Date();
|
|
477
|
-
for (const [id, verification] of this.verificationCodes) {
|
|
478
|
-
if (now > verification.expiresAt) {
|
|
479
|
-
this.verificationCodes.delete(id);
|
|
480
|
-
const senderNumber = this.senderNumbers.get(id);
|
|
481
|
-
if (senderNumber && senderNumber.status === "VERIFYING" /* VERIFYING */) {
|
|
482
|
-
senderNumber.status = "PENDING" /* PENDING */;
|
|
483
|
-
delete senderNumber.verificationCode;
|
|
484
|
-
senderNumber.updatedAt = /* @__PURE__ */ new Date();
|
|
485
|
-
}
|
|
486
|
-
}
|
|
487
|
-
}
|
|
488
|
-
}
|
|
489
|
-
};
|
|
490
|
-
|
|
491
|
-
// src/management/crud.ts
|
|
492
|
-
import { EventEmitter } from "events";
|
|
493
|
-
var ChannelCRUD = class extends EventEmitter {
|
|
494
|
-
constructor(options = {}) {
|
|
495
|
-
super();
|
|
496
|
-
this.options = options;
|
|
497
|
-
this.channels = /* @__PURE__ */ new Map();
|
|
498
|
-
this.senderNumbers = /* @__PURE__ */ new Map();
|
|
499
|
-
this.auditLogs = [];
|
|
500
|
-
this.defaultOptions = {
|
|
501
|
-
enableAuditLog: true,
|
|
502
|
-
enableEventEmission: true,
|
|
503
|
-
defaultPageSize: 20,
|
|
504
|
-
maxPageSize: 100,
|
|
505
|
-
enableSoftDelete: true,
|
|
506
|
-
autoCleanup: true,
|
|
507
|
-
cleanupInterval: 36e5
|
|
508
|
-
// 1 hour
|
|
509
|
-
};
|
|
510
|
-
this.options = { ...this.defaultOptions, ...options };
|
|
511
|
-
if (this.options.autoCleanup) {
|
|
512
|
-
this.startAutoCleanup();
|
|
513
|
-
}
|
|
514
|
-
}
|
|
515
|
-
// Channel CRUD Operations
|
|
516
|
-
async createChannel(request, userId) {
|
|
517
|
-
const channelId = this.generateChannelId();
|
|
518
|
-
const channel = {
|
|
519
|
-
id: channelId,
|
|
520
|
-
name: request.name,
|
|
521
|
-
provider: request.provider,
|
|
522
|
-
type: request.type,
|
|
523
|
-
status: "PENDING" /* PENDING */,
|
|
524
|
-
profileKey: request.profileKey,
|
|
525
|
-
senderNumbers: [],
|
|
526
|
-
metadata: {
|
|
527
|
-
businessInfo: request.businessInfo,
|
|
528
|
-
kakaoInfo: request.kakaoInfo,
|
|
529
|
-
limits: this.getDefaultLimits(request.type),
|
|
530
|
-
features: this.getDefaultFeatures(request.type)
|
|
531
|
-
},
|
|
532
|
-
verification: {
|
|
533
|
-
status: request.businessInfo ? "PENDING" /* PENDING */ : "NOT_REQUIRED" /* NOT_REQUIRED */,
|
|
534
|
-
documents: []
|
|
535
|
-
},
|
|
536
|
-
createdAt: /* @__PURE__ */ new Date(),
|
|
537
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
538
|
-
};
|
|
539
|
-
this.channels.set(channelId, channel);
|
|
540
|
-
if (this.options.enableAuditLog) {
|
|
541
|
-
this.addAuditLog("channel", channelId, "create", userId, void 0, channel);
|
|
542
|
-
}
|
|
543
|
-
if (this.options.enableEventEmission) {
|
|
544
|
-
this.emit("channel:created", { channel, userId });
|
|
545
|
-
}
|
|
546
|
-
return channel;
|
|
547
|
-
}
|
|
548
|
-
async getChannel(channelId, userId) {
|
|
549
|
-
const channel = this.channels.get(channelId);
|
|
550
|
-
if (channel && this.options.enableAuditLog) {
|
|
551
|
-
this.addAuditLog("channel", channelId, "read", userId);
|
|
552
|
-
}
|
|
553
|
-
return channel || null;
|
|
554
|
-
}
|
|
555
|
-
async updateChannel(channelId, updates, userId) {
|
|
556
|
-
const channel = this.channels.get(channelId);
|
|
557
|
-
if (!channel) {
|
|
558
|
-
throw new Error(`Channel ${channelId} not found`);
|
|
559
|
-
}
|
|
560
|
-
const before = this.options.enableAuditLog ? { ...channel } : void 0;
|
|
561
|
-
const updatedChannel = {
|
|
562
|
-
...channel,
|
|
563
|
-
...updates,
|
|
564
|
-
id: channelId,
|
|
565
|
-
// Ensure ID doesn't change
|
|
566
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
567
|
-
};
|
|
568
|
-
this.channels.set(channelId, updatedChannel);
|
|
569
|
-
if (this.options.enableAuditLog) {
|
|
570
|
-
this.addAuditLog("channel", channelId, "update", userId, before, updatedChannel);
|
|
571
|
-
}
|
|
572
|
-
if (this.options.enableEventEmission) {
|
|
573
|
-
this.emit("channel:updated", {
|
|
574
|
-
channel: updatedChannel,
|
|
575
|
-
previousChannel: channel,
|
|
576
|
-
userId
|
|
577
|
-
});
|
|
578
|
-
}
|
|
579
|
-
return updatedChannel;
|
|
580
|
-
}
|
|
581
|
-
async deleteChannel(channelId, userId) {
|
|
582
|
-
const channel = this.channels.get(channelId);
|
|
583
|
-
if (!channel) {
|
|
584
|
-
return false;
|
|
585
|
-
}
|
|
586
|
-
if (this.options.enableSoftDelete) {
|
|
587
|
-
channel.status = "DELETED" /* DELETED */;
|
|
588
|
-
channel.updatedAt = /* @__PURE__ */ new Date();
|
|
589
|
-
} else {
|
|
590
|
-
this.channels.delete(channelId);
|
|
591
|
-
for (const [id, senderNumber] of this.senderNumbers) {
|
|
592
|
-
}
|
|
593
|
-
}
|
|
594
|
-
if (this.options.enableAuditLog) {
|
|
595
|
-
this.addAuditLog("channel", channelId, "delete", userId, channel);
|
|
596
|
-
}
|
|
597
|
-
if (this.options.enableEventEmission) {
|
|
598
|
-
this.emit("channel:deleted", { channel, userId });
|
|
599
|
-
}
|
|
600
|
-
return true;
|
|
601
|
-
}
|
|
602
|
-
async listChannels(filters = {}, pagination = { page: 1, limit: this.options.defaultPageSize }) {
|
|
603
|
-
let channels = Array.from(this.channels.values());
|
|
604
|
-
if (filters.provider) {
|
|
605
|
-
channels = channels.filter((c) => c.provider === filters.provider);
|
|
606
|
-
}
|
|
607
|
-
if (filters.type) {
|
|
608
|
-
channels = channels.filter((c) => c.type === filters.type);
|
|
609
|
-
}
|
|
610
|
-
if (filters.status) {
|
|
611
|
-
channels = channels.filter((c) => c.status === filters.status);
|
|
612
|
-
}
|
|
613
|
-
if (filters.verified !== void 0) {
|
|
614
|
-
const targetStatus = filters.verified ? "VERIFIED" /* VERIFIED */ : "PENDING" /* PENDING */;
|
|
615
|
-
channels = channels.filter((c) => c.verification.status === targetStatus);
|
|
616
|
-
}
|
|
617
|
-
if (filters.createdAfter) {
|
|
618
|
-
channels = channels.filter((c) => c.createdAt >= filters.createdAfter);
|
|
619
|
-
}
|
|
620
|
-
if (filters.createdBefore) {
|
|
621
|
-
channels = channels.filter((c) => c.createdAt <= filters.createdBefore);
|
|
622
|
-
}
|
|
623
|
-
if (!filters.status || filters.status !== "DELETED" /* DELETED */) {
|
|
624
|
-
channels = channels.filter((c) => c.status !== "DELETED" /* DELETED */);
|
|
625
|
-
}
|
|
626
|
-
const sortBy = pagination.sortBy || "createdAt";
|
|
627
|
-
const sortOrder = pagination.sortOrder || "desc";
|
|
628
|
-
channels.sort((a, b) => {
|
|
629
|
-
let aValue, bValue;
|
|
630
|
-
switch (sortBy) {
|
|
631
|
-
case "name":
|
|
632
|
-
aValue = a.name;
|
|
633
|
-
bValue = b.name;
|
|
634
|
-
break;
|
|
635
|
-
case "createdAt":
|
|
636
|
-
aValue = a.createdAt.getTime();
|
|
637
|
-
bValue = b.createdAt.getTime();
|
|
638
|
-
break;
|
|
639
|
-
case "updatedAt":
|
|
640
|
-
aValue = a.updatedAt.getTime();
|
|
641
|
-
bValue = b.updatedAt.getTime();
|
|
642
|
-
break;
|
|
643
|
-
default:
|
|
644
|
-
aValue = a.createdAt.getTime();
|
|
645
|
-
bValue = b.createdAt.getTime();
|
|
646
|
-
}
|
|
647
|
-
if (sortOrder === "asc") {
|
|
648
|
-
return aValue < bValue ? -1 : aValue > bValue ? 1 : 0;
|
|
649
|
-
} else {
|
|
650
|
-
return aValue > bValue ? -1 : aValue < bValue ? 1 : 0;
|
|
651
|
-
}
|
|
652
|
-
});
|
|
653
|
-
const total = channels.length;
|
|
654
|
-
const limit = Math.min(pagination.limit, this.options.maxPageSize);
|
|
655
|
-
const page = Math.max(1, pagination.page);
|
|
656
|
-
const offset = (page - 1) * limit;
|
|
657
|
-
const paginatedChannels = channels.slice(offset, offset + limit);
|
|
658
|
-
return {
|
|
659
|
-
data: paginatedChannels,
|
|
660
|
-
total,
|
|
661
|
-
page,
|
|
662
|
-
limit,
|
|
663
|
-
totalPages: Math.ceil(total / limit),
|
|
664
|
-
hasNext: offset + limit < total,
|
|
665
|
-
hasPrev: page > 1
|
|
666
|
-
};
|
|
667
|
-
}
|
|
668
|
-
// Sender Number CRUD Operations
|
|
669
|
-
async createSenderNumber(channelId, request, userId) {
|
|
670
|
-
const channel = this.channels.get(channelId);
|
|
671
|
-
if (!channel) {
|
|
672
|
-
throw new Error(`Channel ${channelId} not found`);
|
|
673
|
-
}
|
|
674
|
-
const senderNumberId = this.generateSenderNumberId();
|
|
675
|
-
const senderNumber = {
|
|
676
|
-
id: senderNumberId,
|
|
677
|
-
phoneNumber: request.phoneNumber,
|
|
678
|
-
status: "PENDING" /* PENDING */,
|
|
679
|
-
category: request.category,
|
|
680
|
-
metadata: {
|
|
681
|
-
businessName: request.businessInfo?.businessName,
|
|
682
|
-
businessRegistrationNumber: request.businessInfo?.businessRegistrationNumber,
|
|
683
|
-
contactPerson: request.businessInfo?.contactPerson,
|
|
684
|
-
contactEmail: request.businessInfo?.contactEmail
|
|
685
|
-
},
|
|
686
|
-
createdAt: /* @__PURE__ */ new Date(),
|
|
687
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
688
|
-
};
|
|
689
|
-
this.senderNumbers.set(senderNumberId, senderNumber);
|
|
690
|
-
channel.senderNumbers.push(senderNumber);
|
|
691
|
-
channel.updatedAt = /* @__PURE__ */ new Date();
|
|
692
|
-
if (this.options.enableAuditLog) {
|
|
693
|
-
this.addAuditLog("senderNumber", senderNumberId, "create", userId, void 0, senderNumber);
|
|
694
|
-
}
|
|
695
|
-
if (this.options.enableEventEmission) {
|
|
696
|
-
this.emit("senderNumber:created", { senderNumber, channelId, userId });
|
|
697
|
-
}
|
|
698
|
-
return senderNumber;
|
|
699
|
-
}
|
|
700
|
-
async getSenderNumber(senderNumberId, userId) {
|
|
701
|
-
const senderNumber = this.senderNumbers.get(senderNumberId);
|
|
702
|
-
if (senderNumber && this.options.enableAuditLog) {
|
|
703
|
-
this.addAuditLog("senderNumber", senderNumberId, "read", userId);
|
|
704
|
-
}
|
|
705
|
-
return senderNumber || null;
|
|
706
|
-
}
|
|
707
|
-
async updateSenderNumber(senderNumberId, updates, userId) {
|
|
708
|
-
const senderNumber = this.senderNumbers.get(senderNumberId);
|
|
709
|
-
if (!senderNumber) {
|
|
710
|
-
throw new Error(`Sender number ${senderNumberId} not found`);
|
|
711
|
-
}
|
|
712
|
-
const before = this.options.enableAuditLog ? { ...senderNumber } : void 0;
|
|
713
|
-
const updatedSenderNumber = {
|
|
714
|
-
...senderNumber,
|
|
715
|
-
...updates,
|
|
716
|
-
id: senderNumberId,
|
|
717
|
-
// Ensure ID doesn't change
|
|
718
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
719
|
-
};
|
|
720
|
-
this.senderNumbers.set(senderNumberId, updatedSenderNumber);
|
|
721
|
-
for (const channel of this.channels.values()) {
|
|
722
|
-
const index = channel.senderNumbers.findIndex((sn) => sn.id === senderNumberId);
|
|
723
|
-
if (index !== -1) {
|
|
724
|
-
channel.senderNumbers[index] = updatedSenderNumber;
|
|
725
|
-
channel.updatedAt = /* @__PURE__ */ new Date();
|
|
726
|
-
break;
|
|
727
|
-
}
|
|
728
|
-
}
|
|
729
|
-
if (this.options.enableAuditLog) {
|
|
730
|
-
this.addAuditLog("senderNumber", senderNumberId, "update", userId, before, updatedSenderNumber);
|
|
731
|
-
}
|
|
732
|
-
if (this.options.enableEventEmission) {
|
|
733
|
-
this.emit("senderNumber:updated", {
|
|
734
|
-
senderNumber: updatedSenderNumber,
|
|
735
|
-
previousSenderNumber: senderNumber,
|
|
736
|
-
userId
|
|
737
|
-
});
|
|
738
|
-
}
|
|
739
|
-
return updatedSenderNumber;
|
|
740
|
-
}
|
|
741
|
-
async deleteSenderNumber(senderNumberId, userId) {
|
|
742
|
-
const senderNumber = this.senderNumbers.get(senderNumberId);
|
|
743
|
-
if (!senderNumber) {
|
|
744
|
-
return false;
|
|
745
|
-
}
|
|
746
|
-
this.senderNumbers.delete(senderNumberId);
|
|
747
|
-
for (const channel of this.channels.values()) {
|
|
748
|
-
const index = channel.senderNumbers.findIndex((sn) => sn.id === senderNumberId);
|
|
749
|
-
if (index !== -1) {
|
|
750
|
-
channel.senderNumbers.splice(index, 1);
|
|
751
|
-
channel.updatedAt = /* @__PURE__ */ new Date();
|
|
752
|
-
break;
|
|
753
|
-
}
|
|
754
|
-
}
|
|
755
|
-
if (this.options.enableAuditLog) {
|
|
756
|
-
this.addAuditLog("senderNumber", senderNumberId, "delete", userId, senderNumber);
|
|
757
|
-
}
|
|
758
|
-
if (this.options.enableEventEmission) {
|
|
759
|
-
this.emit("senderNumber:deleted", { senderNumber, userId });
|
|
760
|
-
}
|
|
761
|
-
return true;
|
|
762
|
-
}
|
|
763
|
-
async listSenderNumbers(filters = {}, pagination = { page: 1, limit: this.options.defaultPageSize }) {
|
|
764
|
-
let senderNumbers = Array.from(this.senderNumbers.values());
|
|
765
|
-
if (filters.channelId) {
|
|
766
|
-
const channel = this.channels.get(filters.channelId);
|
|
767
|
-
if (channel) {
|
|
768
|
-
senderNumbers = channel.senderNumbers;
|
|
769
|
-
} else {
|
|
770
|
-
senderNumbers = [];
|
|
771
|
-
}
|
|
772
|
-
}
|
|
773
|
-
if (filters.status) {
|
|
774
|
-
senderNumbers = senderNumbers.filter((sn) => sn.status === filters.status);
|
|
775
|
-
}
|
|
776
|
-
if (filters.category) {
|
|
777
|
-
senderNumbers = senderNumbers.filter((sn) => sn.category === filters.category);
|
|
778
|
-
}
|
|
779
|
-
if (filters.verified !== void 0) {
|
|
780
|
-
if (filters.verified) {
|
|
781
|
-
senderNumbers = senderNumbers.filter((sn) => sn.status === "VERIFIED" /* VERIFIED */);
|
|
782
|
-
} else {
|
|
783
|
-
senderNumbers = senderNumbers.filter((sn) => sn.status !== "VERIFIED" /* VERIFIED */);
|
|
784
|
-
}
|
|
785
|
-
}
|
|
786
|
-
const sortBy = pagination.sortBy || "createdAt";
|
|
787
|
-
const sortOrder = pagination.sortOrder || "desc";
|
|
788
|
-
senderNumbers.sort((a, b) => {
|
|
789
|
-
let aValue, bValue;
|
|
790
|
-
switch (sortBy) {
|
|
791
|
-
case "phoneNumber":
|
|
792
|
-
aValue = a.phoneNumber;
|
|
793
|
-
bValue = b.phoneNumber;
|
|
794
|
-
break;
|
|
795
|
-
case "createdAt":
|
|
796
|
-
aValue = a.createdAt.getTime();
|
|
797
|
-
bValue = b.createdAt.getTime();
|
|
798
|
-
break;
|
|
799
|
-
case "updatedAt":
|
|
800
|
-
aValue = a.updatedAt.getTime();
|
|
801
|
-
bValue = b.updatedAt.getTime();
|
|
802
|
-
break;
|
|
803
|
-
default:
|
|
804
|
-
aValue = a.createdAt.getTime();
|
|
805
|
-
bValue = b.createdAt.getTime();
|
|
806
|
-
}
|
|
807
|
-
if (sortOrder === "asc") {
|
|
808
|
-
return aValue < bValue ? -1 : aValue > bValue ? 1 : 0;
|
|
809
|
-
} else {
|
|
810
|
-
return aValue > bValue ? -1 : aValue < bValue ? 1 : 0;
|
|
811
|
-
}
|
|
812
|
-
});
|
|
813
|
-
const total = senderNumbers.length;
|
|
814
|
-
const limit = Math.min(pagination.limit, this.options.maxPageSize);
|
|
815
|
-
const page = Math.max(1, pagination.page);
|
|
816
|
-
const offset = (page - 1) * limit;
|
|
817
|
-
const paginatedSenderNumbers = senderNumbers.slice(offset, offset + limit);
|
|
818
|
-
return {
|
|
819
|
-
data: paginatedSenderNumbers,
|
|
820
|
-
total,
|
|
821
|
-
page,
|
|
822
|
-
limit,
|
|
823
|
-
totalPages: Math.ceil(total / limit),
|
|
824
|
-
hasNext: offset + limit < total,
|
|
825
|
-
hasPrev: page > 1
|
|
826
|
-
};
|
|
827
|
-
}
|
|
828
|
-
// Audit and Analytics
|
|
829
|
-
getAuditLogs(entityType, entityId, limit = 100) {
|
|
830
|
-
let logs = [...this.auditLogs];
|
|
831
|
-
if (entityType) {
|
|
832
|
-
logs = logs.filter((log) => log.entityType === entityType);
|
|
833
|
-
}
|
|
834
|
-
if (entityId) {
|
|
835
|
-
logs = logs.filter((log) => log.entityId === entityId);
|
|
836
|
-
}
|
|
837
|
-
return logs.sort((a, b) => b.timestamp.getTime() - a.timestamp.getTime()).slice(0, limit);
|
|
838
|
-
}
|
|
839
|
-
getStatistics() {
|
|
840
|
-
const channels = Array.from(this.channels.values());
|
|
841
|
-
const senderNumbers = Array.from(this.senderNumbers.values());
|
|
842
|
-
const channelsByStatus = {};
|
|
843
|
-
const channelsByType = {};
|
|
844
|
-
const channelsByProvider = {};
|
|
845
|
-
channels.forEach((channel) => {
|
|
846
|
-
channelsByStatus[channel.status] = (channelsByStatus[channel.status] || 0) + 1;
|
|
847
|
-
channelsByType[channel.type] = (channelsByType[channel.type] || 0) + 1;
|
|
848
|
-
channelsByProvider[channel.provider] = (channelsByProvider[channel.provider] || 0) + 1;
|
|
849
|
-
});
|
|
850
|
-
const senderNumbersByStatus = {};
|
|
851
|
-
const senderNumbersByCategory = {};
|
|
852
|
-
senderNumbers.forEach((senderNumber) => {
|
|
853
|
-
senderNumbersByStatus[senderNumber.status] = (senderNumbersByStatus[senderNumber.status] || 0) + 1;
|
|
854
|
-
senderNumbersByCategory[senderNumber.category] = (senderNumbersByCategory[senderNumber.category] || 0) + 1;
|
|
855
|
-
});
|
|
856
|
-
return {
|
|
857
|
-
channels: {
|
|
858
|
-
total: channels.length,
|
|
859
|
-
byStatus: channelsByStatus,
|
|
860
|
-
byType: channelsByType,
|
|
861
|
-
byProvider: channelsByProvider
|
|
862
|
-
},
|
|
863
|
-
senderNumbers: {
|
|
864
|
-
total: senderNumbers.length,
|
|
865
|
-
byStatus: senderNumbersByStatus,
|
|
866
|
-
byCategory: senderNumbersByCategory
|
|
867
|
-
}
|
|
868
|
-
};
|
|
869
|
-
}
|
|
870
|
-
// Cleanup and Maintenance
|
|
871
|
-
cleanup() {
|
|
872
|
-
let deletedChannels = 0;
|
|
873
|
-
let expiredAuditLogs = 0;
|
|
874
|
-
const thirtyDaysAgo = new Date(Date.now() - 30 * 24 * 60 * 60 * 1e3);
|
|
875
|
-
for (const [id, channel] of this.channels) {
|
|
876
|
-
if (channel.status === "DELETED" /* DELETED */ && channel.updatedAt < thirtyDaysAgo) {
|
|
877
|
-
this.channels.delete(id);
|
|
878
|
-
deletedChannels++;
|
|
879
|
-
}
|
|
880
|
-
}
|
|
881
|
-
const ninetyDaysAgo = new Date(Date.now() - 90 * 24 * 60 * 60 * 1e3);
|
|
882
|
-
const originalLogCount = this.auditLogs.length;
|
|
883
|
-
this.auditLogs = this.auditLogs.filter((log) => log.timestamp >= ninetyDaysAgo);
|
|
884
|
-
expiredAuditLogs = originalLogCount - this.auditLogs.length;
|
|
885
|
-
return { deletedChannels, expiredAuditLogs };
|
|
886
|
-
}
|
|
887
|
-
destroy() {
|
|
888
|
-
if (this.cleanupTimer) {
|
|
889
|
-
clearInterval(this.cleanupTimer);
|
|
890
|
-
this.cleanupTimer = void 0;
|
|
891
|
-
}
|
|
892
|
-
this.removeAllListeners();
|
|
893
|
-
this.channels.clear();
|
|
894
|
-
this.senderNumbers.clear();
|
|
895
|
-
this.auditLogs = [];
|
|
896
|
-
}
|
|
897
|
-
addAuditLog(entityType, entityId, action, userId, before, after) {
|
|
898
|
-
const auditLog = {
|
|
899
|
-
id: this.generateAuditLogId(),
|
|
900
|
-
entityType,
|
|
901
|
-
entityId,
|
|
902
|
-
action,
|
|
903
|
-
userId,
|
|
904
|
-
timestamp: /* @__PURE__ */ new Date(),
|
|
905
|
-
changes: before || after ? { before, after } : void 0
|
|
906
|
-
};
|
|
907
|
-
this.auditLogs.push(auditLog);
|
|
908
|
-
if (this.auditLogs.length > 1e4) {
|
|
909
|
-
this.auditLogs = this.auditLogs.slice(-1e4);
|
|
910
|
-
}
|
|
911
|
-
}
|
|
912
|
-
getDefaultLimits(channelType) {
|
|
913
|
-
switch (channelType) {
|
|
914
|
-
case "KAKAO_ALIMTALK" /* KAKAO_ALIMTALK */:
|
|
915
|
-
return {
|
|
916
|
-
dailyMessageLimit: 1e4,
|
|
917
|
-
monthlyMessageLimit: 3e5,
|
|
918
|
-
rateLimit: 10
|
|
919
|
-
};
|
|
920
|
-
case "KAKAO_FRIENDTALK" /* KAKAO_FRIENDTALK */:
|
|
921
|
-
return {
|
|
922
|
-
dailyMessageLimit: 1e3,
|
|
923
|
-
monthlyMessageLimit: 3e4,
|
|
924
|
-
rateLimit: 5
|
|
925
|
-
};
|
|
926
|
-
case "SMS" /* SMS */:
|
|
927
|
-
case "LMS" /* LMS */:
|
|
928
|
-
case "MMS" /* MMS */:
|
|
929
|
-
return {
|
|
930
|
-
dailyMessageLimit: 1e3,
|
|
931
|
-
monthlyMessageLimit: 3e4,
|
|
932
|
-
rateLimit: 3
|
|
933
|
-
};
|
|
934
|
-
default:
|
|
935
|
-
return {
|
|
936
|
-
dailyMessageLimit: 1e3,
|
|
937
|
-
monthlyMessageLimit: 3e4,
|
|
938
|
-
rateLimit: 1
|
|
939
|
-
};
|
|
940
|
-
}
|
|
941
|
-
}
|
|
942
|
-
getDefaultFeatures(channelType) {
|
|
943
|
-
switch (channelType) {
|
|
944
|
-
case "KAKAO_ALIMTALK" /* KAKAO_ALIMTALK */:
|
|
945
|
-
return {
|
|
946
|
-
supportsBulkSending: true,
|
|
947
|
-
supportsScheduling: true,
|
|
948
|
-
supportsButtons: true,
|
|
949
|
-
maxButtonCount: 5
|
|
950
|
-
};
|
|
951
|
-
case "KAKAO_FRIENDTALK" /* KAKAO_FRIENDTALK */:
|
|
952
|
-
return {
|
|
953
|
-
supportsBulkSending: true,
|
|
954
|
-
supportsScheduling: true,
|
|
955
|
-
supportsButtons: false,
|
|
956
|
-
maxButtonCount: 0
|
|
957
|
-
};
|
|
958
|
-
default:
|
|
959
|
-
return {
|
|
960
|
-
supportsBulkSending: false,
|
|
961
|
-
supportsScheduling: false,
|
|
962
|
-
supportsButtons: false,
|
|
963
|
-
maxButtonCount: 0
|
|
964
|
-
};
|
|
965
|
-
}
|
|
966
|
-
}
|
|
967
|
-
startAutoCleanup() {
|
|
968
|
-
this.cleanupTimer = setInterval(() => {
|
|
969
|
-
this.cleanup();
|
|
970
|
-
}, this.options.cleanupInterval);
|
|
971
|
-
}
|
|
972
|
-
generateChannelId() {
|
|
973
|
-
return `ch_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
|
|
974
|
-
}
|
|
975
|
-
generateSenderNumberId() {
|
|
976
|
-
return `sn_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
|
|
977
|
-
}
|
|
978
|
-
generateAuditLogId() {
|
|
979
|
-
return `audit_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
|
|
980
|
-
}
|
|
981
|
-
};
|
|
982
|
-
|
|
983
|
-
// src/management/permissions.ts
|
|
984
|
-
import { EventEmitter as EventEmitter2 } from "events";
|
|
985
|
-
var ResourceType = /* @__PURE__ */ ((ResourceType2) => {
|
|
986
|
-
ResourceType2["CHANNEL"] = "channel";
|
|
987
|
-
ResourceType2["SENDER_NUMBER"] = "senderNumber";
|
|
988
|
-
ResourceType2["TEMPLATE"] = "template";
|
|
989
|
-
ResourceType2["MESSAGE"] = "message";
|
|
990
|
-
ResourceType2["USER"] = "user";
|
|
991
|
-
ResourceType2["ROLE"] = "role";
|
|
992
|
-
ResourceType2["AUDIT_LOG"] = "auditLog";
|
|
993
|
-
ResourceType2["ANALYTICS"] = "analytics";
|
|
994
|
-
return ResourceType2;
|
|
995
|
-
})(ResourceType || {});
|
|
996
|
-
var ActionType = /* @__PURE__ */ ((ActionType2) => {
|
|
997
|
-
ActionType2["CREATE"] = "create";
|
|
998
|
-
ActionType2["READ"] = "read";
|
|
999
|
-
ActionType2["UPDATE"] = "update";
|
|
1000
|
-
ActionType2["DELETE"] = "delete";
|
|
1001
|
-
ActionType2["VERIFY"] = "verify";
|
|
1002
|
-
ActionType2["SUSPEND"] = "suspend";
|
|
1003
|
-
ActionType2["ACTIVATE"] = "activate";
|
|
1004
|
-
ActionType2["SEND"] = "send";
|
|
1005
|
-
ActionType2["MANAGE"] = "manage";
|
|
1006
|
-
return ActionType2;
|
|
1007
|
-
})(ActionType || {});
|
|
1008
|
-
var PermissionScope = /* @__PURE__ */ ((PermissionScope2) => {
|
|
1009
|
-
PermissionScope2["GLOBAL"] = "global";
|
|
1010
|
-
PermissionScope2["ORGANIZATION"] = "organization";
|
|
1011
|
-
PermissionScope2["TEAM"] = "team";
|
|
1012
|
-
PermissionScope2["PERSONAL"] = "personal";
|
|
1013
|
-
return PermissionScope2;
|
|
1014
|
-
})(PermissionScope || {});
|
|
1015
|
-
var PermissionManager = class extends EventEmitter2 {
|
|
1016
|
-
// 5 minutes
|
|
1017
|
-
constructor() {
|
|
1018
|
-
super();
|
|
1019
|
-
this.users = /* @__PURE__ */ new Map();
|
|
1020
|
-
this.roles = /* @__PURE__ */ new Map();
|
|
1021
|
-
this.userRoleCache = /* @__PURE__ */ new Map();
|
|
1022
|
-
this.permissionCache = /* @__PURE__ */ new Map();
|
|
1023
|
-
this.cacheExpiry = /* @__PURE__ */ new Map();
|
|
1024
|
-
this.CACHE_DURATION = 5 * 60 * 1e3;
|
|
1025
|
-
this.initializeSystemRoles();
|
|
1026
|
-
}
|
|
1027
|
-
// User Management
|
|
1028
|
-
async createUser(userData) {
|
|
1029
|
-
const userId = this.generateUserId();
|
|
1030
|
-
const user = {
|
|
1031
|
-
...userData,
|
|
1032
|
-
id: userId,
|
|
1033
|
-
createdAt: /* @__PURE__ */ new Date(),
|
|
1034
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
1035
|
-
};
|
|
1036
|
-
this.users.set(userId, user);
|
|
1037
|
-
this.updateUserRoleCache(userId, user.roles.map((r) => r.id));
|
|
1038
|
-
this.emit("user:created", { user });
|
|
1039
|
-
return user;
|
|
1040
|
-
}
|
|
1041
|
-
async getUser(userId) {
|
|
1042
|
-
return this.users.get(userId) || null;
|
|
1043
|
-
}
|
|
1044
|
-
async updateUser(userId, updates) {
|
|
1045
|
-
const user = this.users.get(userId);
|
|
1046
|
-
if (!user) {
|
|
1047
|
-
throw new Error("User not found");
|
|
1048
|
-
}
|
|
1049
|
-
const updatedUser = {
|
|
1050
|
-
...user,
|
|
1051
|
-
...updates,
|
|
1052
|
-
id: userId,
|
|
1053
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
1054
|
-
};
|
|
1055
|
-
this.users.set(userId, updatedUser);
|
|
1056
|
-
if (updates.roles) {
|
|
1057
|
-
this.updateUserRoleCache(userId, updates.roles.map((r) => r.id));
|
|
1058
|
-
}
|
|
1059
|
-
this.clearUserPermissionCache(userId);
|
|
1060
|
-
this.emit("user:updated", { user: updatedUser, previousUser: user });
|
|
1061
|
-
return updatedUser;
|
|
1062
|
-
}
|
|
1063
|
-
async deleteUser(userId) {
|
|
1064
|
-
const user = this.users.get(userId);
|
|
1065
|
-
if (!user) {
|
|
1066
|
-
return false;
|
|
1067
|
-
}
|
|
1068
|
-
this.users.delete(userId);
|
|
1069
|
-
this.userRoleCache.delete(userId);
|
|
1070
|
-
this.clearUserPermissionCache(userId);
|
|
1071
|
-
this.emit("user:deleted", { user });
|
|
1072
|
-
return true;
|
|
1073
|
-
}
|
|
1074
|
-
// Role Management
|
|
1075
|
-
async createRole(roleData) {
|
|
1076
|
-
const roleId = this.generateRoleId();
|
|
1077
|
-
const role = {
|
|
1078
|
-
...roleData,
|
|
1079
|
-
id: roleId,
|
|
1080
|
-
createdAt: /* @__PURE__ */ new Date(),
|
|
1081
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
1082
|
-
};
|
|
1083
|
-
this.roles.set(roleId, role);
|
|
1084
|
-
this.emit("role:created", { role });
|
|
1085
|
-
return role;
|
|
1086
|
-
}
|
|
1087
|
-
async getRole(roleId) {
|
|
1088
|
-
return this.roles.get(roleId) || null;
|
|
1089
|
-
}
|
|
1090
|
-
async updateRole(roleId, updates) {
|
|
1091
|
-
const role = this.roles.get(roleId);
|
|
1092
|
-
if (!role) {
|
|
1093
|
-
throw new Error("Role not found");
|
|
1094
|
-
}
|
|
1095
|
-
if (role.isSystem && updates.permissions) {
|
|
1096
|
-
throw new Error("Cannot modify permissions of system roles");
|
|
1097
|
-
}
|
|
1098
|
-
const updatedRole = {
|
|
1099
|
-
...role,
|
|
1100
|
-
...updates,
|
|
1101
|
-
id: roleId,
|
|
1102
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
1103
|
-
};
|
|
1104
|
-
this.roles.set(roleId, updatedRole);
|
|
1105
|
-
this.clearRolePermissionCache(roleId);
|
|
1106
|
-
this.emit("role:updated", { role: updatedRole, previousRole: role });
|
|
1107
|
-
return updatedRole;
|
|
1108
|
-
}
|
|
1109
|
-
async deleteRole(roleId) {
|
|
1110
|
-
const role = this.roles.get(roleId);
|
|
1111
|
-
if (!role) {
|
|
1112
|
-
return false;
|
|
1113
|
-
}
|
|
1114
|
-
if (role.isSystem) {
|
|
1115
|
-
throw new Error("Cannot delete system roles");
|
|
1116
|
-
}
|
|
1117
|
-
const usersWithRole = Array.from(this.users.values()).filter((user) => user.roles.some((r) => r.id === roleId));
|
|
1118
|
-
if (usersWithRole.length > 0) {
|
|
1119
|
-
throw new Error("Cannot delete role that is assigned to users");
|
|
1120
|
-
}
|
|
1121
|
-
this.roles.delete(roleId);
|
|
1122
|
-
this.emit("role:deleted", { role });
|
|
1123
|
-
return true;
|
|
1124
|
-
}
|
|
1125
|
-
// Permission Management
|
|
1126
|
-
async assignRoleToUser(userId, roleId) {
|
|
1127
|
-
const user = this.users.get(userId);
|
|
1128
|
-
const role = this.roles.get(roleId);
|
|
1129
|
-
if (!user) {
|
|
1130
|
-
throw new Error("User not found");
|
|
1131
|
-
}
|
|
1132
|
-
if (!role) {
|
|
1133
|
-
throw new Error("Role not found");
|
|
1134
|
-
}
|
|
1135
|
-
if (user.roles.some((r) => r.id === roleId)) {
|
|
1136
|
-
return;
|
|
1137
|
-
}
|
|
1138
|
-
user.roles.push(role);
|
|
1139
|
-
user.updatedAt = /* @__PURE__ */ new Date();
|
|
1140
|
-
this.updateUserRoleCache(userId, user.roles.map((r) => r.id));
|
|
1141
|
-
this.clearUserPermissionCache(userId);
|
|
1142
|
-
this.emit("role:assigned", { userId, roleId });
|
|
1143
|
-
}
|
|
1144
|
-
async removeRoleFromUser(userId, roleId) {
|
|
1145
|
-
const user = this.users.get(userId);
|
|
1146
|
-
if (!user) {
|
|
1147
|
-
throw new Error("User not found");
|
|
1148
|
-
}
|
|
1149
|
-
const roleIndex = user.roles.findIndex((r) => r.id === roleId);
|
|
1150
|
-
if (roleIndex === -1) {
|
|
1151
|
-
return;
|
|
1152
|
-
}
|
|
1153
|
-
user.roles.splice(roleIndex, 1);
|
|
1154
|
-
user.updatedAt = /* @__PURE__ */ new Date();
|
|
1155
|
-
this.updateUserRoleCache(userId, user.roles.map((r) => r.id));
|
|
1156
|
-
this.clearUserPermissionCache(userId);
|
|
1157
|
-
this.emit("role:removed", { userId, roleId });
|
|
1158
|
-
}
|
|
1159
|
-
// Permission Checking
|
|
1160
|
-
async checkPermission(check) {
|
|
1161
|
-
const cacheKey = this.getCacheKey(check);
|
|
1162
|
-
const cached = this.getFromCache(cacheKey);
|
|
1163
|
-
if (cached) {
|
|
1164
|
-
return cached;
|
|
1165
|
-
}
|
|
1166
|
-
const result = await this.performPermissionCheck(check);
|
|
1167
|
-
this.setCache(cacheKey, result);
|
|
1168
|
-
return result;
|
|
1169
|
-
}
|
|
1170
|
-
async hasPermission(userId, resource, action, resourceId, context) {
|
|
1171
|
-
const result = await this.checkPermission({
|
|
1172
|
-
userId,
|
|
1173
|
-
resource,
|
|
1174
|
-
action,
|
|
1175
|
-
resourceId,
|
|
1176
|
-
context
|
|
1177
|
-
});
|
|
1178
|
-
return result.granted;
|
|
1179
|
-
}
|
|
1180
|
-
async requirePermission(userId, resource, action, resourceId, context) {
|
|
1181
|
-
const hasAccess = await this.hasPermission(userId, resource, action, resourceId, context);
|
|
1182
|
-
if (!hasAccess) {
|
|
1183
|
-
throw new Error(`Access denied: ${action} on ${resource}`);
|
|
1184
|
-
}
|
|
1185
|
-
}
|
|
1186
|
-
// Utility Methods
|
|
1187
|
-
async getUserPermissions(userId) {
|
|
1188
|
-
const user = this.users.get(userId);
|
|
1189
|
-
if (!user) {
|
|
1190
|
-
return [];
|
|
1191
|
-
}
|
|
1192
|
-
const permissions = [];
|
|
1193
|
-
for (const role of user.roles) {
|
|
1194
|
-
permissions.push(...role.permissions);
|
|
1195
|
-
}
|
|
1196
|
-
const uniquePermissions = permissions.filter(
|
|
1197
|
-
(permission, index, self) => index === self.findIndex((p) => p.id === permission.id)
|
|
1198
|
-
);
|
|
1199
|
-
return uniquePermissions;
|
|
1200
|
-
}
|
|
1201
|
-
async getUserRoles(userId) {
|
|
1202
|
-
const user = this.users.get(userId);
|
|
1203
|
-
return user ? user.roles : [];
|
|
1204
|
-
}
|
|
1205
|
-
listUsers(filters) {
|
|
1206
|
-
let users = Array.from(this.users.values());
|
|
1207
|
-
if (filters?.isActive !== void 0) {
|
|
1208
|
-
users = users.filter((u) => u.isActive === filters.isActive);
|
|
1209
|
-
}
|
|
1210
|
-
if (filters?.roleId) {
|
|
1211
|
-
users = users.filter((u) => u.roles.some((r) => r.id === filters.roleId));
|
|
1212
|
-
}
|
|
1213
|
-
return users;
|
|
1214
|
-
}
|
|
1215
|
-
listRoles() {
|
|
1216
|
-
return Array.from(this.roles.values());
|
|
1217
|
-
}
|
|
1218
|
-
// Private Methods
|
|
1219
|
-
async performPermissionCheck(check) {
|
|
1220
|
-
const user = this.users.get(check.userId);
|
|
1221
|
-
if (!user) {
|
|
1222
|
-
return {
|
|
1223
|
-
granted: false,
|
|
1224
|
-
reason: "User not found",
|
|
1225
|
-
matchedPermissions: [],
|
|
1226
|
-
deniedReasons: ["User not found"]
|
|
1227
|
-
};
|
|
1228
|
-
}
|
|
1229
|
-
if (!user.isActive) {
|
|
1230
|
-
return {
|
|
1231
|
-
granted: false,
|
|
1232
|
-
reason: "User is inactive",
|
|
1233
|
-
matchedPermissions: [],
|
|
1234
|
-
deniedReasons: ["User is inactive"]
|
|
1235
|
-
};
|
|
1236
|
-
}
|
|
1237
|
-
const matchedPermissions = [];
|
|
1238
|
-
const deniedReasons = [];
|
|
1239
|
-
for (const role of user.roles) {
|
|
1240
|
-
for (const permission of role.permissions) {
|
|
1241
|
-
if (this.doesPermissionMatch(permission, check)) {
|
|
1242
|
-
if (await this.checkConditions(permission, check)) {
|
|
1243
|
-
matchedPermissions.push(permission);
|
|
1244
|
-
} else {
|
|
1245
|
-
deniedReasons.push(`Conditions not met for permission ${permission.id}`);
|
|
1
|
+
var{defineProperty:Sv,getOwnPropertyNames:EU,getOwnPropertyDescriptor:FU}=Object,VU=Object.prototype.hasOwnProperty;var n6=new WeakMap,mU=(r)=>{var v=n6.get(r),c;if(v)return v;if(v=Sv({},"__esModule",{value:!0}),r&&typeof r==="object"||typeof r==="function")EU(r).map((g)=>!VU.call(v,g)&&Sv(v,g,{get:()=>r[g],enumerable:!(c=FU(r,g))||c.enumerable}));return n6.set(r,v),v};var a=(r,v)=>{for(var c in v)Sv(r,c,{get:v[c],enumerable:!0,configurable:!0,set:(g)=>v[c]=()=>g})};var OO={};a(OO,{VerificationType:()=>_6,VerificationStatus:()=>O$,VerificationMethod:()=>w6,SenderNumberStatus:()=>Kr,SenderNumberFiltersSchema:()=>yj,SenderNumberCreateRequestSchema:()=>hj,SenderNumberCategory:()=>kv,ResourceType:()=>zv,PermissionScope:()=>c6,PermissionManager:()=>o6,NumberVerifier:()=>j6,KakaoSenderNumberManager:()=>e4,KakaoChannelManager:()=>a4,DocumentType:()=>p4,DocumentStatus:()=>d4,ChannelType:()=>Wr,ChannelStatus:()=>j$,ChannelService:()=>g6,ChannelFiltersSchema:()=>fj,ChannelCreateRequestSchema:()=>Cj,ChannelCRUD:()=>v6,BusinessVerifier:()=>U6,ActionType:()=>bv});module.exports=mU(OO);var X={};a(X,{xid:()=>Cw,void:()=>ij,uuidv7:()=>Vw,uuidv6:()=>Fw,uuidv4:()=>Ew,uuid:()=>tw,url:()=>mw,uppercase:()=>yr,unknown:()=>gv,union:()=>R4,undefined:()=>nj,ulid:()=>qw,uint64:()=>jj,uint32:()=>Uj,tuple:()=>xj,trim:()=>r$,treeifyError:()=>Lv,transform:()=>Z4,toUpperCase:()=>v$,toLowerCase:()=>$$,toJSONSchema:()=>U4,templateLiteral:()=>Yj,symbol:()=>Oj,superRefine:()=>AU,success:()=>Lj,stringbool:()=>Mj,stringFormat:()=>$j,string:()=>b4,strictObject:()=>Sj,startsWith:()=>dr,size:()=>Cr,setErrorMap:()=>Vj,set:()=>Wj,safeParseAsync:()=>z4,safeParse:()=>i4,registry:()=>Y$,regexes:()=>C,regex:()=>hr,refine:()=>GU,record:()=>vU,readonly:()=>xU,property:()=>ag,promise:()=>uj,prettifyError:()=>Qv,preprocess:()=>Ej,prefault:()=>iU,positive:()=>fg,pipe:()=>wv,partialRecord:()=>Jj,parseAsync:()=>k4,parse:()=>n4,overwrite:()=>y,optional:()=>Uv,object:()=>Dj,number:()=>T6,nullish:()=>Aj,nullable:()=>_v,null:()=>h6,normalize:()=>sr,nonpositive:()=>pg,nonoptional:()=>zU,nonnegative:()=>dg,never:()=>F4,negative:()=>yg,nativeEnum:()=>Kj,nanoid:()=>Tw,nan:()=>Qj,multipleOf:()=>Ur,minSize:()=>_r,minLength:()=>rr,mime:()=>er,maxSize:()=>Pr,maxLength:()=>Ir,map:()=>Xj,lte:()=>T,lt:()=>h,lowercase:()=>fr,looseObject:()=>Pj,locales:()=>lr,literal:()=>_U,length:()=>xr,lazy:()=>WU,ksuid:()=>hw,keyof:()=>bj,jwt:()=>rj,json:()=>tj,iso:()=>cv,ipv6:()=>yw,ipv4:()=>fw,intersection:()=>rU,int64:()=>wj,int32:()=>gj,int:()=>D4,instanceof:()=>Bj,includes:()=>pr,hostname:()=>vj,guid:()=>Mw,gte:()=>F,gt:()=>f,globalRegistry:()=>Z,getErrorMap:()=>mj,function:()=>g4,formatError:()=>Er,float64:()=>oj,float32:()=>cj,flattenError:()=>tr,file:()=>Gj,enum:()=>gU,endsWith:()=>ar,emoji:()=>Rw,email:()=>Bw,e164:()=>sw,discriminatedUnion:()=>Ij,date:()=>zj,custom:()=>Nj,cuid2:()=>Zw,cuid:()=>lw,core:()=>p,config:()=>B,coerce:()=>y4,clone:()=>E,cidrv6:()=>dw,cidrv4:()=>pw,check:()=>Hj,catch:()=>SU,boolean:()=>l6,bigint:()=>_j,base64url:()=>ew,base64:()=>aw,array:()=>V4,any:()=>kj,_default:()=>nU,_ZodString:()=>S4,ZodXID:()=>G4,ZodVoid:()=>d6,ZodUnknown:()=>y6,ZodUnion:()=>m4,ZodUndefined:()=>q6,ZodUUID:()=>d,ZodURL:()=>I4,ZodULID:()=>K4,ZodType:()=>W,ZodTuple:()=>$U,ZodTransform:()=>l4,ZodTemplateLiteral:()=>JU,ZodSymbol:()=>Z6,ZodSuccess:()=>bU,ZodStringFormat:()=>u,ZodString:()=>g$,ZodSet:()=>oU,ZodRecord:()=>T4,ZodRealError:()=>Jr,ZodReadonly:()=>IU,ZodPromise:()=>KU,ZodPrefault:()=>kU,ZodPipe:()=>h4,ZodOptional:()=>q4,ZodObject:()=>Ov,ZodNumberFormat:()=>Xr,ZodNumber:()=>U$,ZodNullable:()=>jU,ZodNull:()=>C6,ZodNonOptional:()=>C4,ZodNever:()=>p6,ZodNanoID:()=>J4,ZodNaN:()=>PU,ZodMap:()=>cU,ZodLiteral:()=>UU,ZodLazy:()=>XU,ZodKSUID:()=>A4,ZodJWT:()=>M4,ZodIssueCode:()=>Fj,ZodIntersection:()=>s6,ZodISOTime:()=>$v,ZodISODuration:()=>vv,ZodISODateTime:()=>s$,ZodISODate:()=>rv,ZodIPv6:()=>Q4,ZodIPv4:()=>L4,ZodGUID:()=>ov,ZodFirstPartyTypeKind:()=>f4,ZodFile:()=>wU,ZodError:()=>Hw,ZodEnum:()=>o$,ZodEmoji:()=>x4,ZodEmail:()=>P4,ZodE164:()=>B4,ZodDiscriminatedUnion:()=>e6,ZodDefault:()=>OU,ZodDate:()=>jv,ZodCustomStringFormat:()=>t4,ZodCustom:()=>nv,ZodCatch:()=>DU,ZodCUID2:()=>W4,ZodCUID:()=>X4,ZodCIDRv6:()=>u4,ZodCIDRv4:()=>Y4,ZodBoolean:()=>_$,ZodBigIntFormat:()=>E4,ZodBigInt:()=>w$,ZodBase64URL:()=>N4,ZodBase64:()=>H4,ZodArray:()=>a6,ZodAny:()=>f6,TimePrecision:()=>xg,NEVER:()=>Pv,$output:()=>Dg,$input:()=>Sg,$brand:()=>Iv});var p={};a(p,{version:()=>Kc,util:()=>S,treeifyError:()=>Lv,toJSONSchema:()=>U4,toDotPath:()=>b6,safeParseAsync:()=>uv,safeParse:()=>Yv,registry:()=>Y$,regexes:()=>C,prettifyError:()=>Qv,parseAsync:()=>S$,parse:()=>b$,locales:()=>lr,isValidJWT:()=>B6,isValidBase64URL:()=>N6,isValidBase64:()=>Cc,globalRegistry:()=>Z,globalConfig:()=>Ar,function:()=>g4,formatError:()=>Er,flattenError:()=>tr,config:()=>B,clone:()=>E,_xid:()=>T$,_void:()=>Zg,_uuidv7:()=>M$,_uuidv6:()=>B$,_uuidv4:()=>N$,_uuid:()=>H$,_url:()=>t$,_uppercase:()=>yr,_unknown:()=>Sr,_union:()=>jw,_undefined:()=>mg,_ulid:()=>R$,_uint64:()=>Fg,_uint32:()=>Hg,_tuple:()=>eg,_trim:()=>r$,_transform:()=>Pw,_toUpperCase:()=>v$,_toLowerCase:()=>$$,_templateLiteral:()=>Lw,_symbol:()=>Vg,_superRefine:()=>v4,_success:()=>Ww,_stringbool:()=>c4,_stringFormat:()=>a$,_string:()=>Pg,_startsWith:()=>dr,_size:()=>Cr,_set:()=>zw,_safeParseAsync:()=>I$,_safeParse:()=>P$,_regex:()=>hr,_refine:()=>$4,_record:()=>kw,_readonly:()=>Aw,_property:()=>ag,_promise:()=>Yw,_positive:()=>fg,_pipe:()=>Gw,_parseAsync:()=>D$,_parse:()=>z$,_overwrite:()=>y,_optional:()=>Iw,_number:()=>Gg,_nullable:()=>xw,_null:()=>Rg,_normalize:()=>sr,_nonpositive:()=>pg,_nonoptional:()=>Xw,_nonnegative:()=>dg,_never:()=>lg,_negative:()=>yg,_nativeEnum:()=>Dw,_nanoid:()=>F$,_nan:()=>hg,_multipleOf:()=>Ur,_minSize:()=>_r,_minLength:()=>rr,_min:()=>F,_mime:()=>er,_maxSize:()=>Pr,_maxLength:()=>Ir,_max:()=>T,_map:()=>iw,_lte:()=>T,_lt:()=>h,_lowercase:()=>fr,_literal:()=>Sw,_length:()=>xr,_lazy:()=>Qw,_ksuid:()=>l$,_jwt:()=>d$,_isoTime:()=>Wg,_isoDuration:()=>Kg,_isoDateTime:()=>Jg,_isoDate:()=>Xg,_ipv6:()=>q$,_ipv4:()=>Z$,_intersection:()=>nw,_int64:()=>Eg,_int32:()=>ug,_int:()=>Lg,_includes:()=>pr,_guid:()=>qr,_gte:()=>F,_gt:()=>f,_float64:()=>Yg,_float32:()=>Qg,_file:()=>sg,_enum:()=>bw,_endsWith:()=>ar,_emoji:()=>E$,_email:()=>u$,_e164:()=>p$,_discriminatedUnion:()=>Ow,_default:()=>Jw,_date:()=>qg,_custom:()=>r4,_cuid2:()=>m$,_cuid:()=>V$,_coercedString:()=>Ig,_coercedNumber:()=>Ag,_coercedDate:()=>Cg,_coercedBoolean:()=>Bg,_coercedBigint:()=>tg,_cidrv6:()=>h$,_cidrv4:()=>C$,_check:()=>F6,_catch:()=>Kw,_boolean:()=>Ng,_bigint:()=>Mg,_base64url:()=>y$,_base64:()=>f$,_array:()=>c$,_any:()=>Tg,TimePrecision:()=>xg,NEVER:()=>Pv,JSONSchemaGenerator:()=>e$,JSONSchema:()=>V6,Doc:()=>W$,$output:()=>Dg,$input:()=>Sg,$constructor:()=>w,$brand:()=>Iv,$ZodXID:()=>tc,$ZodVoid:()=>oo,$ZodUnknown:()=>Dr,$ZodUnion:()=>Q$,$ZodUndefined:()=>ro,$ZodUUID:()=>Lc,$ZodURL:()=>Yc,$ZodULID:()=>Mc,$ZodType:()=>J,$ZodTuple:()=>gr,$ZodTransform:()=>mr,$ZodTemplateLiteral:()=>Ko,$ZodSymbol:()=>sc,$ZodSuccess:()=>xo,$ZodStringFormat:()=>Y,$ZodString:()=>or,$ZodSet:()=>no,$ZodRegistry:()=>Zr,$ZodRecord:()=>jo,$ZodRealError:()=>zr,$ZodReadonly:()=>Wo,$ZodPromise:()=>Go,$ZodPrefault:()=>Po,$ZodPipe:()=>Rr,$ZodOptional:()=>bo,$ZodObject:()=>Uo,$ZodNumberFormat:()=>ac,$ZodNumber:()=>A$,$ZodNullable:()=>Do,$ZodNull:()=>$o,$ZodNonOptional:()=>Io,$ZodNever:()=>co,$ZodNanoID:()=>Hc,$ZodNaN:()=>Xo,$ZodMap:()=>Oo,$ZodLiteral:()=>io,$ZodLazy:()=>Ao,$ZodKSUID:()=>Ec,$ZodJWT:()=>pc,$ZodIntersection:()=>wo,$ZodISOTime:()=>mc,$ZodISODuration:()=>Rc,$ZodISODateTime:()=>Fc,$ZodISODate:()=>Vc,$ZodIPv6:()=>lc,$ZodIPv4:()=>Tc,$ZodGUID:()=>Ac,$ZodFunction:()=>o4,$ZodFile:()=>zo,$ZodError:()=>Mr,$ZodEnum:()=>ko,$ZodEmoji:()=>uc,$ZodEmail:()=>Qc,$ZodE164:()=>yc,$ZodDiscriminatedUnion:()=>_o,$ZodDefault:()=>So,$ZodDate:()=>go,$ZodCustomStringFormat:()=>dc,$ZodCustom:()=>Lo,$ZodCheckUpperCase:()=>Sc,$ZodCheckStringFormat:()=>br,$ZodCheckStartsWith:()=>Ic,$ZodCheckSizeEquals:()=>nc,$ZodCheckRegex:()=>bc,$ZodCheckProperty:()=>Jc,$ZodCheckOverwrite:()=>Wc,$ZodCheckNumberFormat:()=>_c,$ZodCheckMultipleOf:()=>Uc,$ZodCheckMinSize:()=>Oc,$ZodCheckMinLength:()=>ic,$ZodCheckMimeType:()=>Xc,$ZodCheckMaxSize:()=>jc,$ZodCheckMaxLength:()=>kc,$ZodCheckLowerCase:()=>Dc,$ZodCheckLessThan:()=>J$,$ZodCheckLengthEquals:()=>zc,$ZodCheckIncludes:()=>Pc,$ZodCheckGreaterThan:()=>X$,$ZodCheckEndsWith:()=>xc,$ZodCheckBigIntFormat:()=>wc,$ZodCheck:()=>H,$ZodCatch:()=>Jo,$ZodCUID2:()=>Bc,$ZodCUID:()=>Nc,$ZodCIDRv6:()=>qc,$ZodCIDRv4:()=>Zc,$ZodBoolean:()=>Fr,$ZodBigIntFormat:()=>ec,$ZodBigInt:()=>L$,$ZodBase64URL:()=>fc,$ZodBase64:()=>hc,$ZodAsyncError:()=>q,$ZodArray:()=>Vr,$ZodAny:()=>vo});var Pv=Object.freeze({status:"aborted"});function w(r,v,c){function g(_,j){var n;Object.defineProperty(_,"_zod",{value:_._zod??{},enumerable:!1}),(n=_._zod).traits??(n.traits=new Set),_._zod.traits.add(r),v(_,j);for(let k in U.prototype)if(!(k in _))Object.defineProperty(_,k,{value:U.prototype[k].bind(_)});_._zod.constr=U,_._zod.def=j}let $=c?.Parent??Object;class o extends ${}Object.defineProperty(o,"name",{value:r});function U(_){var j;let n=c?.Parent?new o:this;g(n,_),(j=n._zod).deferred??(j.deferred=[]);for(let k of n._zod.deferred)k();return n}return Object.defineProperty(U,"init",{value:g}),Object.defineProperty(U,Symbol.hasInstance,{value:(_)=>{if(c?.Parent&&_ instanceof c.Parent)return!0;return _?._zod?.traits?.has(r)}}),Object.defineProperty(U,"name",{value:r}),U}var Iv=Symbol("zod_brand");class q extends Error{constructor(){super("Encountered Promise during synchronous parse. Use .parseAsync() instead.")}}var Ar={};function B(r){if(r)Object.assign(Ar,r);return Ar}var S={};a(S,{unwrapMessage:()=>Lr,stringifyPrimitive:()=>D,required:()=>o_,randomString:()=>pU,propertyKeyTypes:()=>Hr,promiseAllObject:()=>yU,primitiveTypes:()=>Wv,prefixIssues:()=>m,pick:()=>sU,partial:()=>c_,optionalKeys:()=>Kv,omit:()=>r_,objectClone:()=>CU,numKeys:()=>dU,nullish:()=>e,normalizeParams:()=>z,mergeDefs:()=>s,merge:()=>v_,jsonStringifyReplacer:()=>nr,joinValues:()=>i,issue:()=>ir,isPlainObject:()=>kr,isObject:()=>Or,getSizableOrigin:()=>Nr,getParsedType:()=>aU,getLengthableOrigin:()=>Br,getEnumValues:()=>Qr,getElementAtPath:()=>fU,floatSafeRemainder:()=>Jv,finalizeIssue:()=>R,extend:()=>$_,escapeRegex:()=>l,esc:()=>k$,defineLazy:()=>K,createTransparentProxy:()=>eU,cloneDef:()=>hU,clone:()=>E,cleanRegex:()=>ur,cleanEnum:()=>g_,captureStackTrace:()=>i$,cached:()=>Yr,assignProp:()=>$r,assertNotEqual:()=>TU,assertNever:()=>ZU,assertIs:()=>lU,assertEqual:()=>RU,assert:()=>qU,allowsEval:()=>Xv,aborted:()=>vr,NUMBER_FORMAT_RANGES:()=>Gv,Class:()=>i6,BIGINT_FORMAT_RANGES:()=>Av});function RU(r){return r}function TU(r){return r}function lU(r){}function ZU(r){throw Error()}function qU(r){}function Qr(r){let v=Object.values(r).filter((g)=>typeof g==="number");return Object.entries(r).filter(([g,$])=>v.indexOf(+g)===-1).map(([g,$])=>$)}function i(r,v="|"){return r.map((c)=>D(c)).join(v)}function nr(r,v){if(typeof v==="bigint")return v.toString();return v}function Yr(r){return{get value(){{let c=r();return Object.defineProperty(this,"value",{value:c}),c}throw Error("cached value already set")}}}function e(r){return r===null||r===void 0}function ur(r){let v=r.startsWith("^")?1:0,c=r.endsWith("$")?r.length-1:r.length;return r.slice(v,c)}function Jv(r,v){let c=(r.toString().split(".")[1]||"").length,g=v.toString(),$=(g.split(".")[1]||"").length;if($===0&&/\d?e-\d?/.test(g)){let j=g.match(/\d?e-(\d?)/);if(j?.[1])$=Number.parseInt(j[1])}let o=c>$?c:$,U=Number.parseInt(r.toFixed(o).replace(".","")),_=Number.parseInt(v.toFixed(o).replace(".",""));return U%_/10**o}var k6=Symbol("evaluating");function K(r,v,c){let g=void 0;Object.defineProperty(r,v,{get(){if(g===k6)return;if(g===void 0)g=k6,g=c();return g},set($){Object.defineProperty(r,v,{value:$})},configurable:!0})}function CU(r){return Object.create(Object.getPrototypeOf(r),Object.getOwnPropertyDescriptors(r))}function $r(r,v,c){Object.defineProperty(r,v,{value:c,writable:!0,enumerable:!0,configurable:!0})}function s(...r){let v={};for(let c of r){let g=Object.getOwnPropertyDescriptors(c);Object.assign(v,g)}return Object.defineProperties({},v)}function hU(r){return s(r._zod.def)}function fU(r,v){if(!v)return r;return v.reduce((c,g)=>c?.[g],r)}function yU(r){let v=Object.keys(r),c=v.map((g)=>r[g]);return Promise.all(c).then((g)=>{let $={};for(let o=0;o<v.length;o++)$[v[o]]=g[o];return $})}function pU(r=10){let c="";for(let g=0;g<r;g++)c+="abcdefghijklmnopqrstuvwxyz"[Math.floor(Math.random()*26)];return c}function k$(r){return JSON.stringify(r)}var i$="captureStackTrace"in Error?Error.captureStackTrace:(...r)=>{};function Or(r){return typeof r==="object"&&r!==null&&!Array.isArray(r)}var Xv=Yr(()=>{if(typeof navigator<"u"&&navigator?.userAgent?.includes("Cloudflare"))return!1;try{return new Function(""),!0}catch(r){return!1}});function kr(r){if(Or(r)===!1)return!1;let v=r.constructor;if(v===void 0)return!0;let c=v.prototype;if(Or(c)===!1)return!1;if(Object.prototype.hasOwnProperty.call(c,"isPrototypeOf")===!1)return!1;return!0}function dU(r){let v=0;for(let c in r)if(Object.prototype.hasOwnProperty.call(r,c))v++;return v}var aU=(r)=>{let v=typeof r;switch(v){case"undefined":return"undefined";case"string":return"string";case"number":return Number.isNaN(r)?"nan":"number";case"boolean":return"boolean";case"function":return"function";case"bigint":return"bigint";case"symbol":return"symbol";case"object":if(Array.isArray(r))return"array";if(r===null)return"null";if(r.then&&typeof r.then==="function"&&r.catch&&typeof r.catch==="function")return"promise";if(typeof Map<"u"&&r instanceof Map)return"map";if(typeof Set<"u"&&r instanceof Set)return"set";if(typeof Date<"u"&&r instanceof Date)return"date";if(typeof File<"u"&&r instanceof File)return"file";return"object";default:throw Error(`Unknown data type: ${v}`)}},Hr=new Set(["string","number","symbol"]),Wv=new Set(["string","number","bigint","boolean","symbol","undefined"]);function l(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function E(r,v,c){let g=new r._zod.constr(v??r._zod.def);if(!v||c?.parent)g._zod.parent=r;return g}function z(r){let v=r;if(!v)return{};if(typeof v==="string")return{error:()=>v};if(v?.message!==void 0){if(v?.error!==void 0)throw Error("Cannot specify both `message` and `error` params");v.error=v.message}if(delete v.message,typeof v.error==="string")return{...v,error:()=>v.error};return v}function eU(r){let v;return new Proxy({},{get(c,g,$){return v??(v=r()),Reflect.get(v,g,$)},set(c,g,$,o){return v??(v=r()),Reflect.set(v,g,$,o)},has(c,g){return v??(v=r()),Reflect.has(v,g)},deleteProperty(c,g){return v??(v=r()),Reflect.deleteProperty(v,g)},ownKeys(c){return v??(v=r()),Reflect.ownKeys(v)},getOwnPropertyDescriptor(c,g){return v??(v=r()),Reflect.getOwnPropertyDescriptor(v,g)},defineProperty(c,g,$){return v??(v=r()),Reflect.defineProperty(v,g,$)}})}function D(r){if(typeof r==="bigint")return r.toString()+"n";if(typeof r==="string")return`"${r}"`;return`${r}`}function Kv(r){return Object.keys(r).filter((v)=>{return r[v]._zod.optin==="optional"&&r[v]._zod.optout==="optional"})}var Gv={safeint:[Number.MIN_SAFE_INTEGER,Number.MAX_SAFE_INTEGER],int32:[-2147483648,2147483647],uint32:[0,4294967295],float32:[-340282346638528860000000000000000000000,340282346638528860000000000000000000000],float64:[-Number.MAX_VALUE,Number.MAX_VALUE]},Av={int64:[BigInt("-9223372036854775808"),BigInt("9223372036854775807")],uint64:[BigInt(0),BigInt("18446744073709551615")]};function sU(r,v){let c=r._zod.def,g=s(r._zod.def,{get shape(){let $={};for(let o in v){if(!(o in c.shape))throw Error(`Unrecognized key: "${o}"`);if(!v[o])continue;$[o]=c.shape[o]}return $r(this,"shape",$),$},checks:[]});return E(r,g)}function r_(r,v){let c=r._zod.def,g=s(r._zod.def,{get shape(){let $={...r._zod.def.shape};for(let o in v){if(!(o in c.shape))throw Error(`Unrecognized key: "${o}"`);if(!v[o])continue;delete $[o]}return $r(this,"shape",$),$},checks:[]});return E(r,g)}function $_(r,v){if(!kr(v))throw Error("Invalid input to extend: expected a plain object");let c=s(r._zod.def,{get shape(){let g={...r._zod.def.shape,...v};return $r(this,"shape",g),g},checks:[]});return E(r,c)}function v_(r,v){let c=s(r._zod.def,{get shape(){let g={...r._zod.def.shape,...v._zod.def.shape};return $r(this,"shape",g),g},get catchall(){return v._zod.def.catchall},checks:[]});return E(r,c)}function c_(r,v,c){let g=s(v._zod.def,{get shape(){let $=v._zod.def.shape,o={...$};if(c)for(let U in c){if(!(U in $))throw Error(`Unrecognized key: "${U}"`);if(!c[U])continue;o[U]=r?new r({type:"optional",innerType:$[U]}):$[U]}else for(let U in $)o[U]=r?new r({type:"optional",innerType:$[U]}):$[U];return $r(this,"shape",o),o},checks:[]});return E(v,g)}function o_(r,v,c){let g=s(v._zod.def,{get shape(){let $=v._zod.def.shape,o={...$};if(c)for(let U in c){if(!(U in o))throw Error(`Unrecognized key: "${U}"`);if(!c[U])continue;o[U]=new r({type:"nonoptional",innerType:$[U]})}else for(let U in $)o[U]=new r({type:"nonoptional",innerType:$[U]});return $r(this,"shape",o),o},checks:[]});return E(v,g)}function vr(r,v=0){for(let c=v;c<r.issues.length;c++)if(r.issues[c]?.continue!==!0)return!0;return!1}function m(r,v){return v.map((c)=>{var g;return(g=c).path??(g.path=[]),c.path.unshift(r),c})}function Lr(r){return typeof r==="string"?r:r?.message}function R(r,v,c){let g={...r,path:r.path??[]};if(!r.message){let $=Lr(r.inst?._zod.def?.error?.(r))??Lr(v?.error?.(r))??Lr(c.customError?.(r))??Lr(c.localeError?.(r))??"Invalid input";g.message=$}if(delete g.inst,delete g.continue,!v?.reportInput)delete g.input;return g}function Nr(r){if(r instanceof Set)return"set";if(r instanceof Map)return"map";if(r instanceof File)return"file";return"unknown"}function Br(r){if(Array.isArray(r))return"array";if(typeof r==="string")return"string";return"unknown"}function ir(...r){let[v,c,g]=r;if(typeof v==="string")return{message:v,code:"custom",input:c,inst:g};return{...v}}function g_(r){return Object.entries(r).filter(([v,c])=>{return Number.isNaN(Number.parseInt(v,10))}).map((v)=>v[1])}class i6{constructor(...r){}}var z6=(r,v)=>{r.name="$ZodError",Object.defineProperty(r,"_zod",{value:r._zod,enumerable:!1}),Object.defineProperty(r,"issues",{value:v,enumerable:!1}),r.message=JSON.stringify(v,nr,2),Object.defineProperty(r,"toString",{value:()=>r.message,enumerable:!1})},Mr=w("$ZodError",z6),zr=w("$ZodError",z6,{Parent:Error});function tr(r,v=(c)=>c.message){let c={},g=[];for(let $ of r.issues)if($.path.length>0)c[$.path[0]]=c[$.path[0]]||[],c[$.path[0]].push(v($));else g.push(v($));return{formErrors:g,fieldErrors:c}}function Er(r,v){let c=v||function(o){return o.message},g={_errors:[]},$=(o)=>{for(let U of o.issues)if(U.code==="invalid_union"&&U.errors.length)U.errors.map((_)=>$({issues:_}));else if(U.code==="invalid_key")$({issues:U.issues});else if(U.code==="invalid_element")$({issues:U.issues});else if(U.path.length===0)g._errors.push(c(U));else{let _=g,j=0;while(j<U.path.length){let n=U.path[j];if(j!==U.path.length-1)_[n]=_[n]||{_errors:[]};else _[n]=_[n]||{_errors:[]},_[n]._errors.push(c(U));_=_[n],j++}}};return $(r),g}function Lv(r,v){let c=v||function(o){return o.message},g={errors:[]},$=(o,U=[])=>{var _,j;for(let n of o.issues)if(n.code==="invalid_union"&&n.errors.length)n.errors.map((k)=>$({issues:k},n.path));else if(n.code==="invalid_key")$({issues:n.issues},n.path);else if(n.code==="invalid_element")$({issues:n.issues},n.path);else{let k=[...U,...n.path];if(k.length===0){g.errors.push(c(n));continue}let P=g,b=0;while(b<k.length){let O=k[b],I=b===k.length-1;if(typeof O==="string")P.properties??(P.properties={}),(_=P.properties)[O]??(_[O]={errors:[]}),P=P.properties[O];else P.items??(P.items=[]),(j=P.items)[O]??(j[O]={errors:[]}),P=P.items[O];if(I)P.errors.push(c(n));b++}}};return $(r),g}function b6(r){let v=[],c=r.map((g)=>typeof g==="object"?g.key:g);for(let g of c)if(typeof g==="number")v.push(`[${g}]`);else if(typeof g==="symbol")v.push(`[${JSON.stringify(String(g))}]`);else if(/[^\w$]/.test(g))v.push(`[${JSON.stringify(g)}]`);else{if(v.length)v.push(".");v.push(g)}return v.join("")}function Qv(r){let v=[],c=[...r.issues].sort((g,$)=>(g.path??[]).length-($.path??[]).length);for(let g of c)if(v.push(`✖ ${g.message}`),g.path?.length)v.push(` → at ${b6(g.path)}`);return v.join(`
|
|
2
|
+
`)}var z$=(r)=>(v,c,g,$)=>{let o=g?Object.assign(g,{async:!1}):{async:!1},U=v._zod.run({value:c,issues:[]},o);if(U instanceof Promise)throw new q;if(U.issues.length){let _=new($?.Err??r)(U.issues.map((j)=>R(j,o,B())));throw i$(_,$?.callee),_}return U.value},b$=z$(zr),D$=(r)=>async(v,c,g,$)=>{let o=g?Object.assign(g,{async:!0}):{async:!0},U=v._zod.run({value:c,issues:[]},o);if(U instanceof Promise)U=await U;if(U.issues.length){let _=new($?.Err??r)(U.issues.map((j)=>R(j,o,B())));throw i$(_,$?.callee),_}return U.value},S$=D$(zr),P$=(r)=>(v,c,g)=>{let $=g?{...g,async:!1}:{async:!1},o=v._zod.run({value:c,issues:[]},$);if(o instanceof Promise)throw new q;return o.issues.length?{success:!1,error:new(r??Mr)(o.issues.map((U)=>R(U,$,B())))}:{success:!0,data:o.value}},Yv=P$(zr),I$=(r)=>async(v,c,g)=>{let $=g?Object.assign(g,{async:!0}):{async:!0},o=v._zod.run({value:c,issues:[]},$);if(o instanceof Promise)o=await o;return o.issues.length?{success:!1,error:new r(o.issues.map((U)=>R(U,$,B())))}:{success:!0,data:o.value}},uv=I$(zr);var C={};a(C,{xid:()=>Mv,uuid7:()=>O_,uuid6:()=>j_,uuid4:()=>w_,uuid:()=>cr,uppercase:()=>gc,unicodeEmail:()=>i_,undefined:()=>cc,ulid:()=>Bv,time:()=>pv,string:()=>av,rfc5322Email:()=>k_,number:()=>rc,null:()=>vc,nanoid:()=>Ev,lowercase:()=>oc,ksuid:()=>tv,ipv6:()=>lv,ipv4:()=>Tv,integer:()=>sv,idnEmail:()=>z_,html5Email:()=>n_,hostname:()=>hv,guid:()=>Vv,extendedDuration:()=>__,emoji:()=>Rv,email:()=>mv,e164:()=>fv,duration:()=>Fv,domain:()=>D_,datetime:()=>dv,date:()=>yv,cuid2:()=>Nv,cuid:()=>Hv,cidrv6:()=>qv,cidrv4:()=>Zv,browserEmail:()=>b_,boolean:()=>$c,bigint:()=>ev,base64url:()=>x$,base64:()=>Cv});var Hv=/^[cC][^\s-]{8,}$/,Nv=/^[0-9a-z]+$/,Bv=/^[0-9A-HJKMNP-TV-Za-hjkmnp-tv-z]{26}$/,Mv=/^[0-9a-vA-V]{20}$/,tv=/^[A-Za-z0-9]{27}$/,Ev=/^[a-zA-Z0-9_-]{21}$/,Fv=/^P(?:(\d+W)|(?!.*W)(?=\d|T\d)(\d+Y)?(\d+M)?(\d+D)?(T(?=\d)(\d+H)?(\d+M)?(\d+([.,]\d+)?S)?)?)$/,__=/^[-+]?P(?!$)(?:(?:[-+]?\d+Y)|(?:[-+]?\d+[.,]\d+Y$))?(?:(?:[-+]?\d+M)|(?:[-+]?\d+[.,]\d+M$))?(?:(?:[-+]?\d+W)|(?:[-+]?\d+[.,]\d+W$))?(?:(?:[-+]?\d+D)|(?:[-+]?\d+[.,]\d+D$))?(?:T(?=[\d+-])(?:(?:[-+]?\d+H)|(?:[-+]?\d+[.,]\d+H$))?(?:(?:[-+]?\d+M)|(?:[-+]?\d+[.,]\d+M$))?(?:[-+]?\d+(?:[.,]\d+)?S)?)??$/,Vv=/^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12})$/,cr=(r)=>{if(!r)return/^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[1-8][0-9a-fA-F]{3}-[89abAB][0-9a-fA-F]{3}-[0-9a-fA-F]{12}|00000000-0000-0000-0000-000000000000)$/;return new RegExp(`^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-${r}[0-9a-fA-F]{3}-[89abAB][0-9a-fA-F]{3}-[0-9a-fA-F]{12})$`)},w_=cr(4),j_=cr(6),O_=cr(7),mv=/^(?!\.)(?!.*\.\.)([A-Za-z0-9_'+\-\.]*)[A-Za-z0-9_+-]@([A-Za-z0-9][A-Za-z0-9\-]*\.)+[A-Za-z]{2,}$/,n_=/^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/,k_=/^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,i_=/^[^\s@"]{1,64}@[^\s@]{1,255}$/u,z_=/^[^\s@"]{1,64}@[^\s@]{1,255}$/u,b_=/^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/;function Rv(){return new RegExp("^(\\p{Extended_Pictographic}|\\p{Emoji_Component})+$","u")}var Tv=/^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])$/,lv=/^(([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}|::|([0-9a-fA-F]{1,4})?::([0-9a-fA-F]{1,4}:?){0,6})$/,Zv=/^((25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\/([0-9]|[1-2][0-9]|3[0-2])$/,qv=/^(([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}|::|([0-9a-fA-F]{1,4})?::([0-9a-fA-F]{1,4}:?){0,6})\/(12[0-8]|1[01][0-9]|[1-9]?[0-9])$/,Cv=/^$|^(?:[0-9a-zA-Z+/]{4})*(?:(?:[0-9a-zA-Z+/]{2}==)|(?:[0-9a-zA-Z+/]{3}=))?$/,x$=/^[A-Za-z0-9_-]*$/,hv=/^(?=.{1,253}\.?$)[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[-0-9a-zA-Z]{0,61}[0-9a-zA-Z])?)*\.?$/,D_=/^([a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,}$/,fv=/^\+(?:[0-9]){6,14}[0-9]$/,D6="(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))",yv=new RegExp(`^${D6}$`);function S6(r){return typeof r.precision==="number"?r.precision===-1?"(?:[01]\\d|2[0-3]):[0-5]\\d":r.precision===0?"(?:[01]\\d|2[0-3]):[0-5]\\d:[0-5]\\d":`(?:[01]\\d|2[0-3]):[0-5]\\d:[0-5]\\d\\.\\d{${r.precision}}`:"(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?"}function pv(r){return new RegExp(`^${S6(r)}$`)}function dv(r){let v=S6({precision:r.precision}),c=["Z"];if(r.local)c.push("");if(r.offset)c.push("([+-](?:[01]\\d|2[0-3]):[0-5]\\d)");let g=`${v}(?:${c.join("|")})`;return new RegExp(`^${D6}T(?:${g})$`)}var av=(r)=>{let v=r?`[\\s\\S]{${r?.minimum??0},${r?.maximum??""}}`:"[\\s\\S]*";return new RegExp(`^${v}$`)},ev=/^\d+n?$/,sv=/^\d+$/,rc=/^-?\d+(?:\.\d+)?/i,$c=/true|false/i,vc=/null/i;var cc=/undefined/i;var oc=/^[^A-Z]*$/,gc=/^[^a-z]*$/;var H=w("$ZodCheck",(r,v)=>{var c;r._zod??(r._zod={}),r._zod.def=v,(c=r._zod).onattach??(c.onattach=[])}),I6={number:"number",bigint:"bigint",object:"date"},J$=w("$ZodCheckLessThan",(r,v)=>{H.init(r,v);let c=I6[typeof v.value];r._zod.onattach.push((g)=>{let $=g._zod.bag,o=(v.inclusive?$.maximum:$.exclusiveMaximum)??Number.POSITIVE_INFINITY;if(v.value<o)if(v.inclusive)$.maximum=v.value;else $.exclusiveMaximum=v.value}),r._zod.check=(g)=>{if(v.inclusive?g.value<=v.value:g.value<v.value)return;g.issues.push({origin:c,code:"too_big",maximum:v.value,input:g.value,inclusive:v.inclusive,inst:r,continue:!v.abort})}}),X$=w("$ZodCheckGreaterThan",(r,v)=>{H.init(r,v);let c=I6[typeof v.value];r._zod.onattach.push((g)=>{let $=g._zod.bag,o=(v.inclusive?$.minimum:$.exclusiveMinimum)??Number.NEGATIVE_INFINITY;if(v.value>o)if(v.inclusive)$.minimum=v.value;else $.exclusiveMinimum=v.value}),r._zod.check=(g)=>{if(v.inclusive?g.value>=v.value:g.value>v.value)return;g.issues.push({origin:c,code:"too_small",minimum:v.value,input:g.value,inclusive:v.inclusive,inst:r,continue:!v.abort})}}),Uc=w("$ZodCheckMultipleOf",(r,v)=>{H.init(r,v),r._zod.onattach.push((c)=>{var g;(g=c._zod.bag).multipleOf??(g.multipleOf=v.value)}),r._zod.check=(c)=>{if(typeof c.value!==typeof v.value)throw Error("Cannot mix number and bigint in multiple_of check.");if(typeof c.value==="bigint"?c.value%v.value===BigInt(0):Jv(c.value,v.value)===0)return;c.issues.push({origin:typeof c.value,code:"not_multiple_of",divisor:v.value,input:c.value,inst:r,continue:!v.abort})}}),_c=w("$ZodCheckNumberFormat",(r,v)=>{H.init(r,v),v.format=v.format||"float64";let c=v.format?.includes("int"),g=c?"int":"number",[$,o]=Gv[v.format];r._zod.onattach.push((U)=>{let _=U._zod.bag;if(_.format=v.format,_.minimum=$,_.maximum=o,c)_.pattern=sv}),r._zod.check=(U)=>{let _=U.value;if(c){if(!Number.isInteger(_)){U.issues.push({expected:g,format:v.format,code:"invalid_type",continue:!1,input:_,inst:r});return}if(!Number.isSafeInteger(_)){if(_>0)U.issues.push({input:_,code:"too_big",maximum:Number.MAX_SAFE_INTEGER,note:"Integers must be within the safe integer range.",inst:r,origin:g,continue:!v.abort});else U.issues.push({input:_,code:"too_small",minimum:Number.MIN_SAFE_INTEGER,note:"Integers must be within the safe integer range.",inst:r,origin:g,continue:!v.abort});return}}if(_<$)U.issues.push({origin:"number",input:_,code:"too_small",minimum:$,inclusive:!0,inst:r,continue:!v.abort});if(_>o)U.issues.push({origin:"number",input:_,code:"too_big",maximum:o,inst:r})}}),wc=w("$ZodCheckBigIntFormat",(r,v)=>{H.init(r,v);let[c,g]=Av[v.format];r._zod.onattach.push(($)=>{let o=$._zod.bag;o.format=v.format,o.minimum=c,o.maximum=g}),r._zod.check=($)=>{let o=$.value;if(o<c)$.issues.push({origin:"bigint",input:o,code:"too_small",minimum:c,inclusive:!0,inst:r,continue:!v.abort});if(o>g)$.issues.push({origin:"bigint",input:o,code:"too_big",maximum:g,inst:r})}}),jc=w("$ZodCheckMaxSize",(r,v)=>{var c;H.init(r,v),(c=r._zod.def).when??(c.when=(g)=>{let $=g.value;return!e($)&&$.size!==void 0}),r._zod.onattach.push((g)=>{let $=g._zod.bag.maximum??Number.POSITIVE_INFINITY;if(v.maximum<$)g._zod.bag.maximum=v.maximum}),r._zod.check=(g)=>{let $=g.value;if($.size<=v.maximum)return;g.issues.push({origin:Nr($),code:"too_big",maximum:v.maximum,input:$,inst:r,continue:!v.abort})}}),Oc=w("$ZodCheckMinSize",(r,v)=>{var c;H.init(r,v),(c=r._zod.def).when??(c.when=(g)=>{let $=g.value;return!e($)&&$.size!==void 0}),r._zod.onattach.push((g)=>{let $=g._zod.bag.minimum??Number.NEGATIVE_INFINITY;if(v.minimum>$)g._zod.bag.minimum=v.minimum}),r._zod.check=(g)=>{let $=g.value;if($.size>=v.minimum)return;g.issues.push({origin:Nr($),code:"too_small",minimum:v.minimum,input:$,inst:r,continue:!v.abort})}}),nc=w("$ZodCheckSizeEquals",(r,v)=>{var c;H.init(r,v),(c=r._zod.def).when??(c.when=(g)=>{let $=g.value;return!e($)&&$.size!==void 0}),r._zod.onattach.push((g)=>{let $=g._zod.bag;$.minimum=v.size,$.maximum=v.size,$.size=v.size}),r._zod.check=(g)=>{let $=g.value,o=$.size;if(o===v.size)return;let U=o>v.size;g.issues.push({origin:Nr($),...U?{code:"too_big",maximum:v.size}:{code:"too_small",minimum:v.size},inclusive:!0,exact:!0,input:g.value,inst:r,continue:!v.abort})}}),kc=w("$ZodCheckMaxLength",(r,v)=>{var c;H.init(r,v),(c=r._zod.def).when??(c.when=(g)=>{let $=g.value;return!e($)&&$.length!==void 0}),r._zod.onattach.push((g)=>{let $=g._zod.bag.maximum??Number.POSITIVE_INFINITY;if(v.maximum<$)g._zod.bag.maximum=v.maximum}),r._zod.check=(g)=>{let $=g.value;if($.length<=v.maximum)return;let U=Br($);g.issues.push({origin:U,code:"too_big",maximum:v.maximum,inclusive:!0,input:$,inst:r,continue:!v.abort})}}),ic=w("$ZodCheckMinLength",(r,v)=>{var c;H.init(r,v),(c=r._zod.def).when??(c.when=(g)=>{let $=g.value;return!e($)&&$.length!==void 0}),r._zod.onattach.push((g)=>{let $=g._zod.bag.minimum??Number.NEGATIVE_INFINITY;if(v.minimum>$)g._zod.bag.minimum=v.minimum}),r._zod.check=(g)=>{let $=g.value;if($.length>=v.minimum)return;let U=Br($);g.issues.push({origin:U,code:"too_small",minimum:v.minimum,inclusive:!0,input:$,inst:r,continue:!v.abort})}}),zc=w("$ZodCheckLengthEquals",(r,v)=>{var c;H.init(r,v),(c=r._zod.def).when??(c.when=(g)=>{let $=g.value;return!e($)&&$.length!==void 0}),r._zod.onattach.push((g)=>{let $=g._zod.bag;$.minimum=v.length,$.maximum=v.length,$.length=v.length}),r._zod.check=(g)=>{let $=g.value,o=$.length;if(o===v.length)return;let U=Br($),_=o>v.length;g.issues.push({origin:U,..._?{code:"too_big",maximum:v.length}:{code:"too_small",minimum:v.length},inclusive:!0,exact:!0,input:g.value,inst:r,continue:!v.abort})}}),br=w("$ZodCheckStringFormat",(r,v)=>{var c,g;if(H.init(r,v),r._zod.onattach.push(($)=>{let o=$._zod.bag;if(o.format=v.format,v.pattern)o.patterns??(o.patterns=new Set),o.patterns.add(v.pattern)}),v.pattern)(c=r._zod).check??(c.check=($)=>{if(v.pattern.lastIndex=0,v.pattern.test($.value))return;$.issues.push({origin:"string",code:"invalid_format",format:v.format,input:$.value,...v.pattern?{pattern:v.pattern.toString()}:{},inst:r,continue:!v.abort})});else(g=r._zod).check??(g.check=()=>{})}),bc=w("$ZodCheckRegex",(r,v)=>{br.init(r,v),r._zod.check=(c)=>{if(v.pattern.lastIndex=0,v.pattern.test(c.value))return;c.issues.push({origin:"string",code:"invalid_format",format:"regex",input:c.value,pattern:v.pattern.toString(),inst:r,continue:!v.abort})}}),Dc=w("$ZodCheckLowerCase",(r,v)=>{v.pattern??(v.pattern=oc),br.init(r,v)}),Sc=w("$ZodCheckUpperCase",(r,v)=>{v.pattern??(v.pattern=gc),br.init(r,v)}),Pc=w("$ZodCheckIncludes",(r,v)=>{H.init(r,v);let c=l(v.includes),g=new RegExp(typeof v.position==="number"?`^.{${v.position}}${c}`:c);v.pattern=g,r._zod.onattach.push(($)=>{let o=$._zod.bag;o.patterns??(o.patterns=new Set),o.patterns.add(g)}),r._zod.check=($)=>{if($.value.includes(v.includes,v.position))return;$.issues.push({origin:"string",code:"invalid_format",format:"includes",includes:v.includes,input:$.value,inst:r,continue:!v.abort})}}),Ic=w("$ZodCheckStartsWith",(r,v)=>{H.init(r,v);let c=new RegExp(`^${l(v.prefix)}.*`);v.pattern??(v.pattern=c),r._zod.onattach.push((g)=>{let $=g._zod.bag;$.patterns??($.patterns=new Set),$.patterns.add(c)}),r._zod.check=(g)=>{if(g.value.startsWith(v.prefix))return;g.issues.push({origin:"string",code:"invalid_format",format:"starts_with",prefix:v.prefix,input:g.value,inst:r,continue:!v.abort})}}),xc=w("$ZodCheckEndsWith",(r,v)=>{H.init(r,v);let c=new RegExp(`.*${l(v.suffix)}$`);v.pattern??(v.pattern=c),r._zod.onattach.push((g)=>{let $=g._zod.bag;$.patterns??($.patterns=new Set),$.patterns.add(c)}),r._zod.check=(g)=>{if(g.value.endsWith(v.suffix))return;g.issues.push({origin:"string",code:"invalid_format",format:"ends_with",suffix:v.suffix,input:g.value,inst:r,continue:!v.abort})}});function P6(r,v,c){if(r.issues.length)v.issues.push(...m(c,r.issues))}var Jc=w("$ZodCheckProperty",(r,v)=>{H.init(r,v),r._zod.check=(c)=>{let g=v.schema._zod.run({value:c.value[v.property],issues:[]},{});if(g instanceof Promise)return g.then(($)=>P6($,c,v.property));P6(g,c,v.property);return}}),Xc=w("$ZodCheckMimeType",(r,v)=>{H.init(r,v);let c=new Set(v.mime);r._zod.onattach.push((g)=>{g._zod.bag.mime=v.mime}),r._zod.check=(g)=>{if(c.has(g.value.type))return;g.issues.push({code:"invalid_value",values:v.mime,input:g.value.type,inst:r,continue:!v.abort})}}),Wc=w("$ZodCheckOverwrite",(r,v)=>{H.init(r,v),r._zod.check=(c)=>{c.value=v.tx(c.value)}});class W${constructor(r=[]){if(this.content=[],this.indent=0,this)this.args=r}indented(r){this.indent+=1,r(this),this.indent-=1}write(r){if(typeof r==="function"){r(this,{execution:"sync"}),r(this,{execution:"async"});return}let c=r.split(`
|
|
3
|
+
`).filter((o)=>o),g=Math.min(...c.map((o)=>o.length-o.trimStart().length)),$=c.map((o)=>o.slice(g)).map((o)=>" ".repeat(this.indent*2)+o);for(let o of $)this.content.push(o)}compile(){let r=Function,v=this?.args,g=[...(this?.content??[""]).map(($)=>` ${$}`)];return new r(...v,g.join(`
|
|
4
|
+
`))}}var Kc={major:4,minor:0,patch:15};var J=w("$ZodType",(r,v)=>{var c;r??(r={}),r._zod.def=v,r._zod.bag=r._zod.bag||{},r._zod.version=Kc;let g=[...r._zod.def.checks??[]];if(r._zod.traits.has("$ZodCheck"))g.unshift(r);for(let $ of g)for(let o of $._zod.onattach)o(r);if(g.length===0)(c=r._zod).deferred??(c.deferred=[]),r._zod.deferred?.push(()=>{r._zod.run=r._zod.parse});else{let $=(o,U,_)=>{let j=vr(o),n;for(let k of U){if(k._zod.def.when){if(!k._zod.def.when(o))continue}else if(j)continue;let P=o.issues.length,b=k._zod.check(o);if(b instanceof Promise&&_?.async===!1)throw new q;if(n||b instanceof Promise)n=(n??Promise.resolve()).then(async()=>{if(await b,o.issues.length===P)return;if(!j)j=vr(o,P)});else{if(o.issues.length===P)continue;if(!j)j=vr(o,P)}}if(n)return n.then(()=>{return o});return o};r._zod.run=(o,U)=>{let _=r._zod.parse(o,U);if(_ instanceof Promise){if(U.async===!1)throw new q;return _.then((j)=>$(j,g,U))}return $(_,g,U)}}r["~standard"]={validate:($)=>{try{let o=Yv(r,$);return o.success?{value:o.data}:{issues:o.error?.issues}}catch(o){return uv(r,$).then((U)=>U.success?{value:U.data}:{issues:U.error?.issues})}},vendor:"zod",version:1}}),or=w("$ZodString",(r,v)=>{J.init(r,v),r._zod.pattern=[...r?._zod.bag?.patterns??[]].pop()??av(r._zod.bag),r._zod.parse=(c,g)=>{if(v.coerce)try{c.value=String(c.value)}catch($){}if(typeof c.value==="string")return c;return c.issues.push({expected:"string",code:"invalid_type",input:c.value,inst:r}),c}}),Y=w("$ZodStringFormat",(r,v)=>{br.init(r,v),or.init(r,v)}),Ac=w("$ZodGUID",(r,v)=>{v.pattern??(v.pattern=Vv),Y.init(r,v)}),Lc=w("$ZodUUID",(r,v)=>{if(v.version){let g={v1:1,v2:2,v3:3,v4:4,v5:5,v6:6,v7:7,v8:8}[v.version];if(g===void 0)throw Error(`Invalid UUID version: "${v.version}"`);v.pattern??(v.pattern=cr(g))}else v.pattern??(v.pattern=cr());Y.init(r,v)}),Qc=w("$ZodEmail",(r,v)=>{v.pattern??(v.pattern=mv),Y.init(r,v)}),Yc=w("$ZodURL",(r,v)=>{Y.init(r,v),r._zod.check=(c)=>{try{let g=c.value.trim(),$=new URL(g);if(v.hostname){if(v.hostname.lastIndex=0,!v.hostname.test($.hostname))c.issues.push({code:"invalid_format",format:"url",note:"Invalid hostname",pattern:hv.source,input:c.value,inst:r,continue:!v.abort})}if(v.protocol){if(v.protocol.lastIndex=0,!v.protocol.test($.protocol.endsWith(":")?$.protocol.slice(0,-1):$.protocol))c.issues.push({code:"invalid_format",format:"url",note:"Invalid protocol",pattern:v.protocol.source,input:c.value,inst:r,continue:!v.abort})}if(v.normalize)c.value=$.href;else c.value=g;return}catch(g){c.issues.push({code:"invalid_format",format:"url",input:c.value,inst:r,continue:!v.abort})}}}),uc=w("$ZodEmoji",(r,v)=>{v.pattern??(v.pattern=Rv()),Y.init(r,v)}),Hc=w("$ZodNanoID",(r,v)=>{v.pattern??(v.pattern=Ev),Y.init(r,v)}),Nc=w("$ZodCUID",(r,v)=>{v.pattern??(v.pattern=Hv),Y.init(r,v)}),Bc=w("$ZodCUID2",(r,v)=>{v.pattern??(v.pattern=Nv),Y.init(r,v)}),Mc=w("$ZodULID",(r,v)=>{v.pattern??(v.pattern=Bv),Y.init(r,v)}),tc=w("$ZodXID",(r,v)=>{v.pattern??(v.pattern=Mv),Y.init(r,v)}),Ec=w("$ZodKSUID",(r,v)=>{v.pattern??(v.pattern=tv),Y.init(r,v)}),Fc=w("$ZodISODateTime",(r,v)=>{v.pattern??(v.pattern=dv(v)),Y.init(r,v)}),Vc=w("$ZodISODate",(r,v)=>{v.pattern??(v.pattern=yv),Y.init(r,v)}),mc=w("$ZodISOTime",(r,v)=>{v.pattern??(v.pattern=pv(v)),Y.init(r,v)}),Rc=w("$ZodISODuration",(r,v)=>{v.pattern??(v.pattern=Fv),Y.init(r,v)}),Tc=w("$ZodIPv4",(r,v)=>{v.pattern??(v.pattern=Tv),Y.init(r,v),r._zod.onattach.push((c)=>{let g=c._zod.bag;g.format="ipv4"})}),lc=w("$ZodIPv6",(r,v)=>{v.pattern??(v.pattern=lv),Y.init(r,v),r._zod.onattach.push((c)=>{let g=c._zod.bag;g.format="ipv6"}),r._zod.check=(c)=>{try{new URL(`http://[${c.value}]`)}catch{c.issues.push({code:"invalid_format",format:"ipv6",input:c.value,inst:r,continue:!v.abort})}}}),Zc=w("$ZodCIDRv4",(r,v)=>{v.pattern??(v.pattern=Zv),Y.init(r,v)}),qc=w("$ZodCIDRv6",(r,v)=>{v.pattern??(v.pattern=qv),Y.init(r,v),r._zod.check=(c)=>{let[g,$]=c.value.split("/");try{if(!$)throw Error();let o=Number($);if(`${o}`!==$)throw Error();if(o<0||o>128)throw Error();new URL(`http://[${g}]`)}catch{c.issues.push({code:"invalid_format",format:"cidrv6",input:c.value,inst:r,continue:!v.abort})}}});function Cc(r){if(r==="")return!0;if(r.length%4!==0)return!1;try{return atob(r),!0}catch{return!1}}var hc=w("$ZodBase64",(r,v)=>{v.pattern??(v.pattern=Cv),Y.init(r,v),r._zod.onattach.push((c)=>{c._zod.bag.contentEncoding="base64"}),r._zod.check=(c)=>{if(Cc(c.value))return;c.issues.push({code:"invalid_format",format:"base64",input:c.value,inst:r,continue:!v.abort})}});function N6(r){if(!x$.test(r))return!1;let v=r.replace(/[-_]/g,(g)=>g==="-"?"+":"/"),c=v.padEnd(Math.ceil(v.length/4)*4,"=");return Cc(c)}var fc=w("$ZodBase64URL",(r,v)=>{v.pattern??(v.pattern=x$),Y.init(r,v),r._zod.onattach.push((c)=>{c._zod.bag.contentEncoding="base64url"}),r._zod.check=(c)=>{if(N6(c.value))return;c.issues.push({code:"invalid_format",format:"base64url",input:c.value,inst:r,continue:!v.abort})}}),yc=w("$ZodE164",(r,v)=>{v.pattern??(v.pattern=fv),Y.init(r,v)});function B6(r,v=null){try{let c=r.split(".");if(c.length!==3)return!1;let[g]=c;if(!g)return!1;let $=JSON.parse(atob(g));if("typ"in $&&$?.typ!=="JWT")return!1;if(!$.alg)return!1;if(v&&(!("alg"in $)||$.alg!==v))return!1;return!0}catch{return!1}}var pc=w("$ZodJWT",(r,v)=>{Y.init(r,v),r._zod.check=(c)=>{if(B6(c.value,v.alg))return;c.issues.push({code:"invalid_format",format:"jwt",input:c.value,inst:r,continue:!v.abort})}}),dc=w("$ZodCustomStringFormat",(r,v)=>{Y.init(r,v),r._zod.check=(c)=>{if(v.fn(c.value))return;c.issues.push({code:"invalid_format",format:v.format,input:c.value,inst:r,continue:!v.abort})}}),A$=w("$ZodNumber",(r,v)=>{J.init(r,v),r._zod.pattern=r._zod.bag.pattern??rc,r._zod.parse=(c,g)=>{if(v.coerce)try{c.value=Number(c.value)}catch(U){}let $=c.value;if(typeof $==="number"&&!Number.isNaN($)&&Number.isFinite($))return c;let o=typeof $==="number"?Number.isNaN($)?"NaN":!Number.isFinite($)?"Infinity":void 0:void 0;return c.issues.push({expected:"number",code:"invalid_type",input:$,inst:r,...o?{received:o}:{}}),c}}),ac=w("$ZodNumber",(r,v)=>{_c.init(r,v),A$.init(r,v)}),Fr=w("$ZodBoolean",(r,v)=>{J.init(r,v),r._zod.pattern=$c,r._zod.parse=(c,g)=>{if(v.coerce)try{c.value=Boolean(c.value)}catch(o){}let $=c.value;if(typeof $==="boolean")return c;return c.issues.push({expected:"boolean",code:"invalid_type",input:$,inst:r}),c}}),L$=w("$ZodBigInt",(r,v)=>{J.init(r,v),r._zod.pattern=ev,r._zod.parse=(c,g)=>{if(v.coerce)try{c.value=BigInt(c.value)}catch($){}if(typeof c.value==="bigint")return c;return c.issues.push({expected:"bigint",code:"invalid_type",input:c.value,inst:r}),c}}),ec=w("$ZodBigInt",(r,v)=>{wc.init(r,v),L$.init(r,v)}),sc=w("$ZodSymbol",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{let $=c.value;if(typeof $==="symbol")return c;return c.issues.push({expected:"symbol",code:"invalid_type",input:$,inst:r}),c}}),ro=w("$ZodUndefined",(r,v)=>{J.init(r,v),r._zod.pattern=cc,r._zod.values=new Set([void 0]),r._zod.optin="optional",r._zod.optout="optional",r._zod.parse=(c,g)=>{let $=c.value;if(typeof $>"u")return c;return c.issues.push({expected:"undefined",code:"invalid_type",input:$,inst:r}),c}}),$o=w("$ZodNull",(r,v)=>{J.init(r,v),r._zod.pattern=vc,r._zod.values=new Set([null]),r._zod.parse=(c,g)=>{let $=c.value;if($===null)return c;return c.issues.push({expected:"null",code:"invalid_type",input:$,inst:r}),c}}),vo=w("$ZodAny",(r,v)=>{J.init(r,v),r._zod.parse=(c)=>c}),Dr=w("$ZodUnknown",(r,v)=>{J.init(r,v),r._zod.parse=(c)=>c}),co=w("$ZodNever",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{return c.issues.push({expected:"never",code:"invalid_type",input:c.value,inst:r}),c}}),oo=w("$ZodVoid",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{let $=c.value;if(typeof $>"u")return c;return c.issues.push({expected:"void",code:"invalid_type",input:$,inst:r}),c}}),go=w("$ZodDate",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{if(v.coerce)try{c.value=new Date(c.value)}catch(_){}let $=c.value,o=$ instanceof Date;if(o&&!Number.isNaN($.getTime()))return c;return c.issues.push({expected:"date",code:"invalid_type",input:$,...o?{received:"Invalid Date"}:{},inst:r}),c}});function J6(r,v,c){if(r.issues.length)v.issues.push(...m(c,r.issues));v.value[c]=r.value}var Vr=w("$ZodArray",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{let $=c.value;if(!Array.isArray($))return c.issues.push({expected:"array",code:"invalid_type",input:$,inst:r}),c;c.value=Array($.length);let o=[];for(let U=0;U<$.length;U++){let _=$[U],j=v.element._zod.run({value:_,issues:[]},g);if(j instanceof Promise)o.push(j.then((n)=>J6(n,c,U)));else J6(j,c,U)}if(o.length)return Promise.all(o).then(()=>c);return c}});function K$(r,v,c,g){if(r.issues.length)v.issues.push(...m(c,r.issues));if(r.value===void 0){if(c in g)v.value[c]=void 0}else v.value[c]=r.value}var Uo=w("$ZodObject",(r,v)=>{J.init(r,v);let c=Yr(()=>{let P=Object.keys(v.shape);for(let O of P)if(!(v.shape[O]instanceof J))throw Error(`Invalid element at key "${O}": expected a Zod schema`);let b=Kv(v.shape);return{shape:v.shape,keys:P,keySet:new Set(P),numKeys:P.length,optionalKeys:new Set(b)}});K(r._zod,"propValues",()=>{let P=v.shape,b={};for(let O in P){let I=P[O]._zod;if(I.values){b[O]??(b[O]=new Set);for(let x of I.values)b[O].add(x)}}return b});let g=(P)=>{let b=new W$(["shape","payload","ctx"]),O=c.value,I=(L)=>{let Q=k$(L);return`shape[${Q}]._zod.run({ value: input[${Q}], issues: [] }, ctx)`};b.write("const input = payload.value;");let x=Object.create(null),G=0;for(let L of O.keys)x[L]=`key_${G++}`;b.write("const newResult = {}");for(let L of O.keys){let Q=x[L],t=k$(L);b.write(`const ${Q} = ${I(L)};`),b.write(`
|
|
5
|
+
if (${Q}.issues.length) {
|
|
6
|
+
payload.issues = payload.issues.concat(${Q}.issues.map(iss => ({
|
|
7
|
+
...iss,
|
|
8
|
+
path: iss.path ? [${t}, ...iss.path] : [${t}]
|
|
9
|
+
})));
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
if (${Q}.value === undefined) {
|
|
13
|
+
if (${t} in input) {
|
|
14
|
+
newResult[${t}] = undefined;
|
|
1246
15
|
}
|
|
16
|
+
} else {
|
|
17
|
+
newResult[${t}] = ${Q}.value;
|
|
1247
18
|
}
|
|
1248
|
-
}
|
|
1249
|
-
}
|
|
1250
|
-
const granted = matchedPermissions.length > 0;
|
|
1251
|
-
return {
|
|
1252
|
-
granted,
|
|
1253
|
-
reason: granted ? void 0 : "No matching permissions found",
|
|
1254
|
-
matchedPermissions,
|
|
1255
|
-
deniedReasons: granted ? [] : deniedReasons
|
|
1256
|
-
};
|
|
1257
|
-
}
|
|
1258
|
-
doesPermissionMatch(permission, check) {
|
|
1259
|
-
return permission.resource === check.resource && permission.action === check.action;
|
|
1260
|
-
}
|
|
1261
|
-
async checkConditions(permission, check) {
|
|
1262
|
-
if (!permission.conditions || permission.conditions.length === 0) {
|
|
1263
|
-
return true;
|
|
1264
|
-
}
|
|
1265
|
-
for (const condition of permission.conditions) {
|
|
1266
|
-
if (!await this.evaluateCondition(condition, check)) {
|
|
1267
|
-
return false;
|
|
1268
|
-
}
|
|
1269
|
-
}
|
|
1270
|
-
return true;
|
|
1271
|
-
}
|
|
1272
|
-
async evaluateCondition(condition, check) {
|
|
1273
|
-
let actualValue;
|
|
1274
|
-
switch (condition.field) {
|
|
1275
|
-
case "userId":
|
|
1276
|
-
actualValue = check.userId;
|
|
1277
|
-
break;
|
|
1278
|
-
case "organizationId":
|
|
1279
|
-
actualValue = check.context?.organizationId;
|
|
1280
|
-
break;
|
|
1281
|
-
case "teamId":
|
|
1282
|
-
actualValue = check.context?.teamId;
|
|
1283
|
-
break;
|
|
1284
|
-
case "resourceOwnerId":
|
|
1285
|
-
actualValue = check.context?.resourceOwnerId;
|
|
1286
|
-
break;
|
|
1287
|
-
default:
|
|
1288
|
-
actualValue = check.context?.metadata?.[condition.field];
|
|
1289
|
-
}
|
|
1290
|
-
switch (condition.operator) {
|
|
1291
|
-
case "equals":
|
|
1292
|
-
return actualValue === condition.value;
|
|
1293
|
-
case "not_equals":
|
|
1294
|
-
return actualValue !== condition.value;
|
|
1295
|
-
case "in":
|
|
1296
|
-
return Array.isArray(condition.value) && condition.value.includes(actualValue);
|
|
1297
|
-
case "not_in":
|
|
1298
|
-
return Array.isArray(condition.value) && !condition.value.includes(actualValue);
|
|
1299
|
-
case "contains":
|
|
1300
|
-
return String(actualValue).includes(String(condition.value));
|
|
1301
|
-
case "starts_with":
|
|
1302
|
-
return String(actualValue).startsWith(String(condition.value));
|
|
1303
|
-
default:
|
|
1304
|
-
return false;
|
|
1305
|
-
}
|
|
1306
|
-
}
|
|
1307
|
-
initializeSystemRoles() {
|
|
1308
|
-
const superAdminRole = {
|
|
1309
|
-
id: "super-admin",
|
|
1310
|
-
name: "Super Admin",
|
|
1311
|
-
description: "Full system access",
|
|
1312
|
-
isSystem: true,
|
|
1313
|
-
permissions: [
|
|
1314
|
-
// Global permissions for all resources and actions
|
|
1315
|
-
...Object.values(ResourceType).flatMap(
|
|
1316
|
-
(resource) => Object.values(ActionType).map((action) => ({
|
|
1317
|
-
id: `super-admin-${resource}-${action}`,
|
|
1318
|
-
resource,
|
|
1319
|
-
action,
|
|
1320
|
-
scope: "global" /* GLOBAL */
|
|
1321
|
-
}))
|
|
1322
|
-
)
|
|
1323
|
-
],
|
|
1324
|
-
createdAt: /* @__PURE__ */ new Date(),
|
|
1325
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
1326
|
-
};
|
|
1327
|
-
const channelAdminRole = {
|
|
1328
|
-
id: "channel-admin",
|
|
1329
|
-
name: "Channel Admin",
|
|
1330
|
-
description: "Manage channels and sender numbers",
|
|
1331
|
-
isSystem: true,
|
|
1332
|
-
permissions: [
|
|
1333
|
-
{
|
|
1334
|
-
id: "channel-admin-channel-manage",
|
|
1335
|
-
resource: "channel" /* CHANNEL */,
|
|
1336
|
-
action: "manage" /* MANAGE */,
|
|
1337
|
-
scope: "organization" /* ORGANIZATION */
|
|
1338
|
-
},
|
|
1339
|
-
{
|
|
1340
|
-
id: "channel-admin-sender-manage",
|
|
1341
|
-
resource: "senderNumber" /* SENDER_NUMBER */,
|
|
1342
|
-
action: "manage" /* MANAGE */,
|
|
1343
|
-
scope: "organization" /* ORGANIZATION */
|
|
1344
|
-
}
|
|
1345
|
-
],
|
|
1346
|
-
createdAt: /* @__PURE__ */ new Date(),
|
|
1347
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
1348
|
-
};
|
|
1349
|
-
const messageSenderRole = {
|
|
1350
|
-
id: "message-sender",
|
|
1351
|
-
name: "Message Sender",
|
|
1352
|
-
description: "Send messages using configured channels",
|
|
1353
|
-
isSystem: true,
|
|
1354
|
-
permissions: [
|
|
1355
|
-
{
|
|
1356
|
-
id: "message-sender-channel-read",
|
|
1357
|
-
resource: "channel" /* CHANNEL */,
|
|
1358
|
-
action: "read" /* READ */,
|
|
1359
|
-
scope: "organization" /* ORGANIZATION */
|
|
1360
|
-
},
|
|
1361
|
-
{
|
|
1362
|
-
id: "message-sender-message-send",
|
|
1363
|
-
resource: "message" /* MESSAGE */,
|
|
1364
|
-
action: "send" /* SEND */,
|
|
1365
|
-
scope: "organization" /* ORGANIZATION */
|
|
1366
|
-
}
|
|
1367
|
-
],
|
|
1368
|
-
createdAt: /* @__PURE__ */ new Date(),
|
|
1369
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
1370
|
-
};
|
|
1371
|
-
const viewerRole = {
|
|
1372
|
-
id: "viewer",
|
|
1373
|
-
name: "Viewer",
|
|
1374
|
-
description: "Read-only access",
|
|
1375
|
-
isSystem: true,
|
|
1376
|
-
permissions: [
|
|
1377
|
-
{
|
|
1378
|
-
id: "viewer-channel-read",
|
|
1379
|
-
resource: "channel" /* CHANNEL */,
|
|
1380
|
-
action: "read" /* READ */,
|
|
1381
|
-
scope: "organization" /* ORGANIZATION */
|
|
1382
|
-
},
|
|
1383
|
-
{
|
|
1384
|
-
id: "viewer-sender-read",
|
|
1385
|
-
resource: "senderNumber" /* SENDER_NUMBER */,
|
|
1386
|
-
action: "read" /* READ */,
|
|
1387
|
-
scope: "organization" /* ORGANIZATION */
|
|
1388
|
-
},
|
|
1389
|
-
{
|
|
1390
|
-
id: "viewer-analytics-read",
|
|
1391
|
-
resource: "analytics" /* ANALYTICS */,
|
|
1392
|
-
action: "read" /* READ */,
|
|
1393
|
-
scope: "organization" /* ORGANIZATION */
|
|
1394
|
-
}
|
|
1395
|
-
],
|
|
1396
|
-
createdAt: /* @__PURE__ */ new Date(),
|
|
1397
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
1398
|
-
};
|
|
1399
|
-
this.roles.set(superAdminRole.id, superAdminRole);
|
|
1400
|
-
this.roles.set(channelAdminRole.id, channelAdminRole);
|
|
1401
|
-
this.roles.set(messageSenderRole.id, messageSenderRole);
|
|
1402
|
-
this.roles.set(viewerRole.id, viewerRole);
|
|
1403
|
-
}
|
|
1404
|
-
updateUserRoleCache(userId, roleIds) {
|
|
1405
|
-
this.userRoleCache.set(userId, new Set(roleIds));
|
|
1406
|
-
}
|
|
1407
|
-
clearUserPermissionCache(userId) {
|
|
1408
|
-
const keysToDelete = [];
|
|
1409
|
-
for (const key of this.permissionCache.keys()) {
|
|
1410
|
-
if (key.startsWith(`${userId}:`)) {
|
|
1411
|
-
keysToDelete.push(key);
|
|
1412
|
-
}
|
|
1413
|
-
}
|
|
1414
|
-
keysToDelete.forEach((key) => {
|
|
1415
|
-
this.permissionCache.delete(key);
|
|
1416
|
-
this.cacheExpiry.delete(key);
|
|
1417
|
-
});
|
|
1418
|
-
}
|
|
1419
|
-
clearRolePermissionCache(roleId) {
|
|
1420
|
-
for (const [userId, roleIds] of this.userRoleCache) {
|
|
1421
|
-
if (roleIds.has(roleId)) {
|
|
1422
|
-
this.clearUserPermissionCache(userId);
|
|
1423
|
-
}
|
|
1424
|
-
}
|
|
1425
|
-
}
|
|
1426
|
-
getCacheKey(check) {
|
|
1427
|
-
const contextKey = check.context ? JSON.stringify(check.context) : "";
|
|
1428
|
-
return `${check.userId}:${check.resource}:${check.action}:${check.resourceId || ""}:${contextKey}`;
|
|
1429
|
-
}
|
|
1430
|
-
getFromCache(key) {
|
|
1431
|
-
const expiry = this.cacheExpiry.get(key);
|
|
1432
|
-
if (!expiry || expiry < Date.now()) {
|
|
1433
|
-
this.permissionCache.delete(key);
|
|
1434
|
-
this.cacheExpiry.delete(key);
|
|
1435
|
-
return null;
|
|
1436
|
-
}
|
|
1437
|
-
return this.permissionCache.get(key) || null;
|
|
1438
|
-
}
|
|
1439
|
-
setCache(key, result) {
|
|
1440
|
-
this.permissionCache.set(key, result);
|
|
1441
|
-
this.cacheExpiry.set(key, Date.now() + this.CACHE_DURATION);
|
|
1442
|
-
}
|
|
1443
|
-
generateUserId() {
|
|
1444
|
-
return `user_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
|
|
1445
|
-
}
|
|
1446
|
-
generateRoleId() {
|
|
1447
|
-
return `role_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
|
|
1448
|
-
}
|
|
1449
|
-
};
|
|
1450
|
-
|
|
1451
|
-
// src/verification/business.verify.ts
|
|
1452
|
-
import { EventEmitter as EventEmitter3 } from "events";
|
|
1453
|
-
var BusinessVerifier = class extends EventEmitter3 {
|
|
1454
|
-
constructor(options = {}) {
|
|
1455
|
-
super();
|
|
1456
|
-
this.options = options;
|
|
1457
|
-
this.verificationRequests = /* @__PURE__ */ new Map();
|
|
1458
|
-
this.documentValidators = /* @__PURE__ */ new Map();
|
|
1459
|
-
this.defaultOptions = {
|
|
1460
|
-
enableAutoVerification: true,
|
|
1461
|
-
requiredDocuments: ["BUSINESS_REGISTRATION" /* BUSINESS_REGISTRATION */],
|
|
1462
|
-
autoApprovalThreshold: 80,
|
|
1463
|
-
requireManualReview: false,
|
|
1464
|
-
documentRetentionDays: 365,
|
|
1465
|
-
enableExternalAPIs: false
|
|
1466
|
-
};
|
|
1467
|
-
this.options = { ...this.defaultOptions, ...options };
|
|
1468
|
-
this.initializeDocumentValidators();
|
|
1469
|
-
}
|
|
1470
|
-
/**
|
|
1471
|
-
* Submit business verification request
|
|
1472
|
-
*/
|
|
1473
|
-
async submitVerification(channelId, businessInfo, documents) {
|
|
1474
|
-
const requestId = this.generateRequestId();
|
|
1475
|
-
this.validateRequiredDocuments(documents);
|
|
1476
|
-
const verificationRequest = {
|
|
1477
|
-
id: requestId,
|
|
1478
|
-
channelId,
|
|
1479
|
-
businessInfo,
|
|
1480
|
-
documents: documents.map((doc) => ({
|
|
1481
|
-
...doc,
|
|
1482
|
-
status: "UPLOADED" /* UPLOADED */
|
|
1483
|
-
})),
|
|
1484
|
-
status: "PENDING" /* PENDING */,
|
|
1485
|
-
submittedAt: /* @__PURE__ */ new Date()
|
|
1486
|
-
};
|
|
1487
|
-
this.verificationRequests.set(requestId, verificationRequest);
|
|
1488
|
-
this.emit("verification:submitted", { verificationRequest });
|
|
1489
|
-
if (this.options.enableAutoVerification) {
|
|
1490
|
-
await this.processAutoVerification(requestId);
|
|
1491
|
-
}
|
|
1492
|
-
return verificationRequest;
|
|
1493
|
-
}
|
|
1494
|
-
/**
|
|
1495
|
-
* Get verification request by ID
|
|
1496
|
-
*/
|
|
1497
|
-
getVerificationRequest(requestId) {
|
|
1498
|
-
return this.verificationRequests.get(requestId) || null;
|
|
1499
|
-
}
|
|
1500
|
-
/**
|
|
1501
|
-
* Get verification request by channel ID
|
|
1502
|
-
*/
|
|
1503
|
-
getVerificationByChannelId(channelId) {
|
|
1504
|
-
for (const request of this.verificationRequests.values()) {
|
|
1505
|
-
if (request.channelId === channelId) {
|
|
1506
|
-
return request;
|
|
1507
|
-
}
|
|
1508
|
-
}
|
|
1509
|
-
return null;
|
|
1510
|
-
}
|
|
1511
|
-
/**
|
|
1512
|
-
* Manually approve verification
|
|
1513
|
-
*/
|
|
1514
|
-
async approveVerification(requestId, reviewerId, notes) {
|
|
1515
|
-
const request = this.verificationRequests.get(requestId);
|
|
1516
|
-
if (!request) {
|
|
1517
|
-
throw new Error("Verification request not found");
|
|
1518
|
-
}
|
|
1519
|
-
request.status = "VERIFIED" /* VERIFIED */;
|
|
1520
|
-
request.reviewedAt = /* @__PURE__ */ new Date();
|
|
1521
|
-
request.reviewedBy = reviewerId;
|
|
1522
|
-
request.reviewNotes = notes;
|
|
1523
|
-
request.documents.forEach((doc) => {
|
|
1524
|
-
doc.status = "VERIFIED" /* VERIFIED */;
|
|
1525
|
-
});
|
|
1526
|
-
this.emit("verification:approved", { verificationRequest: request, reviewerId });
|
|
1527
|
-
return request;
|
|
1528
|
-
}
|
|
1529
|
-
/**
|
|
1530
|
-
* Manually reject verification
|
|
1531
|
-
*/
|
|
1532
|
-
async rejectVerification(requestId, reviewerId, reason) {
|
|
1533
|
-
const request = this.verificationRequests.get(requestId);
|
|
1534
|
-
if (!request) {
|
|
1535
|
-
throw new Error("Verification request not found");
|
|
1536
|
-
}
|
|
1537
|
-
request.status = "REJECTED" /* REJECTED */;
|
|
1538
|
-
request.reviewedAt = /* @__PURE__ */ new Date();
|
|
1539
|
-
request.reviewedBy = reviewerId;
|
|
1540
|
-
request.reviewNotes = reason;
|
|
1541
|
-
request.documents.forEach((doc) => {
|
|
1542
|
-
if (doc.status === "UPLOADED" /* UPLOADED */) {
|
|
1543
|
-
doc.status = "REJECTED" /* REJECTED */;
|
|
1544
|
-
}
|
|
1545
|
-
});
|
|
1546
|
-
this.emit("verification:rejected", { verificationRequest: request, reviewerId, reason });
|
|
1547
|
-
return request;
|
|
1548
|
-
}
|
|
1549
|
-
/**
|
|
1550
|
-
* Update verification request with additional documents
|
|
1551
|
-
*/
|
|
1552
|
-
async addDocument(requestId, document) {
|
|
1553
|
-
const request = this.verificationRequests.get(requestId);
|
|
1554
|
-
if (!request) {
|
|
1555
|
-
throw new Error("Verification request not found");
|
|
1556
|
-
}
|
|
1557
|
-
if (request.status !== "PENDING" /* PENDING */ && request.status !== "UNDER_REVIEW" /* UNDER_REVIEW */) {
|
|
1558
|
-
throw new Error("Cannot add documents to completed verification");
|
|
1559
|
-
}
|
|
1560
|
-
document.status = "UPLOADED" /* UPLOADED */;
|
|
1561
|
-
request.documents.push(document);
|
|
1562
|
-
if (this.options.enableAutoVerification) {
|
|
1563
|
-
await this.processAutoVerification(requestId);
|
|
1564
|
-
}
|
|
1565
|
-
this.emit("verification:document_added", { verificationRequest: request, document });
|
|
1566
|
-
return request;
|
|
1567
|
-
}
|
|
1568
|
-
/**
|
|
1569
|
-
* List verification requests with filters
|
|
1570
|
-
*/
|
|
1571
|
-
listVerificationRequests(filters) {
|
|
1572
|
-
let requests = Array.from(this.verificationRequests.values());
|
|
1573
|
-
if (filters?.status) {
|
|
1574
|
-
requests = requests.filter((r) => r.status === filters.status);
|
|
1575
|
-
}
|
|
1576
|
-
if (filters?.channelId) {
|
|
1577
|
-
requests = requests.filter((r) => r.channelId === filters.channelId);
|
|
1578
|
-
}
|
|
1579
|
-
if (filters?.submittedAfter) {
|
|
1580
|
-
requests = requests.filter((r) => r.submittedAt >= filters.submittedAfter);
|
|
1581
|
-
}
|
|
1582
|
-
if (filters?.submittedBefore) {
|
|
1583
|
-
requests = requests.filter((r) => r.submittedAt <= filters.submittedBefore);
|
|
1584
|
-
}
|
|
1585
|
-
return requests.sort((a, b) => b.submittedAt.getTime() - a.submittedAt.getTime());
|
|
1586
|
-
}
|
|
1587
|
-
/**
|
|
1588
|
-
* Get verification statistics
|
|
1589
|
-
*/
|
|
1590
|
-
getVerificationStats() {
|
|
1591
|
-
const requests = Array.from(this.verificationRequests.values());
|
|
1592
|
-
const byStatus = {};
|
|
1593
|
-
let totalProcessingTime = 0;
|
|
1594
|
-
let processedCount = 0;
|
|
1595
|
-
let autoApprovedCount = 0;
|
|
1596
|
-
requests.forEach((request) => {
|
|
1597
|
-
byStatus[request.status] = (byStatus[request.status] || 0) + 1;
|
|
1598
|
-
if (request.reviewedAt) {
|
|
1599
|
-
const processingTime = request.reviewedAt.getTime() - request.submittedAt.getTime();
|
|
1600
|
-
totalProcessingTime += processingTime;
|
|
1601
|
-
processedCount++;
|
|
1602
|
-
if (!request.reviewedBy && request.status === "VERIFIED" /* VERIFIED */) {
|
|
1603
|
-
autoApprovedCount++;
|
|
1604
|
-
}
|
|
1605
|
-
}
|
|
1606
|
-
});
|
|
1607
|
-
return {
|
|
1608
|
-
total: requests.length,
|
|
1609
|
-
byStatus,
|
|
1610
|
-
averageProcessingTime: processedCount > 0 ? totalProcessingTime / processedCount : 0,
|
|
1611
|
-
autoApprovalRate: processedCount > 0 ? autoApprovedCount / processedCount * 100 : 0
|
|
1612
|
-
};
|
|
1613
|
-
}
|
|
1614
|
-
// Private Methods
|
|
1615
|
-
async processAutoVerification(requestId) {
|
|
1616
|
-
const request = this.verificationRequests.get(requestId);
|
|
1617
|
-
if (!request) return;
|
|
1618
|
-
request.status = "UNDER_REVIEW" /* UNDER_REVIEW */;
|
|
1619
|
-
this.emit("verification:auto_processing_started", { verificationRequest: request });
|
|
1620
|
-
const autoResults = [];
|
|
1621
|
-
try {
|
|
1622
|
-
const businessCheck = await this.verifyBusinessRegistration(request.businessInfo);
|
|
1623
|
-
autoResults.push(businessCheck);
|
|
1624
|
-
for (const document of request.documents) {
|
|
1625
|
-
const docValidation = await this.validateDocument(document);
|
|
1626
|
-
autoResults.push({
|
|
1627
|
-
checkType: "document_validation",
|
|
1628
|
-
status: docValidation.isValid ? "passed" : "failed",
|
|
1629
|
-
score: docValidation.confidence,
|
|
1630
|
-
details: `Document validation: ${docValidation.issues.length} issues found`,
|
|
1631
|
-
metadata: { documentId: document.id, issues: docValidation.issues }
|
|
1632
|
-
});
|
|
1633
|
-
}
|
|
1634
|
-
const addressCheck = await this.verifyAddress(request.businessInfo.address);
|
|
1635
|
-
autoResults.push(addressCheck);
|
|
1636
|
-
const phoneCheck = await this.verifyPhoneNumber(request.businessInfo.contactInfo.phoneNumber);
|
|
1637
|
-
autoResults.push(phoneCheck);
|
|
1638
|
-
request.autoVerificationResults = autoResults;
|
|
1639
|
-
const overallScore = autoResults.reduce((sum, result) => sum + result.score, 0) / autoResults.length;
|
|
1640
|
-
if (overallScore >= this.options.autoApprovalThreshold && !this.options.requireManualReview) {
|
|
1641
|
-
request.status = "VERIFIED" /* VERIFIED */;
|
|
1642
|
-
request.reviewedAt = /* @__PURE__ */ new Date();
|
|
1643
|
-
request.reviewNotes = `Auto-approved with score: ${overallScore.toFixed(1)}`;
|
|
1644
|
-
request.documents.forEach((doc) => {
|
|
1645
|
-
doc.status = "VERIFIED" /* VERIFIED */;
|
|
1646
|
-
});
|
|
1647
|
-
this.emit("verification:auto_approved", { verificationRequest: request, score: overallScore });
|
|
1648
|
-
} else {
|
|
1649
|
-
this.emit("verification:manual_review_required", { verificationRequest: request, score: overallScore });
|
|
1650
|
-
}
|
|
1651
|
-
} catch (error) {
|
|
1652
|
-
request.status = "PENDING" /* PENDING */;
|
|
1653
|
-
this.emit("verification:auto_processing_failed", {
|
|
1654
|
-
verificationRequest: request,
|
|
1655
|
-
error: error instanceof Error ? error.message : "Unknown error"
|
|
1656
|
-
});
|
|
1657
|
-
}
|
|
1658
|
-
}
|
|
1659
|
-
validateRequiredDocuments(documents) {
|
|
1660
|
-
const providedTypes = new Set(documents.map((doc) => doc.type));
|
|
1661
|
-
const missingTypes = this.options.requiredDocuments.filter((type) => !providedTypes.has(type));
|
|
1662
|
-
if (missingTypes.length > 0) {
|
|
1663
|
-
throw new Error(`Missing required documents: ${missingTypes.join(", ")}`);
|
|
1664
|
-
}
|
|
1665
|
-
}
|
|
1666
|
-
async verifyBusinessRegistration(businessInfo) {
|
|
1667
|
-
const score = this.calculateBusinessRegistrationScore(businessInfo);
|
|
1668
|
-
return {
|
|
1669
|
-
checkType: "business_registry",
|
|
1670
|
-
status: score >= 70 ? "passed" : score >= 50 ? "warning" : "failed",
|
|
1671
|
-
score,
|
|
1672
|
-
details: `Business registration verification completed`,
|
|
1673
|
-
metadata: {
|
|
1674
|
-
businessName: businessInfo.businessName,
|
|
1675
|
-
registrationNumber: businessInfo.businessRegistrationNumber
|
|
1676
|
-
}
|
|
1677
|
-
};
|
|
1678
|
-
}
|
|
1679
|
-
calculateBusinessRegistrationScore(businessInfo) {
|
|
1680
|
-
let score = 0;
|
|
1681
|
-
if (/^\d{3}-\d{2}-\d{5}$/.test(businessInfo.businessRegistrationNumber)) {
|
|
1682
|
-
score += 30;
|
|
1683
|
-
}
|
|
1684
|
-
if (businessInfo.businessName.length >= 2 && businessInfo.businessName.length <= 100) {
|
|
1685
|
-
score += 20;
|
|
1686
|
-
}
|
|
1687
|
-
const now = /* @__PURE__ */ new Date();
|
|
1688
|
-
const establishedDate = new Date(businessInfo.establishedDate);
|
|
1689
|
-
const yearsOld = (now.getTime() - establishedDate.getTime()) / (1e3 * 60 * 60 * 24 * 365);
|
|
1690
|
-
if (yearsOld >= 0 && yearsOld <= 100) {
|
|
1691
|
-
score += 20;
|
|
1692
|
-
}
|
|
1693
|
-
if (businessInfo.contactInfo.email && businessInfo.contactInfo.phoneNumber) {
|
|
1694
|
-
score += 15;
|
|
1695
|
-
}
|
|
1696
|
-
if (businessInfo.address.street && businessInfo.address.city && businessInfo.address.postalCode) {
|
|
1697
|
-
score += 15;
|
|
1698
|
-
}
|
|
1699
|
-
return Math.min(100, score);
|
|
1700
|
-
}
|
|
1701
|
-
async validateDocument(document) {
|
|
1702
|
-
const validator = this.documentValidators.get(document.type);
|
|
1703
|
-
if (!validator) {
|
|
1704
|
-
return {
|
|
1705
|
-
isValid: false,
|
|
1706
|
-
confidence: 0,
|
|
1707
|
-
issues: [{
|
|
1708
|
-
type: "format",
|
|
1709
|
-
severity: "critical",
|
|
1710
|
-
message: `No validator available for document type: ${document.type}`
|
|
1711
|
-
}]
|
|
1712
|
-
};
|
|
1713
|
-
}
|
|
1714
|
-
return await validator(document);
|
|
1715
|
-
}
|
|
1716
|
-
async verifyAddress(address) {
|
|
1717
|
-
let score = 0;
|
|
1718
|
-
if (address.street && address.city && address.postalCode) {
|
|
1719
|
-
score += 40;
|
|
1720
|
-
}
|
|
1721
|
-
if (/^\d{5}$/.test(address.postalCode)) {
|
|
1722
|
-
score += 30;
|
|
1723
|
-
}
|
|
1724
|
-
if (address.country === "KR" || address.country === "Korea") {
|
|
1725
|
-
score += 30;
|
|
1726
|
-
}
|
|
1727
|
-
return {
|
|
1728
|
-
checkType: "address_verification",
|
|
1729
|
-
status: score >= 70 ? "passed" : score >= 50 ? "warning" : "failed",
|
|
1730
|
-
score,
|
|
1731
|
-
details: "Address verification completed",
|
|
1732
|
-
metadata: { address }
|
|
1733
|
-
};
|
|
1734
|
-
}
|
|
1735
|
-
async verifyPhoneNumber(phoneNumber) {
|
|
1736
|
-
const isValidFormat = /^(010|011|016|017|018|019)[0-9]{7,8}$/.test(phoneNumber);
|
|
1737
|
-
const score = isValidFormat ? 100 : 0;
|
|
1738
|
-
return {
|
|
1739
|
-
checkType: "phone_verification",
|
|
1740
|
-
status: isValidFormat ? "passed" : "failed",
|
|
1741
|
-
score,
|
|
1742
|
-
details: isValidFormat ? "Phone number format is valid" : "Invalid phone number format",
|
|
1743
|
-
metadata: { phoneNumber }
|
|
1744
|
-
};
|
|
1745
|
-
}
|
|
1746
|
-
initializeDocumentValidators() {
|
|
1747
|
-
this.documentValidators.set("BUSINESS_REGISTRATION" /* BUSINESS_REGISTRATION */, async (doc) => {
|
|
1748
|
-
const issues = [];
|
|
1749
|
-
let confidence = 80;
|
|
1750
|
-
if (!doc.fileName.match(/\.(pdf|jpg|jpeg|png)$/i)) {
|
|
1751
|
-
issues.push({
|
|
1752
|
-
type: "format",
|
|
1753
|
-
severity: "medium",
|
|
1754
|
-
message: "Unsupported file format"
|
|
1755
|
-
});
|
|
1756
|
-
confidence -= 20;
|
|
1757
|
-
}
|
|
1758
|
-
return {
|
|
1759
|
-
isValid: issues.length === 0 || issues.every((i) => i.severity !== "critical"),
|
|
1760
|
-
confidence: Math.max(0, confidence),
|
|
1761
|
-
issues
|
|
1762
|
-
};
|
|
1763
|
-
});
|
|
1764
|
-
this.documentValidators.set("BUSINESS_LICENSE" /* BUSINESS_LICENSE */, async (doc) => {
|
|
1765
|
-
const issues = [];
|
|
1766
|
-
let confidence = 75;
|
|
1767
|
-
if (!doc.fileName.match(/\.(pdf|jpg|jpeg|png)$/i)) {
|
|
1768
|
-
issues.push({
|
|
1769
|
-
type: "format",
|
|
1770
|
-
severity: "medium",
|
|
1771
|
-
message: "Unsupported file format"
|
|
1772
|
-
});
|
|
1773
|
-
confidence -= 15;
|
|
1774
|
-
}
|
|
1775
|
-
return {
|
|
1776
|
-
isValid: issues.length === 0 || issues.every((i) => i.severity !== "critical"),
|
|
1777
|
-
confidence: Math.max(0, confidence),
|
|
1778
|
-
issues
|
|
1779
|
-
};
|
|
1780
|
-
});
|
|
1781
|
-
this.documentValidators.set("ID_CARD" /* ID_CARD */, async (doc) => {
|
|
1782
|
-
const issues = [];
|
|
1783
|
-
let confidence = 70;
|
|
1784
|
-
if (!doc.fileName.match(/\.(jpg|jpeg|png)$/i)) {
|
|
1785
|
-
issues.push({
|
|
1786
|
-
type: "format",
|
|
1787
|
-
severity: "high",
|
|
1788
|
-
message: "ID card should be an image file"
|
|
1789
|
-
});
|
|
1790
|
-
confidence -= 30;
|
|
1791
|
-
}
|
|
1792
|
-
return {
|
|
1793
|
-
isValid: issues.length === 0 || issues.every((i) => i.severity !== "critical"),
|
|
1794
|
-
confidence: Math.max(0, confidence),
|
|
1795
|
-
issues
|
|
1796
|
-
};
|
|
1797
|
-
});
|
|
1798
|
-
const defaultValidator = async (doc) => {
|
|
1799
|
-
const issues = [];
|
|
1800
|
-
let confidence = 60;
|
|
1801
|
-
if (!doc.fileName || doc.fileName.length === 0) {
|
|
1802
|
-
issues.push({
|
|
1803
|
-
type: "format",
|
|
1804
|
-
severity: "critical",
|
|
1805
|
-
message: "File name is required"
|
|
1806
|
-
});
|
|
1807
|
-
confidence = 0;
|
|
1808
|
-
}
|
|
1809
|
-
return {
|
|
1810
|
-
isValid: issues.length === 0 || issues.every((i) => i.severity !== "critical"),
|
|
1811
|
-
confidence: Math.max(0, confidence),
|
|
1812
|
-
issues
|
|
1813
|
-
};
|
|
1814
|
-
};
|
|
1815
|
-
this.documentValidators.set("AUTHORIZATION_LETTER" /* AUTHORIZATION_LETTER */, defaultValidator);
|
|
1816
|
-
this.documentValidators.set("OTHER" /* OTHER */, defaultValidator);
|
|
1817
|
-
}
|
|
1818
|
-
generateRequestId() {
|
|
1819
|
-
return `biz_verify_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
|
|
1820
|
-
}
|
|
1821
|
-
};
|
|
19
|
+
`)}b.write("payload.value = newResult;"),b.write("return payload;");let A=b.compile();return(L,Q)=>A(P,L,Q)},$,o=Or,U=!Ar.jitless,j=U&&Xv.value,n=v.catchall,k;r._zod.parse=(P,b)=>{k??(k=c.value);let O=P.value;if(!o(O))return P.issues.push({expected:"object",code:"invalid_type",input:O,inst:r}),P;let I=[];if(U&&j&&b?.async===!1&&b.jitless!==!0){if(!$)$=g(v.shape);P=$(P,b)}else{P.value={};let Q=k.shape;for(let t of k.keys){let Dv=Q[t]._zod.run({value:O[t],issues:[]},b);if(Dv instanceof Promise)I.push(Dv.then((tU)=>K$(tU,P,t,O)));else K$(Dv,P,t,O)}}if(!n)return I.length?Promise.all(I).then(()=>P):P;let x=[],G=k.keySet,A=n._zod,L=A.def.type;for(let Q of Object.keys(O)){if(G.has(Q))continue;if(L==="never"){x.push(Q);continue}let t=A.run({value:O[Q],issues:[]},b);if(t instanceof Promise)I.push(t.then((O6)=>K$(O6,P,Q,O)));else K$(t,P,Q,O)}if(x.length)P.issues.push({code:"unrecognized_keys",keys:x,input:O,inst:r});if(!I.length)return P;return Promise.all(I).then(()=>{return P})}});function X6(r,v,c,g){for(let o of r)if(o.issues.length===0)return v.value=o.value,v;let $=r.filter((o)=>!vr(o));if($.length===1)return v.value=$[0].value,$[0];return v.issues.push({code:"invalid_union",input:v.value,inst:c,errors:r.map((o)=>o.issues.map((U)=>R(U,g,B())))}),v}var Q$=w("$ZodUnion",(r,v)=>{J.init(r,v),K(r._zod,"optin",()=>v.options.some(($)=>$._zod.optin==="optional")?"optional":void 0),K(r._zod,"optout",()=>v.options.some(($)=>$._zod.optout==="optional")?"optional":void 0),K(r._zod,"values",()=>{if(v.options.every(($)=>$._zod.values))return new Set(v.options.flatMap(($)=>Array.from($._zod.values)));return}),K(r._zod,"pattern",()=>{if(v.options.every(($)=>$._zod.pattern)){let $=v.options.map((o)=>o._zod.pattern);return new RegExp(`^(${$.map((o)=>ur(o.source)).join("|")})$`)}return});let c=v.options.length===1,g=v.options[0]._zod.run;r._zod.parse=($,o)=>{if(c)return g($,o);let U=!1,_=[];for(let j of v.options){let n=j._zod.run({value:$.value,issues:[]},o);if(n instanceof Promise)_.push(n),U=!0;else{if(n.issues.length===0)return n;_.push(n)}}if(!U)return X6(_,$,r,o);return Promise.all(_).then((j)=>{return X6(j,$,r,o)})}}),_o=w("$ZodDiscriminatedUnion",(r,v)=>{Q$.init(r,v);let c=r._zod.parse;K(r._zod,"propValues",()=>{let $={};for(let o of v.options){let U=o._zod.propValues;if(!U||Object.keys(U).length===0)throw Error(`Invalid discriminated union option at index "${v.options.indexOf(o)}"`);for(let[_,j]of Object.entries(U)){if(!$[_])$[_]=new Set;for(let n of j)$[_].add(n)}}return $});let g=Yr(()=>{let $=v.options,o=new Map;for(let U of $){let _=U._zod.propValues?.[v.discriminator];if(!_||_.size===0)throw Error(`Invalid discriminated union option at index "${v.options.indexOf(U)}"`);for(let j of _){if(o.has(j))throw Error(`Duplicate discriminator value "${String(j)}"`);o.set(j,U)}}return o});r._zod.parse=($,o)=>{let U=$.value;if(!Or(U))return $.issues.push({code:"invalid_type",expected:"object",input:U,inst:r}),$;let _=g.value.get(U?.[v.discriminator]);if(_)return _._zod.run($,o);if(v.unionFallback)return c($,o);return $.issues.push({code:"invalid_union",errors:[],note:"No matching discriminator",discriminator:v.discriminator,input:U,path:[v.discriminator],inst:r}),$}}),wo=w("$ZodIntersection",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{let $=c.value,o=v.left._zod.run({value:$,issues:[]},g),U=v.right._zod.run({value:$,issues:[]},g);if(o instanceof Promise||U instanceof Promise)return Promise.all([o,U]).then(([j,n])=>{return W6(c,j,n)});return W6(c,o,U)}});function Gc(r,v){if(r===v)return{valid:!0,data:r};if(r instanceof Date&&v instanceof Date&&+r===+v)return{valid:!0,data:r};if(kr(r)&&kr(v)){let c=Object.keys(v),g=Object.keys(r).filter((o)=>c.indexOf(o)!==-1),$={...r,...v};for(let o of g){let U=Gc(r[o],v[o]);if(!U.valid)return{valid:!1,mergeErrorPath:[o,...U.mergeErrorPath]};$[o]=U.data}return{valid:!0,data:$}}if(Array.isArray(r)&&Array.isArray(v)){if(r.length!==v.length)return{valid:!1,mergeErrorPath:[]};let c=[];for(let g=0;g<r.length;g++){let $=r[g],o=v[g],U=Gc($,o);if(!U.valid)return{valid:!1,mergeErrorPath:[g,...U.mergeErrorPath]};c.push(U.data)}return{valid:!0,data:c}}return{valid:!1,mergeErrorPath:[]}}function W6(r,v,c){if(v.issues.length)r.issues.push(...v.issues);if(c.issues.length)r.issues.push(...c.issues);if(vr(r))return r;let g=Gc(v.value,c.value);if(!g.valid)throw Error(`Unmergable intersection. Error path: ${JSON.stringify(g.mergeErrorPath)}`);return r.value=g.data,r}var gr=w("$ZodTuple",(r,v)=>{J.init(r,v);let c=v.items,g=c.length-[...c].reverse().findIndex(($)=>$._zod.optin!=="optional");r._zod.parse=($,o)=>{let U=$.value;if(!Array.isArray(U))return $.issues.push({input:U,inst:r,expected:"tuple",code:"invalid_type"}),$;$.value=[];let _=[];if(!v.rest){let n=U.length>c.length,k=U.length<g-1;if(n||k)return $.issues.push({...n?{code:"too_big",maximum:c.length}:{code:"too_small",minimum:c.length},input:U,inst:r,origin:"array"}),$}let j=-1;for(let n of c){if(j++,j>=U.length){if(j>=g)continue}let k=n._zod.run({value:U[j],issues:[]},o);if(k instanceof Promise)_.push(k.then((P)=>G$(P,$,j)));else G$(k,$,j)}if(v.rest){let n=U.slice(c.length);for(let k of n){j++;let P=v.rest._zod.run({value:k,issues:[]},o);if(P instanceof Promise)_.push(P.then((b)=>G$(b,$,j)));else G$(P,$,j)}}if(_.length)return Promise.all(_).then(()=>$);return $}});function G$(r,v,c){if(r.issues.length)v.issues.push(...m(c,r.issues));v.value[c]=r.value}var jo=w("$ZodRecord",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{let $=c.value;if(!kr($))return c.issues.push({expected:"record",code:"invalid_type",input:$,inst:r}),c;let o=[];if(v.keyType._zod.values){let U=v.keyType._zod.values;c.value={};for(let j of U)if(typeof j==="string"||typeof j==="number"||typeof j==="symbol"){let n=v.valueType._zod.run({value:$[j],issues:[]},g);if(n instanceof Promise)o.push(n.then((k)=>{if(k.issues.length)c.issues.push(...m(j,k.issues));c.value[j]=k.value}));else{if(n.issues.length)c.issues.push(...m(j,n.issues));c.value[j]=n.value}}let _;for(let j in $)if(!U.has(j))_=_??[],_.push(j);if(_&&_.length>0)c.issues.push({code:"unrecognized_keys",input:$,inst:r,keys:_})}else{c.value={};for(let U of Reflect.ownKeys($)){if(U==="__proto__")continue;let _=v.keyType._zod.run({value:U,issues:[]},g);if(_ instanceof Promise)throw Error("Async schemas not supported in object keys currently");if(_.issues.length){c.issues.push({code:"invalid_key",origin:"record",issues:_.issues.map((n)=>R(n,g,B())),input:U,path:[U],inst:r}),c.value[_.value]=_.value;continue}let j=v.valueType._zod.run({value:$[U],issues:[]},g);if(j instanceof Promise)o.push(j.then((n)=>{if(n.issues.length)c.issues.push(...m(U,n.issues));c.value[_.value]=n.value}));else{if(j.issues.length)c.issues.push(...m(U,j.issues));c.value[_.value]=j.value}}}if(o.length)return Promise.all(o).then(()=>c);return c}}),Oo=w("$ZodMap",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{let $=c.value;if(!($ instanceof Map))return c.issues.push({expected:"map",code:"invalid_type",input:$,inst:r}),c;let o=[];c.value=new Map;for(let[U,_]of $){let j=v.keyType._zod.run({value:U,issues:[]},g),n=v.valueType._zod.run({value:_,issues:[]},g);if(j instanceof Promise||n instanceof Promise)o.push(Promise.all([j,n]).then(([k,P])=>{K6(k,P,c,U,$,r,g)}));else K6(j,n,c,U,$,r,g)}if(o.length)return Promise.all(o).then(()=>c);return c}});function K6(r,v,c,g,$,o,U){if(r.issues.length)if(Hr.has(typeof g))c.issues.push(...m(g,r.issues));else c.issues.push({code:"invalid_key",origin:"map",input:$,inst:o,issues:r.issues.map((_)=>R(_,U,B()))});if(v.issues.length)if(Hr.has(typeof g))c.issues.push(...m(g,v.issues));else c.issues.push({origin:"map",code:"invalid_element",input:$,inst:o,key:g,issues:v.issues.map((_)=>R(_,U,B()))});c.value.set(r.value,v.value)}var no=w("$ZodSet",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{let $=c.value;if(!($ instanceof Set))return c.issues.push({input:$,inst:r,expected:"set",code:"invalid_type"}),c;let o=[];c.value=new Set;for(let U of $){let _=v.valueType._zod.run({value:U,issues:[]},g);if(_ instanceof Promise)o.push(_.then((j)=>G6(j,c)));else G6(_,c)}if(o.length)return Promise.all(o).then(()=>c);return c}});function G6(r,v){if(r.issues.length)v.issues.push(...r.issues);v.value.add(r.value)}var ko=w("$ZodEnum",(r,v)=>{J.init(r,v);let c=Qr(v.entries),g=new Set(c);r._zod.values=g,r._zod.pattern=new RegExp(`^(${c.filter(($)=>Hr.has(typeof $)).map(($)=>typeof $==="string"?l($):$.toString()).join("|")})$`),r._zod.parse=($,o)=>{let U=$.value;if(g.has(U))return $;return $.issues.push({code:"invalid_value",values:c,input:U,inst:r}),$}}),io=w("$ZodLiteral",(r,v)=>{if(J.init(r,v),v.values.length===0)throw Error("Cannot create literal schema with no valid values");r._zod.values=new Set(v.values),r._zod.pattern=new RegExp(`^(${v.values.map((c)=>typeof c==="string"?l(c):c?l(c.toString()):String(c)).join("|")})$`),r._zod.parse=(c,g)=>{let $=c.value;if(r._zod.values.has($))return c;return c.issues.push({code:"invalid_value",values:v.values,input:$,inst:r}),c}}),zo=w("$ZodFile",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{let $=c.value;if($ instanceof File)return c;return c.issues.push({expected:"file",code:"invalid_type",input:$,inst:r}),c}}),mr=w("$ZodTransform",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{let $=v.transform(c.value,c);if(g.async)return($ instanceof Promise?$:Promise.resolve($)).then((U)=>{return c.value=U,c});if($ instanceof Promise)throw new q;return c.value=$,c}});function A6(r,v){if(r.issues.length&&v===void 0)return{issues:[],value:void 0};return r}var bo=w("$ZodOptional",(r,v)=>{J.init(r,v),r._zod.optin="optional",r._zod.optout="optional",K(r._zod,"values",()=>{return v.innerType._zod.values?new Set([...v.innerType._zod.values,void 0]):void 0}),K(r._zod,"pattern",()=>{let c=v.innerType._zod.pattern;return c?new RegExp(`^(${ur(c.source)})?$`):void 0}),r._zod.parse=(c,g)=>{if(v.innerType._zod.optin==="optional"){let $=v.innerType._zod.run(c,g);if($ instanceof Promise)return $.then((o)=>A6(o,c.value));return A6($,c.value)}if(c.value===void 0)return c;return v.innerType._zod.run(c,g)}}),Do=w("$ZodNullable",(r,v)=>{J.init(r,v),K(r._zod,"optin",()=>v.innerType._zod.optin),K(r._zod,"optout",()=>v.innerType._zod.optout),K(r._zod,"pattern",()=>{let c=v.innerType._zod.pattern;return c?new RegExp(`^(${ur(c.source)}|null)$`):void 0}),K(r._zod,"values",()=>{return v.innerType._zod.values?new Set([...v.innerType._zod.values,null]):void 0}),r._zod.parse=(c,g)=>{if(c.value===null)return c;return v.innerType._zod.run(c,g)}}),So=w("$ZodDefault",(r,v)=>{J.init(r,v),r._zod.optin="optional",K(r._zod,"values",()=>v.innerType._zod.values),r._zod.parse=(c,g)=>{if(c.value===void 0)return c.value=v.defaultValue,c;let $=v.innerType._zod.run(c,g);if($ instanceof Promise)return $.then((o)=>L6(o,v));return L6($,v)}});function L6(r,v){if(r.value===void 0)r.value=v.defaultValue;return r}var Po=w("$ZodPrefault",(r,v)=>{J.init(r,v),r._zod.optin="optional",K(r._zod,"values",()=>v.innerType._zod.values),r._zod.parse=(c,g)=>{if(c.value===void 0)c.value=v.defaultValue;return v.innerType._zod.run(c,g)}}),Io=w("$ZodNonOptional",(r,v)=>{J.init(r,v),K(r._zod,"values",()=>{let c=v.innerType._zod.values;return c?new Set([...c].filter((g)=>g!==void 0)):void 0}),r._zod.parse=(c,g)=>{let $=v.innerType._zod.run(c,g);if($ instanceof Promise)return $.then((o)=>Q6(o,r));return Q6($,r)}});function Q6(r,v){if(!r.issues.length&&r.value===void 0)r.issues.push({code:"invalid_type",expected:"nonoptional",input:r.value,inst:v});return r}var xo=w("$ZodSuccess",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{let $=v.innerType._zod.run(c,g);if($ instanceof Promise)return $.then((o)=>{return c.value=o.issues.length===0,c});return c.value=$.issues.length===0,c}}),Jo=w("$ZodCatch",(r,v)=>{J.init(r,v),K(r._zod,"optin",()=>v.innerType._zod.optin),K(r._zod,"optout",()=>v.innerType._zod.optout),K(r._zod,"values",()=>v.innerType._zod.values),r._zod.parse=(c,g)=>{let $=v.innerType._zod.run(c,g);if($ instanceof Promise)return $.then((o)=>{if(c.value=o.value,o.issues.length)c.value=v.catchValue({...c,error:{issues:o.issues.map((U)=>R(U,g,B()))},input:c.value}),c.issues=[];return c});if(c.value=$.value,$.issues.length)c.value=v.catchValue({...c,error:{issues:$.issues.map((o)=>R(o,g,B()))},input:c.value}),c.issues=[];return c}}),Xo=w("$ZodNaN",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{if(typeof c.value!=="number"||!Number.isNaN(c.value))return c.issues.push({input:c.value,inst:r,expected:"nan",code:"invalid_type"}),c;return c}}),Rr=w("$ZodPipe",(r,v)=>{J.init(r,v),K(r._zod,"values",()=>v.in._zod.values),K(r._zod,"optin",()=>v.in._zod.optin),K(r._zod,"optout",()=>v.out._zod.optout),K(r._zod,"propValues",()=>v.in._zod.propValues),r._zod.parse=(c,g)=>{let $=v.in._zod.run(c,g);if($ instanceof Promise)return $.then((o)=>Y6(o,v,g));return Y6($,v,g)}});function Y6(r,v,c){if(r.issues.length)return r;return v.out._zod.run({value:r.value,issues:r.issues},c)}var Wo=w("$ZodReadonly",(r,v)=>{J.init(r,v),K(r._zod,"propValues",()=>v.innerType._zod.propValues),K(r._zod,"values",()=>v.innerType._zod.values),K(r._zod,"optin",()=>v.innerType._zod.optin),K(r._zod,"optout",()=>v.innerType._zod.optout),r._zod.parse=(c,g)=>{let $=v.innerType._zod.run(c,g);if($ instanceof Promise)return $.then(u6);return u6($)}});function u6(r){return r.value=Object.freeze(r.value),r}var Ko=w("$ZodTemplateLiteral",(r,v)=>{J.init(r,v);let c=[];for(let g of v.parts)if(g instanceof J){if(!g._zod.pattern)throw Error(`Invalid template literal part, no pattern found: ${[...g._zod.traits].shift()}`);let $=g._zod.pattern instanceof RegExp?g._zod.pattern.source:g._zod.pattern;if(!$)throw Error(`Invalid template literal part: ${g._zod.traits}`);let o=$.startsWith("^")?1:0,U=$.endsWith("$")?$.length-1:$.length;c.push($.slice(o,U))}else if(g===null||Wv.has(typeof g))c.push(l(`${g}`));else throw Error(`Invalid template literal part: ${g}`);r._zod.pattern=new RegExp(`^${c.join("")}$`),r._zod.parse=(g,$)=>{if(typeof g.value!=="string")return g.issues.push({input:g.value,inst:r,expected:"template_literal",code:"invalid_type"}),g;if(r._zod.pattern.lastIndex=0,!r._zod.pattern.test(g.value))return g.issues.push({input:g.value,inst:r,code:"invalid_format",format:v.format??"template_literal",pattern:r._zod.pattern.source}),g;return g}}),Go=w("$ZodPromise",(r,v)=>{J.init(r,v),r._zod.parse=(c,g)=>{return Promise.resolve(c.value).then(($)=>v.innerType._zod.run({value:$,issues:[]},g))}}),Ao=w("$ZodLazy",(r,v)=>{J.init(r,v),K(r._zod,"innerType",()=>v.getter()),K(r._zod,"pattern",()=>r._zod.innerType._zod.pattern),K(r._zod,"propValues",()=>r._zod.innerType._zod.propValues),K(r._zod,"optin",()=>r._zod.innerType._zod.optin??void 0),K(r._zod,"optout",()=>r._zod.innerType._zod.optout??void 0),r._zod.parse=(c,g)=>{return r._zod.innerType._zod.run(c,g)}}),Lo=w("$ZodCustom",(r,v)=>{H.init(r,v),J.init(r,v),r._zod.parse=(c,g)=>{return c},r._zod.check=(c)=>{let g=c.value,$=v.fn(g);if($ instanceof Promise)return $.then((o)=>H6(o,c,g,r));H6($,c,g,r);return}});function H6(r,v,c,g){if(!r){let $={code:"custom",input:c,inst:g,path:[...g._zod.def.path??[]],continue:!g._zod.def.abort};if(g._zod.def.params)$.params=g._zod.def.params;v.issues.push(ir($))}}var lr={};a(lr,{zhTW:()=>zg,zhCN:()=>ig,yo:()=>bg,vi:()=>kg,ur:()=>ng,ua:()=>Og,tr:()=>jg,th:()=>wg,ta:()=>_g,sv:()=>Ug,sl:()=>gg,ru:()=>og,pt:()=>cg,ps:()=>$g,pl:()=>vg,ota:()=>rg,no:()=>so,nl:()=>eo,ms:()=>ao,mk:()=>po,ko:()=>yo,kh:()=>fo,ja:()=>ho,it:()=>Co,is:()=>qo,id:()=>Zo,hu:()=>lo,he:()=>To,frCA:()=>Ro,fr:()=>mo,fi:()=>Vo,fa:()=>Fo,es:()=>Eo,eo:()=>to,en:()=>Tr,de:()=>Mo,da:()=>Bo,cs:()=>No,ca:()=>Ho,be:()=>uo,az:()=>Yo,ar:()=>Qo});var S_=()=>{let r={string:{unit:"حرف",verb:"أن يحوي"},file:{unit:"بايت",verb:"أن يحوي"},array:{unit:"عنصر",verb:"أن يحوي"},set:{unit:"عنصر",verb:"أن يحوي"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"number";case"object":{if(Array.isArray($))return"array";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"مدخل",email:"بريد إلكتروني",url:"رابط",emoji:"إيموجي",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"تاريخ ووقت بمعيار ISO",date:"تاريخ بمعيار ISO",time:"وقت بمعيار ISO",duration:"مدة بمعيار ISO",ipv4:"عنوان IPv4",ipv6:"عنوان IPv6",cidrv4:"مدى عناوين بصيغة IPv4",cidrv6:"مدى عناوين بصيغة IPv6",base64:"نَص بترميز base64-encoded",base64url:"نَص بترميز base64url-encoded",json_string:"نَص على هيئة JSON",e164:"رقم هاتف بمعيار E.164",jwt:"JWT",template_literal:"مدخل"};return($)=>{switch($.code){case"invalid_type":return`مدخلات غير مقبولة: يفترض إدخال ${$.expected}، ولكن تم إدخال ${c($.input)}`;case"invalid_value":if($.values.length===1)return`مدخلات غير مقبولة: يفترض إدخال ${D($.values[0])}`;return`اختيار غير مقبول: يتوقع انتقاء أحد هذه الخيارات: ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return` أكبر من اللازم: يفترض أن تكون ${$.origin??"القيمة"} ${o} ${$.maximum.toString()} ${U.unit??"عنصر"}`;return`أكبر من اللازم: يفترض أن تكون ${$.origin??"القيمة"} ${o} ${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`أصغر من اللازم: يفترض لـ ${$.origin} أن يكون ${o} ${$.minimum.toString()} ${U.unit}`;return`أصغر من اللازم: يفترض لـ ${$.origin} أن يكون ${o} ${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`نَص غير مقبول: يجب أن يبدأ بـ "${$.prefix}"`;if(o.format==="ends_with")return`نَص غير مقبول: يجب أن ينتهي بـ "${o.suffix}"`;if(o.format==="includes")return`نَص غير مقبول: يجب أن يتضمَّن "${o.includes}"`;if(o.format==="regex")return`نَص غير مقبول: يجب أن يطابق النمط ${o.pattern}`;return`${g[o.format]??$.format} غير مقبول`}case"not_multiple_of":return`رقم غير مقبول: يجب أن يكون من مضاعفات ${$.divisor}`;case"unrecognized_keys":return`معرف${$.keys.length>1?"ات":""} غريب${$.keys.length>1?"ة":""}: ${i($.keys,"، ")}`;case"invalid_key":return`معرف غير مقبول في ${$.origin}`;case"invalid_union":return"مدخل غير مقبول";case"invalid_element":return`مدخل غير مقبول في ${$.origin}`;default:return"مدخل غير مقبول"}}};function Qo(){return{localeError:S_()}}var P_=()=>{let r={string:{unit:"simvol",verb:"olmalıdır"},file:{unit:"bayt",verb:"olmalıdır"},array:{unit:"element",verb:"olmalıdır"},set:{unit:"element",verb:"olmalıdır"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"number";case"object":{if(Array.isArray($))return"array";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"input",email:"email address",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO datetime",date:"ISO date",time:"ISO time",duration:"ISO duration",ipv4:"IPv4 address",ipv6:"IPv6 address",cidrv4:"IPv4 range",cidrv6:"IPv6 range",base64:"base64-encoded string",base64url:"base64url-encoded string",json_string:"JSON string",e164:"E.164 number",jwt:"JWT",template_literal:"input"};return($)=>{switch($.code){case"invalid_type":return`Yanlış dəyər: gözlənilən ${$.expected}, daxil olan ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Yanlış dəyər: gözlənilən ${D($.values[0])}`;return`Yanlış seçim: aşağıdakılardan biri olmalıdır: ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Çox böyük: gözlənilən ${$.origin??"dəyər"} ${o}${$.maximum.toString()} ${U.unit??"element"}`;return`Çox böyük: gözlənilən ${$.origin??"dəyər"} ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Çox kiçik: gözlənilən ${$.origin} ${o}${$.minimum.toString()} ${U.unit}`;return`Çox kiçik: gözlənilən ${$.origin} ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Yanlış mətn: "${o.prefix}" ilə başlamalıdır`;if(o.format==="ends_with")return`Yanlış mətn: "${o.suffix}" ilə bitməlidir`;if(o.format==="includes")return`Yanlış mətn: "${o.includes}" daxil olmalıdır`;if(o.format==="regex")return`Yanlış mətn: ${o.pattern} şablonuna uyğun olmalıdır`;return`Yanlış ${g[o.format]??$.format}`}case"not_multiple_of":return`Yanlış ədəd: ${$.divisor} ilə bölünə bilən olmalıdır`;case"unrecognized_keys":return`Tanınmayan açar${$.keys.length>1?"lar":""}: ${i($.keys,", ")}`;case"invalid_key":return`${$.origin} daxilində yanlış açar`;case"invalid_union":return"Yanlış dəyər";case"invalid_element":return`${$.origin} daxilində yanlış dəyər`;default:return"Yanlış dəyər"}}};function Yo(){return{localeError:P_()}}function t6(r,v,c,g){let $=Math.abs(r),o=$%10,U=$%100;if(U>=11&&U<=19)return g;if(o===1)return v;if(o>=2&&o<=4)return c;return g}var I_=()=>{let r={string:{unit:{one:"сімвал",few:"сімвалы",many:"сімвалаў"},verb:"мець"},array:{unit:{one:"элемент",few:"элементы",many:"элементаў"},verb:"мець"},set:{unit:{one:"элемент",few:"элементы",many:"элементаў"},verb:"мець"},file:{unit:{one:"байт",few:"байты",many:"байтаў"},verb:"мець"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"лік";case"object":{if(Array.isArray($))return"масіў";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"увод",email:"email адрас",url:"URL",emoji:"эмодзі",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO дата і час",date:"ISO дата",time:"ISO час",duration:"ISO працягласць",ipv4:"IPv4 адрас",ipv6:"IPv6 адрас",cidrv4:"IPv4 дыяпазон",cidrv6:"IPv6 дыяпазон",base64:"радок у фармаце base64",base64url:"радок у фармаце base64url",json_string:"JSON радок",e164:"нумар E.164",jwt:"JWT",template_literal:"увод"};return($)=>{switch($.code){case"invalid_type":return`Няправільны ўвод: чакаўся ${$.expected}, атрымана ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Няправільны ўвод: чакалася ${D($.values[0])}`;return`Няправільны варыянт: чакаўся адзін з ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U){let _=Number($.maximum),j=t6(_,U.unit.one,U.unit.few,U.unit.many);return`Занадта вялікі: чакалася, што ${$.origin??"значэнне"} павінна ${U.verb} ${o}${$.maximum.toString()} ${j}`}return`Занадта вялікі: чакалася, што ${$.origin??"значэнне"} павінна быць ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U){let _=Number($.minimum),j=t6(_,U.unit.one,U.unit.few,U.unit.many);return`Занадта малы: чакалася, што ${$.origin} павінна ${U.verb} ${o}${$.minimum.toString()} ${j}`}return`Занадта малы: чакалася, што ${$.origin} павінна быць ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Няправільны радок: павінен пачынацца з "${o.prefix}"`;if(o.format==="ends_with")return`Няправільны радок: павінен заканчвацца на "${o.suffix}"`;if(o.format==="includes")return`Няправільны радок: павінен змяшчаць "${o.includes}"`;if(o.format==="regex")return`Няправільны радок: павінен адпавядаць шаблону ${o.pattern}`;return`Няправільны ${g[o.format]??$.format}`}case"not_multiple_of":return`Няправільны лік: павінен быць кратным ${$.divisor}`;case"unrecognized_keys":return`Нераспазнаны ${$.keys.length>1?"ключы":"ключ"}: ${i($.keys,", ")}`;case"invalid_key":return`Няправільны ключ у ${$.origin}`;case"invalid_union":return"Няправільны ўвод";case"invalid_element":return`Няправільнае значэнне ў ${$.origin}`;default:return"Няправільны ўвод"}}};function uo(){return{localeError:I_()}}var x_=()=>{let r={string:{unit:"caràcters",verb:"contenir"},file:{unit:"bytes",verb:"contenir"},array:{unit:"elements",verb:"contenir"},set:{unit:"elements",verb:"contenir"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"number";case"object":{if(Array.isArray($))return"array";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"entrada",email:"adreça electrònica",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"data i hora ISO",date:"data ISO",time:"hora ISO",duration:"durada ISO",ipv4:"adreça IPv4",ipv6:"adreça IPv6",cidrv4:"rang IPv4",cidrv6:"rang IPv6",base64:"cadena codificada en base64",base64url:"cadena codificada en base64url",json_string:"cadena JSON",e164:"número E.164",jwt:"JWT",template_literal:"entrada"};return($)=>{switch($.code){case"invalid_type":return`Tipus invàlid: s'esperava ${$.expected}, s'ha rebut ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Valor invàlid: s'esperava ${D($.values[0])}`;return`Opció invàlida: s'esperava una de ${i($.values," o ")}`;case"too_big":{let o=$.inclusive?"com a màxim":"menys de",U=v($.origin);if(U)return`Massa gran: s'esperava que ${$.origin??"el valor"} contingués ${o} ${$.maximum.toString()} ${U.unit??"elements"}`;return`Massa gran: s'esperava que ${$.origin??"el valor"} fos ${o} ${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?"com a mínim":"més de",U=v($.origin);if(U)return`Massa petit: s'esperava que ${$.origin} contingués ${o} ${$.minimum.toString()} ${U.unit}`;return`Massa petit: s'esperava que ${$.origin} fos ${o} ${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Format invàlid: ha de començar amb "${o.prefix}"`;if(o.format==="ends_with")return`Format invàlid: ha d'acabar amb "${o.suffix}"`;if(o.format==="includes")return`Format invàlid: ha d'incloure "${o.includes}"`;if(o.format==="regex")return`Format invàlid: ha de coincidir amb el patró ${o.pattern}`;return`Format invàlid per a ${g[o.format]??$.format}`}case"not_multiple_of":return`Número invàlid: ha de ser múltiple de ${$.divisor}`;case"unrecognized_keys":return`Clau${$.keys.length>1?"s":""} no reconeguda${$.keys.length>1?"s":""}: ${i($.keys,", ")}`;case"invalid_key":return`Clau invàlida a ${$.origin}`;case"invalid_union":return"Entrada invàlida";case"invalid_element":return`Element invàlid a ${$.origin}`;default:return"Entrada invàlida"}}};function Ho(){return{localeError:x_()}}var J_=()=>{let r={string:{unit:"znaků",verb:"mít"},file:{unit:"bajtů",verb:"mít"},array:{unit:"prvků",verb:"mít"},set:{unit:"prvků",verb:"mít"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"číslo";case"string":return"řetězec";case"boolean":return"boolean";case"bigint":return"bigint";case"function":return"funkce";case"symbol":return"symbol";case"undefined":return"undefined";case"object":{if(Array.isArray($))return"pole";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"regulární výraz",email:"e-mailová adresa",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"datum a čas ve formátu ISO",date:"datum ve formátu ISO",time:"čas ve formátu ISO",duration:"doba trvání ISO",ipv4:"IPv4 adresa",ipv6:"IPv6 adresa",cidrv4:"rozsah IPv4",cidrv6:"rozsah IPv6",base64:"řetězec zakódovaný ve formátu base64",base64url:"řetězec zakódovaný ve formátu base64url",json_string:"řetězec ve formátu JSON",e164:"číslo E.164",jwt:"JWT",template_literal:"vstup"};return($)=>{switch($.code){case"invalid_type":return`Neplatný vstup: očekáváno ${$.expected}, obdrženo ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Neplatný vstup: očekáváno ${D($.values[0])}`;return`Neplatná možnost: očekávána jedna z hodnot ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Hodnota je příliš velká: ${$.origin??"hodnota"} musí mít ${o}${$.maximum.toString()} ${U.unit??"prvků"}`;return`Hodnota je příliš velká: ${$.origin??"hodnota"} musí být ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Hodnota je příliš malá: ${$.origin??"hodnota"} musí mít ${o}${$.minimum.toString()} ${U.unit??"prvků"}`;return`Hodnota je příliš malá: ${$.origin??"hodnota"} musí být ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Neplatný řetězec: musí začínat na "${o.prefix}"`;if(o.format==="ends_with")return`Neplatný řetězec: musí končit na "${o.suffix}"`;if(o.format==="includes")return`Neplatný řetězec: musí obsahovat "${o.includes}"`;if(o.format==="regex")return`Neplatný řetězec: musí odpovídat vzoru ${o.pattern}`;return`Neplatný formát ${g[o.format]??$.format}`}case"not_multiple_of":return`Neplatné číslo: musí být násobkem ${$.divisor}`;case"unrecognized_keys":return`Neznámé klíče: ${i($.keys,", ")}`;case"invalid_key":return`Neplatný klíč v ${$.origin}`;case"invalid_union":return"Neplatný vstup";case"invalid_element":return`Neplatná hodnota v ${$.origin}`;default:return"Neplatný vstup"}}};function No(){return{localeError:J_()}}var X_=()=>{let r={string:{unit:"tegn",verb:"havde"},file:{unit:"bytes",verb:"havde"},array:{unit:"elementer",verb:"indeholdt"},set:{unit:"elementer",verb:"indeholdt"}},v={string:"streng",number:"tal",boolean:"boolean",array:"liste",object:"objekt",set:"sæt",file:"fil"};function c(U){return r[U]??null}function g(U){return v[U]??U}let $=(U)=>{let _=typeof U;switch(_){case"number":return Number.isNaN(U)?"NaN":"tal";case"object":{if(Array.isArray(U))return"liste";if(U===null)return"null";if(Object.getPrototypeOf(U)!==Object.prototype&&U.constructor)return U.constructor.name;return"objekt"}}return _},o={regex:"input",email:"e-mailadresse",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO dato- og klokkeslæt",date:"ISO-dato",time:"ISO-klokkeslæt",duration:"ISO-varighed",ipv4:"IPv4-område",ipv6:"IPv6-område",cidrv4:"IPv4-spektrum",cidrv6:"IPv6-spektrum",base64:"base64-kodet streng",base64url:"base64url-kodet streng",json_string:"JSON-streng",e164:"E.164-nummer",jwt:"JWT",template_literal:"input"};return(U)=>{switch(U.code){case"invalid_type":return`Ugyldigt input: forventede ${g(U.expected)}, fik ${g($(U.input))}`;case"invalid_value":if(U.values.length===1)return`Ugyldig værdi: forventede ${D(U.values[0])}`;return`Ugyldigt valg: forventede en af følgende ${i(U.values,"|")}`;case"too_big":{let _=U.inclusive?"<=":"<",j=c(U.origin),n=g(U.origin);if(j)return`For stor: forventede ${n??"value"} ${j.verb} ${_} ${U.maximum.toString()} ${j.unit??"elementer"}`;return`For stor: forventede ${n??"value"} havde ${_} ${U.maximum.toString()}`}case"too_small":{let _=U.inclusive?">=":">",j=c(U.origin),n=g(U.origin);if(j)return`For lille: forventede ${n} ${j.verb} ${_} ${U.minimum.toString()} ${j.unit}`;return`For lille: forventede ${n} havde ${_} ${U.minimum.toString()}`}case"invalid_format":{let _=U;if(_.format==="starts_with")return`Ugyldig streng: skal starte med "${_.prefix}"`;if(_.format==="ends_with")return`Ugyldig streng: skal ende med "${_.suffix}"`;if(_.format==="includes")return`Ugyldig streng: skal indeholde "${_.includes}"`;if(_.format==="regex")return`Ugyldig streng: skal matche mønsteret ${_.pattern}`;return`Ugyldig ${o[_.format]??U.format}`}case"not_multiple_of":return`Ugyldigt tal: skal være deleligt med ${U.divisor}`;case"unrecognized_keys":return`${U.keys.length>1?"Ukendte nøgler":"Ukendt nøgle"}: ${i(U.keys,", ")}`;case"invalid_key":return`Ugyldig nøgle i ${U.origin}`;case"invalid_union":return"Ugyldigt input: matcher ingen af de tilladte typer";case"invalid_element":return`Ugyldig værdi i ${U.origin}`;default:return"Ugyldigt input"}}};function Bo(){return{localeError:X_()}}var W_=()=>{let r={string:{unit:"Zeichen",verb:"zu haben"},file:{unit:"Bytes",verb:"zu haben"},array:{unit:"Elemente",verb:"zu haben"},set:{unit:"Elemente",verb:"zu haben"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"Zahl";case"object":{if(Array.isArray($))return"Array";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"Eingabe",email:"E-Mail-Adresse",url:"URL",emoji:"Emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO-Datum und -Uhrzeit",date:"ISO-Datum",time:"ISO-Uhrzeit",duration:"ISO-Dauer",ipv4:"IPv4-Adresse",ipv6:"IPv6-Adresse",cidrv4:"IPv4-Bereich",cidrv6:"IPv6-Bereich",base64:"Base64-codierter String",base64url:"Base64-URL-codierter String",json_string:"JSON-String",e164:"E.164-Nummer",jwt:"JWT",template_literal:"Eingabe"};return($)=>{switch($.code){case"invalid_type":return`Ungültige Eingabe: erwartet ${$.expected}, erhalten ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Ungültige Eingabe: erwartet ${D($.values[0])}`;return`Ungültige Option: erwartet eine von ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Zu groß: erwartet, dass ${$.origin??"Wert"} ${o}${$.maximum.toString()} ${U.unit??"Elemente"} hat`;return`Zu groß: erwartet, dass ${$.origin??"Wert"} ${o}${$.maximum.toString()} ist`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Zu klein: erwartet, dass ${$.origin} ${o}${$.minimum.toString()} ${U.unit} hat`;return`Zu klein: erwartet, dass ${$.origin} ${o}${$.minimum.toString()} ist`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Ungültiger String: muss mit "${o.prefix}" beginnen`;if(o.format==="ends_with")return`Ungültiger String: muss mit "${o.suffix}" enden`;if(o.format==="includes")return`Ungültiger String: muss "${o.includes}" enthalten`;if(o.format==="regex")return`Ungültiger String: muss dem Muster ${o.pattern} entsprechen`;return`Ungültig: ${g[o.format]??$.format}`}case"not_multiple_of":return`Ungültige Zahl: muss ein Vielfaches von ${$.divisor} sein`;case"unrecognized_keys":return`${$.keys.length>1?"Unbekannte Schlüssel":"Unbekannter Schlüssel"}: ${i($.keys,", ")}`;case"invalid_key":return`Ungültiger Schlüssel in ${$.origin}`;case"invalid_union":return"Ungültige Eingabe";case"invalid_element":return`Ungültiger Wert in ${$.origin}`;default:return"Ungültige Eingabe"}}};function Mo(){return{localeError:W_()}}var K_=(r)=>{let v=typeof r;switch(v){case"number":return Number.isNaN(r)?"NaN":"number";case"object":{if(Array.isArray(r))return"array";if(r===null)return"null";if(Object.getPrototypeOf(r)!==Object.prototype&&r.constructor)return r.constructor.name}}return v},G_=()=>{let r={string:{unit:"characters",verb:"to have"},file:{unit:"bytes",verb:"to have"},array:{unit:"items",verb:"to have"},set:{unit:"items",verb:"to have"}};function v(g){return r[g]??null}let c={regex:"input",email:"email address",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO datetime",date:"ISO date",time:"ISO time",duration:"ISO duration",ipv4:"IPv4 address",ipv6:"IPv6 address",cidrv4:"IPv4 range",cidrv6:"IPv6 range",base64:"base64-encoded string",base64url:"base64url-encoded string",json_string:"JSON string",e164:"E.164 number",jwt:"JWT",template_literal:"input"};return(g)=>{switch(g.code){case"invalid_type":return`Invalid input: expected ${g.expected}, received ${K_(g.input)}`;case"invalid_value":if(g.values.length===1)return`Invalid input: expected ${D(g.values[0])}`;return`Invalid option: expected one of ${i(g.values,"|")}`;case"too_big":{let $=g.inclusive?"<=":"<",o=v(g.origin);if(o)return`Too big: expected ${g.origin??"value"} to have ${$}${g.maximum.toString()} ${o.unit??"elements"}`;return`Too big: expected ${g.origin??"value"} to be ${$}${g.maximum.toString()}`}case"too_small":{let $=g.inclusive?">=":">",o=v(g.origin);if(o)return`Too small: expected ${g.origin} to have ${$}${g.minimum.toString()} ${o.unit}`;return`Too small: expected ${g.origin} to be ${$}${g.minimum.toString()}`}case"invalid_format":{let $=g;if($.format==="starts_with")return`Invalid string: must start with "${$.prefix}"`;if($.format==="ends_with")return`Invalid string: must end with "${$.suffix}"`;if($.format==="includes")return`Invalid string: must include "${$.includes}"`;if($.format==="regex")return`Invalid string: must match pattern ${$.pattern}`;return`Invalid ${c[$.format]??g.format}`}case"not_multiple_of":return`Invalid number: must be a multiple of ${g.divisor}`;case"unrecognized_keys":return`Unrecognized key${g.keys.length>1?"s":""}: ${i(g.keys,", ")}`;case"invalid_key":return`Invalid key in ${g.origin}`;case"invalid_union":return"Invalid input";case"invalid_element":return`Invalid value in ${g.origin}`;default:return"Invalid input"}}};function Tr(){return{localeError:G_()}}var A_=(r)=>{let v=typeof r;switch(v){case"number":return Number.isNaN(r)?"NaN":"nombro";case"object":{if(Array.isArray(r))return"tabelo";if(r===null)return"senvalora";if(Object.getPrototypeOf(r)!==Object.prototype&&r.constructor)return r.constructor.name}}return v},L_=()=>{let r={string:{unit:"karaktrojn",verb:"havi"},file:{unit:"bajtojn",verb:"havi"},array:{unit:"elementojn",verb:"havi"},set:{unit:"elementojn",verb:"havi"}};function v(g){return r[g]??null}let c={regex:"enigo",email:"retadreso",url:"URL",emoji:"emoĝio",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO-datotempo",date:"ISO-dato",time:"ISO-tempo",duration:"ISO-daŭro",ipv4:"IPv4-adreso",ipv6:"IPv6-adreso",cidrv4:"IPv4-rango",cidrv6:"IPv6-rango",base64:"64-ume kodita karaktraro",base64url:"URL-64-ume kodita karaktraro",json_string:"JSON-karaktraro",e164:"E.164-nombro",jwt:"JWT",template_literal:"enigo"};return(g)=>{switch(g.code){case"invalid_type":return`Nevalida enigo: atendiĝis ${g.expected}, riceviĝis ${A_(g.input)}`;case"invalid_value":if(g.values.length===1)return`Nevalida enigo: atendiĝis ${D(g.values[0])}`;return`Nevalida opcio: atendiĝis unu el ${i(g.values,"|")}`;case"too_big":{let $=g.inclusive?"<=":"<",o=v(g.origin);if(o)return`Tro granda: atendiĝis ke ${g.origin??"valoro"} havu ${$}${g.maximum.toString()} ${o.unit??"elementojn"}`;return`Tro granda: atendiĝis ke ${g.origin??"valoro"} havu ${$}${g.maximum.toString()}`}case"too_small":{let $=g.inclusive?">=":">",o=v(g.origin);if(o)return`Tro malgranda: atendiĝis ke ${g.origin} havu ${$}${g.minimum.toString()} ${o.unit}`;return`Tro malgranda: atendiĝis ke ${g.origin} estu ${$}${g.minimum.toString()}`}case"invalid_format":{let $=g;if($.format==="starts_with")return`Nevalida karaktraro: devas komenciĝi per "${$.prefix}"`;if($.format==="ends_with")return`Nevalida karaktraro: devas finiĝi per "${$.suffix}"`;if($.format==="includes")return`Nevalida karaktraro: devas inkluzivi "${$.includes}"`;if($.format==="regex")return`Nevalida karaktraro: devas kongrui kun la modelo ${$.pattern}`;return`Nevalida ${c[$.format]??g.format}`}case"not_multiple_of":return`Nevalida nombro: devas esti oblo de ${g.divisor}`;case"unrecognized_keys":return`Nekonata${g.keys.length>1?"j":""} ŝlosilo${g.keys.length>1?"j":""}: ${i(g.keys,", ")}`;case"invalid_key":return`Nevalida ŝlosilo en ${g.origin}`;case"invalid_union":return"Nevalida enigo";case"invalid_element":return`Nevalida valoro en ${g.origin}`;default:return"Nevalida enigo"}}};function to(){return{localeError:L_()}}var Q_=()=>{let r={string:{unit:"caracteres",verb:"tener"},file:{unit:"bytes",verb:"tener"},array:{unit:"elementos",verb:"tener"},set:{unit:"elementos",verb:"tener"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"número";case"object":{if(Array.isArray($))return"arreglo";if($===null)return"nulo";if(Object.getPrototypeOf($)!==Object.prototype)return $.constructor.name}}return o},g={regex:"entrada",email:"dirección de correo electrónico",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"fecha y hora ISO",date:"fecha ISO",time:"hora ISO",duration:"duración ISO",ipv4:"dirección IPv4",ipv6:"dirección IPv6",cidrv4:"rango IPv4",cidrv6:"rango IPv6",base64:"cadena codificada en base64",base64url:"URL codificada en base64",json_string:"cadena JSON",e164:"número E.164",jwt:"JWT",template_literal:"entrada"};return($)=>{switch($.code){case"invalid_type":return`Entrada inválida: se esperaba ${$.expected}, recibido ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Entrada inválida: se esperaba ${D($.values[0])}`;return`Opción inválida: se esperaba una de ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Demasiado grande: se esperaba que ${$.origin??"valor"} tuviera ${o}${$.maximum.toString()} ${U.unit??"elementos"}`;return`Demasiado grande: se esperaba que ${$.origin??"valor"} fuera ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Demasiado pequeño: se esperaba que ${$.origin} tuviera ${o}${$.minimum.toString()} ${U.unit}`;return`Demasiado pequeño: se esperaba que ${$.origin} fuera ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Cadena inválida: debe comenzar con "${o.prefix}"`;if(o.format==="ends_with")return`Cadena inválida: debe terminar en "${o.suffix}"`;if(o.format==="includes")return`Cadena inválida: debe incluir "${o.includes}"`;if(o.format==="regex")return`Cadena inválida: debe coincidir con el patrón ${o.pattern}`;return`Inválido ${g[o.format]??$.format}`}case"not_multiple_of":return`Número inválido: debe ser múltiplo de ${$.divisor}`;case"unrecognized_keys":return`Llave${$.keys.length>1?"s":""} desconocida${$.keys.length>1?"s":""}: ${i($.keys,", ")}`;case"invalid_key":return`Llave inválida en ${$.origin}`;case"invalid_union":return"Entrada inválida";case"invalid_element":return`Valor inválido en ${$.origin}`;default:return"Entrada inválida"}}};function Eo(){return{localeError:Q_()}}var Y_=()=>{let r={string:{unit:"کاراکتر",verb:"داشته باشد"},file:{unit:"بایت",verb:"داشته باشد"},array:{unit:"آیتم",verb:"داشته باشد"},set:{unit:"آیتم",verb:"داشته باشد"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"عدد";case"object":{if(Array.isArray($))return"آرایه";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"ورودی",email:"آدرس ایمیل",url:"URL",emoji:"ایموجی",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"تاریخ و زمان ایزو",date:"تاریخ ایزو",time:"زمان ایزو",duration:"مدت زمان ایزو",ipv4:"IPv4 آدرس",ipv6:"IPv6 آدرس",cidrv4:"IPv4 دامنه",cidrv6:"IPv6 دامنه",base64:"base64-encoded رشته",base64url:"base64url-encoded رشته",json_string:"JSON رشته",e164:"E.164 عدد",jwt:"JWT",template_literal:"ورودی"};return($)=>{switch($.code){case"invalid_type":return`ورودی نامعتبر: میبایست ${$.expected} میبود، ${c($.input)} دریافت شد`;case"invalid_value":if($.values.length===1)return`ورودی نامعتبر: میبایست ${D($.values[0])} میبود`;return`گزینه نامعتبر: میبایست یکی از ${i($.values,"|")} میبود`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`خیلی بزرگ: ${$.origin??"مقدار"} باید ${o}${$.maximum.toString()} ${U.unit??"عنصر"} باشد`;return`خیلی بزرگ: ${$.origin??"مقدار"} باید ${o}${$.maximum.toString()} باشد`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`خیلی کوچک: ${$.origin} باید ${o}${$.minimum.toString()} ${U.unit} باشد`;return`خیلی کوچک: ${$.origin} باید ${o}${$.minimum.toString()} باشد`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`رشته نامعتبر: باید با "${o.prefix}" شروع شود`;if(o.format==="ends_with")return`رشته نامعتبر: باید با "${o.suffix}" تمام شود`;if(o.format==="includes")return`رشته نامعتبر: باید شامل "${o.includes}" باشد`;if(o.format==="regex")return`رشته نامعتبر: باید با الگوی ${o.pattern} مطابقت داشته باشد`;return`${g[o.format]??$.format} نامعتبر`}case"not_multiple_of":return`عدد نامعتبر: باید مضرب ${$.divisor} باشد`;case"unrecognized_keys":return`کلید${$.keys.length>1?"های":""} ناشناس: ${i($.keys,", ")}`;case"invalid_key":return`کلید ناشناس در ${$.origin}`;case"invalid_union":return"ورودی نامعتبر";case"invalid_element":return`مقدار نامعتبر در ${$.origin}`;default:return"ورودی نامعتبر"}}};function Fo(){return{localeError:Y_()}}var u_=()=>{let r={string:{unit:"merkkiä",subject:"merkkijonon"},file:{unit:"tavua",subject:"tiedoston"},array:{unit:"alkiota",subject:"listan"},set:{unit:"alkiota",subject:"joukon"},number:{unit:"",subject:"luvun"},bigint:{unit:"",subject:"suuren kokonaisluvun"},int:{unit:"",subject:"kokonaisluvun"},date:{unit:"",subject:"päivämäärän"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"number";case"object":{if(Array.isArray($))return"array";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"säännöllinen lauseke",email:"sähköpostiosoite",url:"URL-osoite",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO-aikaleima",date:"ISO-päivämäärä",time:"ISO-aika",duration:"ISO-kesto",ipv4:"IPv4-osoite",ipv6:"IPv6-osoite",cidrv4:"IPv4-alue",cidrv6:"IPv6-alue",base64:"base64-koodattu merkkijono",base64url:"base64url-koodattu merkkijono",json_string:"JSON-merkkijono",e164:"E.164-luku",jwt:"JWT",template_literal:"templaattimerkkijono"};return($)=>{switch($.code){case"invalid_type":return`Virheellinen tyyppi: odotettiin ${$.expected}, oli ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Virheellinen syöte: täytyy olla ${D($.values[0])}`;return`Virheellinen valinta: täytyy olla yksi seuraavista: ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Liian suuri: ${U.subject} täytyy olla ${o}${$.maximum.toString()} ${U.unit}`.trim();return`Liian suuri: arvon täytyy olla ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Liian pieni: ${U.subject} täytyy olla ${o}${$.minimum.toString()} ${U.unit}`.trim();return`Liian pieni: arvon täytyy olla ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Virheellinen syöte: täytyy alkaa "${o.prefix}"`;if(o.format==="ends_with")return`Virheellinen syöte: täytyy loppua "${o.suffix}"`;if(o.format==="includes")return`Virheellinen syöte: täytyy sisältää "${o.includes}"`;if(o.format==="regex")return`Virheellinen syöte: täytyy vastata säännöllistä lauseketta ${o.pattern}`;return`Virheellinen ${g[o.format]??$.format}`}case"not_multiple_of":return`Virheellinen luku: täytyy olla luvun ${$.divisor} monikerta`;case"unrecognized_keys":return`${$.keys.length>1?"Tuntemattomat avaimet":"Tuntematon avain"}: ${i($.keys,", ")}`;case"invalid_key":return"Virheellinen avain tietueessa";case"invalid_union":return"Virheellinen unioni";case"invalid_element":return"Virheellinen arvo joukossa";default:return"Virheellinen syöte"}}};function Vo(){return{localeError:u_()}}var H_=()=>{let r={string:{unit:"caractères",verb:"avoir"},file:{unit:"octets",verb:"avoir"},array:{unit:"éléments",verb:"avoir"},set:{unit:"éléments",verb:"avoir"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"nombre";case"object":{if(Array.isArray($))return"tableau";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"entrée",email:"adresse e-mail",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"date et heure ISO",date:"date ISO",time:"heure ISO",duration:"durée ISO",ipv4:"adresse IPv4",ipv6:"adresse IPv6",cidrv4:"plage IPv4",cidrv6:"plage IPv6",base64:"chaîne encodée en base64",base64url:"chaîne encodée en base64url",json_string:"chaîne JSON",e164:"numéro E.164",jwt:"JWT",template_literal:"entrée"};return($)=>{switch($.code){case"invalid_type":return`Entrée invalide : ${$.expected} attendu, ${c($.input)} reçu`;case"invalid_value":if($.values.length===1)return`Entrée invalide : ${D($.values[0])} attendu`;return`Option invalide : une valeur parmi ${i($.values,"|")} attendue`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Trop grand : ${$.origin??"valeur"} doit ${U.verb} ${o}${$.maximum.toString()} ${U.unit??"élément(s)"}`;return`Trop grand : ${$.origin??"valeur"} doit être ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Trop petit : ${$.origin} doit ${U.verb} ${o}${$.minimum.toString()} ${U.unit}`;return`Trop petit : ${$.origin} doit être ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Chaîne invalide : doit commencer par "${o.prefix}"`;if(o.format==="ends_with")return`Chaîne invalide : doit se terminer par "${o.suffix}"`;if(o.format==="includes")return`Chaîne invalide : doit inclure "${o.includes}"`;if(o.format==="regex")return`Chaîne invalide : doit correspondre au modèle ${o.pattern}`;return`${g[o.format]??$.format} invalide`}case"not_multiple_of":return`Nombre invalide : doit être un multiple de ${$.divisor}`;case"unrecognized_keys":return`Clé${$.keys.length>1?"s":""} non reconnue${$.keys.length>1?"s":""} : ${i($.keys,", ")}`;case"invalid_key":return`Clé invalide dans ${$.origin}`;case"invalid_union":return"Entrée invalide";case"invalid_element":return`Valeur invalide dans ${$.origin}`;default:return"Entrée invalide"}}};function mo(){return{localeError:H_()}}var N_=()=>{let r={string:{unit:"caractères",verb:"avoir"},file:{unit:"octets",verb:"avoir"},array:{unit:"éléments",verb:"avoir"},set:{unit:"éléments",verb:"avoir"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"number";case"object":{if(Array.isArray($))return"array";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"entrée",email:"adresse courriel",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"date-heure ISO",date:"date ISO",time:"heure ISO",duration:"durée ISO",ipv4:"adresse IPv4",ipv6:"adresse IPv6",cidrv4:"plage IPv4",cidrv6:"plage IPv6",base64:"chaîne encodée en base64",base64url:"chaîne encodée en base64url",json_string:"chaîne JSON",e164:"numéro E.164",jwt:"JWT",template_literal:"entrée"};return($)=>{switch($.code){case"invalid_type":return`Entrée invalide : attendu ${$.expected}, reçu ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Entrée invalide : attendu ${D($.values[0])}`;return`Option invalide : attendu l'une des valeurs suivantes ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"≤":"<",U=v($.origin);if(U)return`Trop grand : attendu que ${$.origin??"la valeur"} ait ${o}${$.maximum.toString()} ${U.unit}`;return`Trop grand : attendu que ${$.origin??"la valeur"} soit ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?"≥":">",U=v($.origin);if(U)return`Trop petit : attendu que ${$.origin} ait ${o}${$.minimum.toString()} ${U.unit}`;return`Trop petit : attendu que ${$.origin} soit ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Chaîne invalide : doit commencer par "${o.prefix}"`;if(o.format==="ends_with")return`Chaîne invalide : doit se terminer par "${o.suffix}"`;if(o.format==="includes")return`Chaîne invalide : doit inclure "${o.includes}"`;if(o.format==="regex")return`Chaîne invalide : doit correspondre au motif ${o.pattern}`;return`${g[o.format]??$.format} invalide`}case"not_multiple_of":return`Nombre invalide : doit être un multiple de ${$.divisor}`;case"unrecognized_keys":return`Clé${$.keys.length>1?"s":""} non reconnue${$.keys.length>1?"s":""} : ${i($.keys,", ")}`;case"invalid_key":return`Clé invalide dans ${$.origin}`;case"invalid_union":return"Entrée invalide";case"invalid_element":return`Valeur invalide dans ${$.origin}`;default:return"Entrée invalide"}}};function Ro(){return{localeError:N_()}}var B_=()=>{let r={string:{unit:"אותיות",verb:"לכלול"},file:{unit:"בייטים",verb:"לכלול"},array:{unit:"פריטים",verb:"לכלול"},set:{unit:"פריטים",verb:"לכלול"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"number";case"object":{if(Array.isArray($))return"array";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"קלט",email:"כתובת אימייל",url:"כתובת רשת",emoji:"אימוג'י",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"תאריך וזמן ISO",date:"תאריך ISO",time:"זמן ISO",duration:"משך זמן ISO",ipv4:"כתובת IPv4",ipv6:"כתובת IPv6",cidrv4:"טווח IPv4",cidrv6:"טווח IPv6",base64:"מחרוזת בבסיס 64",base64url:"מחרוזת בבסיס 64 לכתובות רשת",json_string:"מחרוזת JSON",e164:"מספר E.164",jwt:"JWT",template_literal:"קלט"};return($)=>{switch($.code){case"invalid_type":return`קלט לא תקין: צריך ${$.expected}, התקבל ${c($.input)}`;case"invalid_value":if($.values.length===1)return`קלט לא תקין: צריך ${D($.values[0])}`;return`קלט לא תקין: צריך אחת מהאפשרויות ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`גדול מדי: ${$.origin??"value"} צריך להיות ${o}${$.maximum.toString()} ${U.unit??"elements"}`;return`גדול מדי: ${$.origin??"value"} צריך להיות ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`קטן מדי: ${$.origin} צריך להיות ${o}${$.minimum.toString()} ${U.unit}`;return`קטן מדי: ${$.origin} צריך להיות ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`מחרוזת לא תקינה: חייבת להתחיל ב"${o.prefix}"`;if(o.format==="ends_with")return`מחרוזת לא תקינה: חייבת להסתיים ב "${o.suffix}"`;if(o.format==="includes")return`מחרוזת לא תקינה: חייבת לכלול "${o.includes}"`;if(o.format==="regex")return`מחרוזת לא תקינה: חייבת להתאים לתבנית ${o.pattern}`;return`${g[o.format]??$.format} לא תקין`}case"not_multiple_of":return`מספר לא תקין: חייב להיות מכפלה של ${$.divisor}`;case"unrecognized_keys":return`מפתח${$.keys.length>1?"ות":""} לא מזוה${$.keys.length>1?"ים":"ה"}: ${i($.keys,", ")}`;case"invalid_key":return`מפתח לא תקין ב${$.origin}`;case"invalid_union":return"קלט לא תקין";case"invalid_element":return`ערך לא תקין ב${$.origin}`;default:return"קלט לא תקין"}}};function To(){return{localeError:B_()}}var M_=()=>{let r={string:{unit:"karakter",verb:"legyen"},file:{unit:"byte",verb:"legyen"},array:{unit:"elem",verb:"legyen"},set:{unit:"elem",verb:"legyen"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"szám";case"object":{if(Array.isArray($))return"tömb";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"bemenet",email:"email cím",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO időbélyeg",date:"ISO dátum",time:"ISO idő",duration:"ISO időintervallum",ipv4:"IPv4 cím",ipv6:"IPv6 cím",cidrv4:"IPv4 tartomány",cidrv6:"IPv6 tartomány",base64:"base64-kódolt string",base64url:"base64url-kódolt string",json_string:"JSON string",e164:"E.164 szám",jwt:"JWT",template_literal:"bemenet"};return($)=>{switch($.code){case"invalid_type":return`Érvénytelen bemenet: a várt érték ${$.expected}, a kapott érték ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Érvénytelen bemenet: a várt érték ${D($.values[0])}`;return`Érvénytelen opció: valamelyik érték várt ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Túl nagy: ${$.origin??"érték"} mérete túl nagy ${o}${$.maximum.toString()} ${U.unit??"elem"}`;return`Túl nagy: a bemeneti érték ${$.origin??"érték"} túl nagy: ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Túl kicsi: a bemeneti érték ${$.origin} mérete túl kicsi ${o}${$.minimum.toString()} ${U.unit}`;return`Túl kicsi: a bemeneti érték ${$.origin} túl kicsi ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Érvénytelen string: "${o.prefix}" értékkel kell kezdődnie`;if(o.format==="ends_with")return`Érvénytelen string: "${o.suffix}" értékkel kell végződnie`;if(o.format==="includes")return`Érvénytelen string: "${o.includes}" értéket kell tartalmaznia`;if(o.format==="regex")return`Érvénytelen string: ${o.pattern} mintának kell megfelelnie`;return`Érvénytelen ${g[o.format]??$.format}`}case"not_multiple_of":return`Érvénytelen szám: ${$.divisor} többszörösének kell lennie`;case"unrecognized_keys":return`Ismeretlen kulcs${$.keys.length>1?"s":""}: ${i($.keys,", ")}`;case"invalid_key":return`Érvénytelen kulcs ${$.origin}`;case"invalid_union":return"Érvénytelen bemenet";case"invalid_element":return`Érvénytelen érték: ${$.origin}`;default:return"Érvénytelen bemenet"}}};function lo(){return{localeError:M_()}}var t_=()=>{let r={string:{unit:"karakter",verb:"memiliki"},file:{unit:"byte",verb:"memiliki"},array:{unit:"item",verb:"memiliki"},set:{unit:"item",verb:"memiliki"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"number";case"object":{if(Array.isArray($))return"array";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"input",email:"alamat email",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"tanggal dan waktu format ISO",date:"tanggal format ISO",time:"jam format ISO",duration:"durasi format ISO",ipv4:"alamat IPv4",ipv6:"alamat IPv6",cidrv4:"rentang alamat IPv4",cidrv6:"rentang alamat IPv6",base64:"string dengan enkode base64",base64url:"string dengan enkode base64url",json_string:"string JSON",e164:"angka E.164",jwt:"JWT",template_literal:"input"};return($)=>{switch($.code){case"invalid_type":return`Input tidak valid: diharapkan ${$.expected}, diterima ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Input tidak valid: diharapkan ${D($.values[0])}`;return`Pilihan tidak valid: diharapkan salah satu dari ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Terlalu besar: diharapkan ${$.origin??"value"} memiliki ${o}${$.maximum.toString()} ${U.unit??"elemen"}`;return`Terlalu besar: diharapkan ${$.origin??"value"} menjadi ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Terlalu kecil: diharapkan ${$.origin} memiliki ${o}${$.minimum.toString()} ${U.unit}`;return`Terlalu kecil: diharapkan ${$.origin} menjadi ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`String tidak valid: harus dimulai dengan "${o.prefix}"`;if(o.format==="ends_with")return`String tidak valid: harus berakhir dengan "${o.suffix}"`;if(o.format==="includes")return`String tidak valid: harus menyertakan "${o.includes}"`;if(o.format==="regex")return`String tidak valid: harus sesuai pola ${o.pattern}`;return`${g[o.format]??$.format} tidak valid`}case"not_multiple_of":return`Angka tidak valid: harus kelipatan dari ${$.divisor}`;case"unrecognized_keys":return`Kunci tidak dikenali ${$.keys.length>1?"s":""}: ${i($.keys,", ")}`;case"invalid_key":return`Kunci tidak valid di ${$.origin}`;case"invalid_union":return"Input tidak valid";case"invalid_element":return`Nilai tidak valid di ${$.origin}`;default:return"Input tidak valid"}}};function Zo(){return{localeError:t_()}}var E_=(r)=>{let v=typeof r;switch(v){case"number":return Number.isNaN(r)?"NaN":"númer";case"object":{if(Array.isArray(r))return"fylki";if(r===null)return"null";if(Object.getPrototypeOf(r)!==Object.prototype&&r.constructor)return r.constructor.name}}return v},F_=()=>{let r={string:{unit:"stafi",verb:"að hafa"},file:{unit:"bæti",verb:"að hafa"},array:{unit:"hluti",verb:"að hafa"},set:{unit:"hluti",verb:"að hafa"}};function v(g){return r[g]??null}let c={regex:"gildi",email:"netfang",url:"vefslóð",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO dagsetning og tími",date:"ISO dagsetning",time:"ISO tími",duration:"ISO tímalengd",ipv4:"IPv4 address",ipv6:"IPv6 address",cidrv4:"IPv4 range",cidrv6:"IPv6 range",base64:"base64-encoded strengur",base64url:"base64url-encoded strengur",json_string:"JSON strengur",e164:"E.164 tölugildi",jwt:"JWT",template_literal:"gildi"};return(g)=>{switch(g.code){case"invalid_type":return`Rangt gildi: Þú slóst inn ${E_(g.input)} þar sem á að vera ${g.expected}`;case"invalid_value":if(g.values.length===1)return`Rangt gildi: gert ráð fyrir ${D(g.values[0])}`;return`Ógilt val: má vera eitt af eftirfarandi ${i(g.values,"|")}`;case"too_big":{let $=g.inclusive?"<=":"<",o=v(g.origin);if(o)return`Of stórt: gert er ráð fyrir að ${g.origin??"gildi"} hafi ${$}${g.maximum.toString()} ${o.unit??"hluti"}`;return`Of stórt: gert er ráð fyrir að ${g.origin??"gildi"} sé ${$}${g.maximum.toString()}`}case"too_small":{let $=g.inclusive?">=":">",o=v(g.origin);if(o)return`Of lítið: gert er ráð fyrir að ${g.origin} hafi ${$}${g.minimum.toString()} ${o.unit}`;return`Of lítið: gert er ráð fyrir að ${g.origin} sé ${$}${g.minimum.toString()}`}case"invalid_format":{let $=g;if($.format==="starts_with")return`Ógildur strengur: verður að byrja á "${$.prefix}"`;if($.format==="ends_with")return`Ógildur strengur: verður að enda á "${$.suffix}"`;if($.format==="includes")return`Ógildur strengur: verður að innihalda "${$.includes}"`;if($.format==="regex")return`Ógildur strengur: verður að fylgja mynstri ${$.pattern}`;return`Rangt ${c[$.format]??g.format}`}case"not_multiple_of":return`Röng tala: verður að vera margfeldi af ${g.divisor}`;case"unrecognized_keys":return`Óþekkt ${g.keys.length>1?"ir lyklar":"ur lykill"}: ${i(g.keys,", ")}`;case"invalid_key":return`Rangur lykill í ${g.origin}`;case"invalid_union":return"Rangt gildi";case"invalid_element":return`Rangt gildi í ${g.origin}`;default:return"Rangt gildi"}}};function qo(){return{localeError:F_()}}var V_=()=>{let r={string:{unit:"caratteri",verb:"avere"},file:{unit:"byte",verb:"avere"},array:{unit:"elementi",verb:"avere"},set:{unit:"elementi",verb:"avere"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"numero";case"object":{if(Array.isArray($))return"vettore";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"input",email:"indirizzo email",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"data e ora ISO",date:"data ISO",time:"ora ISO",duration:"durata ISO",ipv4:"indirizzo IPv4",ipv6:"indirizzo IPv6",cidrv4:"intervallo IPv4",cidrv6:"intervallo IPv6",base64:"stringa codificata in base64",base64url:"URL codificata in base64",json_string:"stringa JSON",e164:"numero E.164",jwt:"JWT",template_literal:"input"};return($)=>{switch($.code){case"invalid_type":return`Input non valido: atteso ${$.expected}, ricevuto ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Input non valido: atteso ${D($.values[0])}`;return`Opzione non valida: atteso uno tra ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Troppo grande: ${$.origin??"valore"} deve avere ${o}${$.maximum.toString()} ${U.unit??"elementi"}`;return`Troppo grande: ${$.origin??"valore"} deve essere ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Troppo piccolo: ${$.origin} deve avere ${o}${$.minimum.toString()} ${U.unit}`;return`Troppo piccolo: ${$.origin} deve essere ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Stringa non valida: deve iniziare con "${o.prefix}"`;if(o.format==="ends_with")return`Stringa non valida: deve terminare con "${o.suffix}"`;if(o.format==="includes")return`Stringa non valida: deve includere "${o.includes}"`;if(o.format==="regex")return`Stringa non valida: deve corrispondere al pattern ${o.pattern}`;return`Invalid ${g[o.format]??$.format}`}case"not_multiple_of":return`Numero non valido: deve essere un multiplo di ${$.divisor}`;case"unrecognized_keys":return`Chiav${$.keys.length>1?"i":"e"} non riconosciut${$.keys.length>1?"e":"a"}: ${i($.keys,", ")}`;case"invalid_key":return`Chiave non valida in ${$.origin}`;case"invalid_union":return"Input non valido";case"invalid_element":return`Valore non valido in ${$.origin}`;default:return"Input non valido"}}};function Co(){return{localeError:V_()}}var m_=()=>{let r={string:{unit:"文字",verb:"である"},file:{unit:"バイト",verb:"である"},array:{unit:"要素",verb:"である"},set:{unit:"要素",verb:"である"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"数値";case"object":{if(Array.isArray($))return"配列";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"入力値",email:"メールアドレス",url:"URL",emoji:"絵文字",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO日時",date:"ISO日付",time:"ISO時刻",duration:"ISO期間",ipv4:"IPv4アドレス",ipv6:"IPv6アドレス",cidrv4:"IPv4範囲",cidrv6:"IPv6範囲",base64:"base64エンコード文字列",base64url:"base64urlエンコード文字列",json_string:"JSON文字列",e164:"E.164番号",jwt:"JWT",template_literal:"入力値"};return($)=>{switch($.code){case"invalid_type":return`無効な入力: ${$.expected}が期待されましたが、${c($.input)}が入力されました`;case"invalid_value":if($.values.length===1)return`無効な入力: ${D($.values[0])}が期待されました`;return`無効な選択: ${i($.values,"、")}のいずれかである必要があります`;case"too_big":{let o=$.inclusive?"以下である":"より小さい",U=v($.origin);if(U)return`大きすぎる値: ${$.origin??"値"}は${$.maximum.toString()}${U.unit??"要素"}${o}必要があります`;return`大きすぎる値: ${$.origin??"値"}は${$.maximum.toString()}${o}必要があります`}case"too_small":{let o=$.inclusive?"以上である":"より大きい",U=v($.origin);if(U)return`小さすぎる値: ${$.origin}は${$.minimum.toString()}${U.unit}${o}必要があります`;return`小さすぎる値: ${$.origin}は${$.minimum.toString()}${o}必要があります`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`無効な文字列: "${o.prefix}"で始まる必要があります`;if(o.format==="ends_with")return`無効な文字列: "${o.suffix}"で終わる必要があります`;if(o.format==="includes")return`無効な文字列: "${o.includes}"を含む必要があります`;if(o.format==="regex")return`無効な文字列: パターン${o.pattern}に一致する必要があります`;return`無効な${g[o.format]??$.format}`}case"not_multiple_of":return`無効な数値: ${$.divisor}の倍数である必要があります`;case"unrecognized_keys":return`認識されていないキー${$.keys.length>1?"群":""}: ${i($.keys,"、")}`;case"invalid_key":return`${$.origin}内の無効なキー`;case"invalid_union":return"無効な入力";case"invalid_element":return`${$.origin}内の無効な値`;default:return"無効な入力"}}};function ho(){return{localeError:m_()}}var R_=()=>{let r={string:{unit:"តួអក្សរ",verb:"គួរមាន"},file:{unit:"បៃ",verb:"គួរមាន"},array:{unit:"ធាតុ",verb:"គួរមាន"},set:{unit:"ធាតុ",verb:"គួរមាន"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"មិនមែនជាលេខ (NaN)":"លេខ";case"object":{if(Array.isArray($))return"អារេ (Array)";if($===null)return"គ្មានតម្លៃ (null)";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"ទិន្នន័យបញ្ចូល",email:"អាសយដ្ឋានអ៊ីមែល",url:"URL",emoji:"សញ្ញាអារម្មណ៍",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"កាលបរិច្ឆេទ និងម៉ោង ISO",date:"កាលបរិច្ឆេទ ISO",time:"ម៉ោង ISO",duration:"រយៈពេល ISO",ipv4:"អាសយដ្ឋាន IPv4",ipv6:"អាសយដ្ឋាន IPv6",cidrv4:"ដែនអាសយដ្ឋាន IPv4",cidrv6:"ដែនអាសយដ្ឋាន IPv6",base64:"ខ្សែអក្សរអ៊ិកូដ base64",base64url:"ខ្សែអក្សរអ៊ិកូដ base64url",json_string:"ខ្សែអក្សរ JSON",e164:"លេខ E.164",jwt:"JWT",template_literal:"ទិន្នន័យបញ្ចូល"};return($)=>{switch($.code){case"invalid_type":return`ទិន្នន័យបញ្ចូលមិនត្រឹមត្រូវ៖ ត្រូវការ ${$.expected} ប៉ុន្តែទទួលបាន ${c($.input)}`;case"invalid_value":if($.values.length===1)return`ទិន្នន័យបញ្ចូលមិនត្រឹមត្រូវ៖ ត្រូវការ ${D($.values[0])}`;return`ជម្រើសមិនត្រឹមត្រូវ៖ ត្រូវជាមួយក្នុងចំណោម ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`ធំពេក៖ ត្រូវការ ${$.origin??"តម្លៃ"} ${o} ${$.maximum.toString()} ${U.unit??"ធាតុ"}`;return`ធំពេក៖ ត្រូវការ ${$.origin??"តម្លៃ"} ${o} ${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`តូចពេក៖ ត្រូវការ ${$.origin} ${o} ${$.minimum.toString()} ${U.unit}`;return`តូចពេក៖ ត្រូវការ ${$.origin} ${o} ${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`ខ្សែអក្សរមិនត្រឹមត្រូវ៖ ត្រូវចាប់ផ្តើមដោយ "${o.prefix}"`;if(o.format==="ends_with")return`ខ្សែអក្សរមិនត្រឹមត្រូវ៖ ត្រូវបញ្ចប់ដោយ "${o.suffix}"`;if(o.format==="includes")return`ខ្សែអក្សរមិនត្រឹមត្រូវ៖ ត្រូវមាន "${o.includes}"`;if(o.format==="regex")return`ខ្សែអក្សរមិនត្រឹមត្រូវ៖ ត្រូវតែផ្គូផ្គងនឹងទម្រង់ដែលបានកំណត់ ${o.pattern}`;return`មិនត្រឹមត្រូវ៖ ${g[o.format]??$.format}`}case"not_multiple_of":return`លេខមិនត្រឹមត្រូវ៖ ត្រូវតែជាពហុគុណនៃ ${$.divisor}`;case"unrecognized_keys":return`រកឃើញសោមិនស្គាល់៖ ${i($.keys,", ")}`;case"invalid_key":return`សោមិនត្រឹមត្រូវនៅក្នុង ${$.origin}`;case"invalid_union":return"ទិន្នន័យមិនត្រឹមត្រូវ";case"invalid_element":return`ទិន្នន័យមិនត្រឹមត្រូវនៅក្នុង ${$.origin}`;default:return"ទិន្នន័យមិនត្រឹមត្រូវ"}}};function fo(){return{localeError:R_()}}var T_=()=>{let r={string:{unit:"문자",verb:"to have"},file:{unit:"바이트",verb:"to have"},array:{unit:"개",verb:"to have"},set:{unit:"개",verb:"to have"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"number";case"object":{if(Array.isArray($))return"array";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"입력",email:"이메일 주소",url:"URL",emoji:"이모지",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO 날짜시간",date:"ISO 날짜",time:"ISO 시간",duration:"ISO 기간",ipv4:"IPv4 주소",ipv6:"IPv6 주소",cidrv4:"IPv4 범위",cidrv6:"IPv6 범위",base64:"base64 인코딩 문자열",base64url:"base64url 인코딩 문자열",json_string:"JSON 문자열",e164:"E.164 번호",jwt:"JWT",template_literal:"입력"};return($)=>{switch($.code){case"invalid_type":return`잘못된 입력: 예상 타입은 ${$.expected}, 받은 타입은 ${c($.input)}입니다`;case"invalid_value":if($.values.length===1)return`잘못된 입력: 값은 ${D($.values[0])} 이어야 합니다`;return`잘못된 옵션: ${i($.values,"또는 ")} 중 하나여야 합니다`;case"too_big":{let o=$.inclusive?"이하":"미만",U=o==="미만"?"이어야 합니다":"여야 합니다",_=v($.origin),j=_?.unit??"요소";if(_)return`${$.origin??"값"}이 너무 큽니다: ${$.maximum.toString()}${j} ${o}${U}`;return`${$.origin??"값"}이 너무 큽니다: ${$.maximum.toString()} ${o}${U}`}case"too_small":{let o=$.inclusive?"이상":"초과",U=o==="이상"?"이어야 합니다":"여야 합니다",_=v($.origin),j=_?.unit??"요소";if(_)return`${$.origin??"값"}이 너무 작습니다: ${$.minimum.toString()}${j} ${o}${U}`;return`${$.origin??"값"}이 너무 작습니다: ${$.minimum.toString()} ${o}${U}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`잘못된 문자열: "${o.prefix}"(으)로 시작해야 합니다`;if(o.format==="ends_with")return`잘못된 문자열: "${o.suffix}"(으)로 끝나야 합니다`;if(o.format==="includes")return`잘못된 문자열: "${o.includes}"을(를) 포함해야 합니다`;if(o.format==="regex")return`잘못된 문자열: 정규식 ${o.pattern} 패턴과 일치해야 합니다`;return`잘못된 ${g[o.format]??$.format}`}case"not_multiple_of":return`잘못된 숫자: ${$.divisor}의 배수여야 합니다`;case"unrecognized_keys":return`인식할 수 없는 키: ${i($.keys,", ")}`;case"invalid_key":return`잘못된 키: ${$.origin}`;case"invalid_union":return"잘못된 입력";case"invalid_element":return`잘못된 값: ${$.origin}`;default:return"잘못된 입력"}}};function yo(){return{localeError:T_()}}var l_=()=>{let r={string:{unit:"знаци",verb:"да имаат"},file:{unit:"бајти",verb:"да имаат"},array:{unit:"ставки",verb:"да имаат"},set:{unit:"ставки",verb:"да имаат"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"број";case"object":{if(Array.isArray($))return"низа";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"внес",email:"адреса на е-пошта",url:"URL",emoji:"емоџи",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO датум и време",date:"ISO датум",time:"ISO време",duration:"ISO времетраење",ipv4:"IPv4 адреса",ipv6:"IPv6 адреса",cidrv4:"IPv4 опсег",cidrv6:"IPv6 опсег",base64:"base64-енкодирана низа",base64url:"base64url-енкодирана низа",json_string:"JSON низа",e164:"E.164 број",jwt:"JWT",template_literal:"внес"};return($)=>{switch($.code){case"invalid_type":return`Грешен внес: се очекува ${$.expected}, примено ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Invalid input: expected ${D($.values[0])}`;return`Грешана опција: се очекува една ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Премногу голем: се очекува ${$.origin??"вредноста"} да има ${o}${$.maximum.toString()} ${U.unit??"елементи"}`;return`Премногу голем: се очекува ${$.origin??"вредноста"} да биде ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Премногу мал: се очекува ${$.origin} да има ${o}${$.minimum.toString()} ${U.unit}`;return`Премногу мал: се очекува ${$.origin} да биде ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Неважечка низа: мора да започнува со "${o.prefix}"`;if(o.format==="ends_with")return`Неважечка низа: мора да завршува со "${o.suffix}"`;if(o.format==="includes")return`Неважечка низа: мора да вклучува "${o.includes}"`;if(o.format==="regex")return`Неважечка низа: мора да одгоара на патернот ${o.pattern}`;return`Invalid ${g[o.format]??$.format}`}case"not_multiple_of":return`Грешен број: мора да биде делив со ${$.divisor}`;case"unrecognized_keys":return`${$.keys.length>1?"Непрепознаени клучеви":"Непрепознаен клуч"}: ${i($.keys,", ")}`;case"invalid_key":return`Грешен клуч во ${$.origin}`;case"invalid_union":return"Грешен внес";case"invalid_element":return`Грешна вредност во ${$.origin}`;default:return"Грешен внес"}}};function po(){return{localeError:l_()}}var Z_=()=>{let r={string:{unit:"aksara",verb:"mempunyai"},file:{unit:"bait",verb:"mempunyai"},array:{unit:"elemen",verb:"mempunyai"},set:{unit:"elemen",verb:"mempunyai"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"nombor";case"object":{if(Array.isArray($))return"array";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"input",email:"alamat e-mel",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"tarikh masa ISO",date:"tarikh ISO",time:"masa ISO",duration:"tempoh ISO",ipv4:"alamat IPv4",ipv6:"alamat IPv6",cidrv4:"julat IPv4",cidrv6:"julat IPv6",base64:"string dikodkan base64",base64url:"string dikodkan base64url",json_string:"string JSON",e164:"nombor E.164",jwt:"JWT",template_literal:"input"};return($)=>{switch($.code){case"invalid_type":return`Input tidak sah: dijangka ${$.expected}, diterima ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Input tidak sah: dijangka ${D($.values[0])}`;return`Pilihan tidak sah: dijangka salah satu daripada ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Terlalu besar: dijangka ${$.origin??"nilai"} ${U.verb} ${o}${$.maximum.toString()} ${U.unit??"elemen"}`;return`Terlalu besar: dijangka ${$.origin??"nilai"} adalah ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Terlalu kecil: dijangka ${$.origin} ${U.verb} ${o}${$.minimum.toString()} ${U.unit}`;return`Terlalu kecil: dijangka ${$.origin} adalah ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`String tidak sah: mesti bermula dengan "${o.prefix}"`;if(o.format==="ends_with")return`String tidak sah: mesti berakhir dengan "${o.suffix}"`;if(o.format==="includes")return`String tidak sah: mesti mengandungi "${o.includes}"`;if(o.format==="regex")return`String tidak sah: mesti sepadan dengan corak ${o.pattern}`;return`${g[o.format]??$.format} tidak sah`}case"not_multiple_of":return`Nombor tidak sah: perlu gandaan ${$.divisor}`;case"unrecognized_keys":return`Kunci tidak dikenali: ${i($.keys,", ")}`;case"invalid_key":return`Kunci tidak sah dalam ${$.origin}`;case"invalid_union":return"Input tidak sah";case"invalid_element":return`Nilai tidak sah dalam ${$.origin}`;default:return"Input tidak sah"}}};function ao(){return{localeError:Z_()}}var q_=()=>{let r={string:{unit:"tekens"},file:{unit:"bytes"},array:{unit:"elementen"},set:{unit:"elementen"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"getal";case"object":{if(Array.isArray($))return"array";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"invoer",email:"emailadres",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO datum en tijd",date:"ISO datum",time:"ISO tijd",duration:"ISO duur",ipv4:"IPv4-adres",ipv6:"IPv6-adres",cidrv4:"IPv4-bereik",cidrv6:"IPv6-bereik",base64:"base64-gecodeerde tekst",base64url:"base64 URL-gecodeerde tekst",json_string:"JSON string",e164:"E.164-nummer",jwt:"JWT",template_literal:"invoer"};return($)=>{switch($.code){case"invalid_type":return`Ongeldige invoer: verwacht ${$.expected}, ontving ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Ongeldige invoer: verwacht ${D($.values[0])}`;return`Ongeldige optie: verwacht één van ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Te lang: verwacht dat ${$.origin??"waarde"} ${o}${$.maximum.toString()} ${U.unit??"elementen"} bevat`;return`Te lang: verwacht dat ${$.origin??"waarde"} ${o}${$.maximum.toString()} is`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Te kort: verwacht dat ${$.origin} ${o}${$.minimum.toString()} ${U.unit} bevat`;return`Te kort: verwacht dat ${$.origin} ${o}${$.minimum.toString()} is`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Ongeldige tekst: moet met "${o.prefix}" beginnen`;if(o.format==="ends_with")return`Ongeldige tekst: moet op "${o.suffix}" eindigen`;if(o.format==="includes")return`Ongeldige tekst: moet "${o.includes}" bevatten`;if(o.format==="regex")return`Ongeldige tekst: moet overeenkomen met patroon ${o.pattern}`;return`Ongeldig: ${g[o.format]??$.format}`}case"not_multiple_of":return`Ongeldig getal: moet een veelvoud van ${$.divisor} zijn`;case"unrecognized_keys":return`Onbekende key${$.keys.length>1?"s":""}: ${i($.keys,", ")}`;case"invalid_key":return`Ongeldige key in ${$.origin}`;case"invalid_union":return"Ongeldige invoer";case"invalid_element":return`Ongeldige waarde in ${$.origin}`;default:return"Ongeldige invoer"}}};function eo(){return{localeError:q_()}}var C_=()=>{let r={string:{unit:"tegn",verb:"å ha"},file:{unit:"bytes",verb:"å ha"},array:{unit:"elementer",verb:"å inneholde"},set:{unit:"elementer",verb:"å inneholde"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"tall";case"object":{if(Array.isArray($))return"liste";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"input",email:"e-postadresse",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO dato- og klokkeslett",date:"ISO-dato",time:"ISO-klokkeslett",duration:"ISO-varighet",ipv4:"IPv4-område",ipv6:"IPv6-område",cidrv4:"IPv4-spekter",cidrv6:"IPv6-spekter",base64:"base64-enkodet streng",base64url:"base64url-enkodet streng",json_string:"JSON-streng",e164:"E.164-nummer",jwt:"JWT",template_literal:"input"};return($)=>{switch($.code){case"invalid_type":return`Ugyldig input: forventet ${$.expected}, fikk ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Ugyldig verdi: forventet ${D($.values[0])}`;return`Ugyldig valg: forventet en av ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`For stor(t): forventet ${$.origin??"value"} til å ha ${o}${$.maximum.toString()} ${U.unit??"elementer"}`;return`For stor(t): forventet ${$.origin??"value"} til å ha ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`For lite(n): forventet ${$.origin} til å ha ${o}${$.minimum.toString()} ${U.unit}`;return`For lite(n): forventet ${$.origin} til å ha ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Ugyldig streng: må starte med "${o.prefix}"`;if(o.format==="ends_with")return`Ugyldig streng: må ende med "${o.suffix}"`;if(o.format==="includes")return`Ugyldig streng: må inneholde "${o.includes}"`;if(o.format==="regex")return`Ugyldig streng: må matche mønsteret ${o.pattern}`;return`Ugyldig ${g[o.format]??$.format}`}case"not_multiple_of":return`Ugyldig tall: må være et multiplum av ${$.divisor}`;case"unrecognized_keys":return`${$.keys.length>1?"Ukjente nøkler":"Ukjent nøkkel"}: ${i($.keys,", ")}`;case"invalid_key":return`Ugyldig nøkkel i ${$.origin}`;case"invalid_union":return"Ugyldig input";case"invalid_element":return`Ugyldig verdi i ${$.origin}`;default:return"Ugyldig input"}}};function so(){return{localeError:C_()}}var h_=()=>{let r={string:{unit:"harf",verb:"olmalıdır"},file:{unit:"bayt",verb:"olmalıdır"},array:{unit:"unsur",verb:"olmalıdır"},set:{unit:"unsur",verb:"olmalıdır"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"numara";case"object":{if(Array.isArray($))return"saf";if($===null)return"gayb";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"giren",email:"epostagâh",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO hengâmı",date:"ISO tarihi",time:"ISO zamanı",duration:"ISO müddeti",ipv4:"IPv4 nişânı",ipv6:"IPv6 nişânı",cidrv4:"IPv4 menzili",cidrv6:"IPv6 menzili",base64:"base64-şifreli metin",base64url:"base64url-şifreli metin",json_string:"JSON metin",e164:"E.164 sayısı",jwt:"JWT",template_literal:"giren"};return($)=>{switch($.code){case"invalid_type":return`Fâsit giren: umulan ${$.expected}, alınan ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Fâsit giren: umulan ${D($.values[0])}`;return`Fâsit tercih: mûteberler ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Fazla büyük: ${$.origin??"value"}, ${o}${$.maximum.toString()} ${U.unit??"elements"} sahip olmalıydı.`;return`Fazla büyük: ${$.origin??"value"}, ${o}${$.maximum.toString()} olmalıydı.`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Fazla küçük: ${$.origin}, ${o}${$.minimum.toString()} ${U.unit} sahip olmalıydı.`;return`Fazla küçük: ${$.origin}, ${o}${$.minimum.toString()} olmalıydı.`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Fâsit metin: "${o.prefix}" ile başlamalı.`;if(o.format==="ends_with")return`Fâsit metin: "${o.suffix}" ile bitmeli.`;if(o.format==="includes")return`Fâsit metin: "${o.includes}" ihtivâ etmeli.`;if(o.format==="regex")return`Fâsit metin: ${o.pattern} nakşına uymalı.`;return`Fâsit ${g[o.format]??$.format}`}case"not_multiple_of":return`Fâsit sayı: ${$.divisor} katı olmalıydı.`;case"unrecognized_keys":return`Tanınmayan anahtar ${$.keys.length>1?"s":""}: ${i($.keys,", ")}`;case"invalid_key":return`${$.origin} için tanınmayan anahtar var.`;case"invalid_union":return"Giren tanınamadı.";case"invalid_element":return`${$.origin} için tanınmayan kıymet var.`;default:return"Kıymet tanınamadı."}}};function rg(){return{localeError:h_()}}var f_=()=>{let r={string:{unit:"توکي",verb:"ولري"},file:{unit:"بایټس",verb:"ولري"},array:{unit:"توکي",verb:"ولري"},set:{unit:"توکي",verb:"ولري"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"عدد";case"object":{if(Array.isArray($))return"ارې";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"ورودي",email:"بریښنالیک",url:"یو آر ال",emoji:"ایموجي",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"نیټه او وخت",date:"نېټه",time:"وخت",duration:"موده",ipv4:"د IPv4 پته",ipv6:"د IPv6 پته",cidrv4:"د IPv4 ساحه",cidrv6:"د IPv6 ساحه",base64:"base64-encoded متن",base64url:"base64url-encoded متن",json_string:"JSON متن",e164:"د E.164 شمېره",jwt:"JWT",template_literal:"ورودي"};return($)=>{switch($.code){case"invalid_type":return`ناسم ورودي: باید ${$.expected} وای, مګر ${c($.input)} ترلاسه شو`;case"invalid_value":if($.values.length===1)return`ناسم ورودي: باید ${D($.values[0])} وای`;return`ناسم انتخاب: باید یو له ${i($.values,"|")} څخه وای`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`ډیر لوی: ${$.origin??"ارزښت"} باید ${o}${$.maximum.toString()} ${U.unit??"عنصرونه"} ولري`;return`ډیر لوی: ${$.origin??"ارزښت"} باید ${o}${$.maximum.toString()} وي`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`ډیر کوچنی: ${$.origin} باید ${o}${$.minimum.toString()} ${U.unit} ولري`;return`ډیر کوچنی: ${$.origin} باید ${o}${$.minimum.toString()} وي`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`ناسم متن: باید د "${o.prefix}" سره پیل شي`;if(o.format==="ends_with")return`ناسم متن: باید د "${o.suffix}" سره پای ته ورسيږي`;if(o.format==="includes")return`ناسم متن: باید "${o.includes}" ولري`;if(o.format==="regex")return`ناسم متن: باید د ${o.pattern} سره مطابقت ولري`;return`${g[o.format]??$.format} ناسم دی`}case"not_multiple_of":return`ناسم عدد: باید د ${$.divisor} مضرب وي`;case"unrecognized_keys":return`ناسم ${$.keys.length>1?"کلیډونه":"کلیډ"}: ${i($.keys,", ")}`;case"invalid_key":return`ناسم کلیډ په ${$.origin} کې`;case"invalid_union":return"ناسمه ورودي";case"invalid_element":return`ناسم عنصر په ${$.origin} کې`;default:return"ناسمه ورودي"}}};function $g(){return{localeError:f_()}}var y_=()=>{let r={string:{unit:"znaków",verb:"mieć"},file:{unit:"bajtów",verb:"mieć"},array:{unit:"elementów",verb:"mieć"},set:{unit:"elementów",verb:"mieć"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"liczba";case"object":{if(Array.isArray($))return"tablica";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"wyrażenie",email:"adres email",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"data i godzina w formacie ISO",date:"data w formacie ISO",time:"godzina w formacie ISO",duration:"czas trwania ISO",ipv4:"adres IPv4",ipv6:"adres IPv6",cidrv4:"zakres IPv4",cidrv6:"zakres IPv6",base64:"ciąg znaków zakodowany w formacie base64",base64url:"ciąg znaków zakodowany w formacie base64url",json_string:"ciąg znaków w formacie JSON",e164:"liczba E.164",jwt:"JWT",template_literal:"wejście"};return($)=>{switch($.code){case"invalid_type":return`Nieprawidłowe dane wejściowe: oczekiwano ${$.expected}, otrzymano ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Nieprawidłowe dane wejściowe: oczekiwano ${D($.values[0])}`;return`Nieprawidłowa opcja: oczekiwano jednej z wartości ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Za duża wartość: oczekiwano, że ${$.origin??"wartość"} będzie mieć ${o}${$.maximum.toString()} ${U.unit??"elementów"}`;return`Zbyt duż(y/a/e): oczekiwano, że ${$.origin??"wartość"} będzie wynosić ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Za mała wartość: oczekiwano, że ${$.origin??"wartość"} będzie mieć ${o}${$.minimum.toString()} ${U.unit??"elementów"}`;return`Zbyt mał(y/a/e): oczekiwano, że ${$.origin??"wartość"} będzie wynosić ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Nieprawidłowy ciąg znaków: musi zaczynać się od "${o.prefix}"`;if(o.format==="ends_with")return`Nieprawidłowy ciąg znaków: musi kończyć się na "${o.suffix}"`;if(o.format==="includes")return`Nieprawidłowy ciąg znaków: musi zawierać "${o.includes}"`;if(o.format==="regex")return`Nieprawidłowy ciąg znaków: musi odpowiadać wzorcowi ${o.pattern}`;return`Nieprawidłow(y/a/e) ${g[o.format]??$.format}`}case"not_multiple_of":return`Nieprawidłowa liczba: musi być wielokrotnością ${$.divisor}`;case"unrecognized_keys":return`Nierozpoznane klucze${$.keys.length>1?"s":""}: ${i($.keys,", ")}`;case"invalid_key":return`Nieprawidłowy klucz w ${$.origin}`;case"invalid_union":return"Nieprawidłowe dane wejściowe";case"invalid_element":return`Nieprawidłowa wartość w ${$.origin}`;default:return"Nieprawidłowe dane wejściowe"}}};function vg(){return{localeError:y_()}}var p_=()=>{let r={string:{unit:"caracteres",verb:"ter"},file:{unit:"bytes",verb:"ter"},array:{unit:"itens",verb:"ter"},set:{unit:"itens",verb:"ter"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"número";case"object":{if(Array.isArray($))return"array";if($===null)return"nulo";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"padrão",email:"endereço de e-mail",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"data e hora ISO",date:"data ISO",time:"hora ISO",duration:"duração ISO",ipv4:"endereço IPv4",ipv6:"endereço IPv6",cidrv4:"faixa de IPv4",cidrv6:"faixa de IPv6",base64:"texto codificado em base64",base64url:"URL codificada em base64",json_string:"texto JSON",e164:"número E.164",jwt:"JWT",template_literal:"entrada"};return($)=>{switch($.code){case"invalid_type":return`Tipo inválido: esperado ${$.expected}, recebido ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Entrada inválida: esperado ${D($.values[0])}`;return`Opção inválida: esperada uma das ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Muito grande: esperado que ${$.origin??"valor"} tivesse ${o}${$.maximum.toString()} ${U.unit??"elementos"}`;return`Muito grande: esperado que ${$.origin??"valor"} fosse ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Muito pequeno: esperado que ${$.origin} tivesse ${o}${$.minimum.toString()} ${U.unit}`;return`Muito pequeno: esperado que ${$.origin} fosse ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Texto inválido: deve começar com "${o.prefix}"`;if(o.format==="ends_with")return`Texto inválido: deve terminar com "${o.suffix}"`;if(o.format==="includes")return`Texto inválido: deve incluir "${o.includes}"`;if(o.format==="regex")return`Texto inválido: deve corresponder ao padrão ${o.pattern}`;return`${g[o.format]??$.format} inválido`}case"not_multiple_of":return`Número inválido: deve ser múltiplo de ${$.divisor}`;case"unrecognized_keys":return`Chave${$.keys.length>1?"s":""} desconhecida${$.keys.length>1?"s":""}: ${i($.keys,", ")}`;case"invalid_key":return`Chave inválida em ${$.origin}`;case"invalid_union":return"Entrada inválida";case"invalid_element":return`Valor inválido em ${$.origin}`;default:return"Campo inválido"}}};function cg(){return{localeError:p_()}}function E6(r,v,c,g){let $=Math.abs(r),o=$%10,U=$%100;if(U>=11&&U<=19)return g;if(o===1)return v;if(o>=2&&o<=4)return c;return g}var d_=()=>{let r={string:{unit:{one:"символ",few:"символа",many:"символов"},verb:"иметь"},file:{unit:{one:"байт",few:"байта",many:"байт"},verb:"иметь"},array:{unit:{one:"элемент",few:"элемента",many:"элементов"},verb:"иметь"},set:{unit:{one:"элемент",few:"элемента",many:"элементов"},verb:"иметь"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"число";case"object":{if(Array.isArray($))return"массив";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"ввод",email:"email адрес",url:"URL",emoji:"эмодзи",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO дата и время",date:"ISO дата",time:"ISO время",duration:"ISO длительность",ipv4:"IPv4 адрес",ipv6:"IPv6 адрес",cidrv4:"IPv4 диапазон",cidrv6:"IPv6 диапазон",base64:"строка в формате base64",base64url:"строка в формате base64url",json_string:"JSON строка",e164:"номер E.164",jwt:"JWT",template_literal:"ввод"};return($)=>{switch($.code){case"invalid_type":return`Неверный ввод: ожидалось ${$.expected}, получено ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Неверный ввод: ожидалось ${D($.values[0])}`;return`Неверный вариант: ожидалось одно из ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U){let _=Number($.maximum),j=E6(_,U.unit.one,U.unit.few,U.unit.many);return`Слишком большое значение: ожидалось, что ${$.origin??"значение"} будет иметь ${o}${$.maximum.toString()} ${j}`}return`Слишком большое значение: ожидалось, что ${$.origin??"значение"} будет ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U){let _=Number($.minimum),j=E6(_,U.unit.one,U.unit.few,U.unit.many);return`Слишком маленькое значение: ожидалось, что ${$.origin} будет иметь ${o}${$.minimum.toString()} ${j}`}return`Слишком маленькое значение: ожидалось, что ${$.origin} будет ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Неверная строка: должна начинаться с "${o.prefix}"`;if(o.format==="ends_with")return`Неверная строка: должна заканчиваться на "${o.suffix}"`;if(o.format==="includes")return`Неверная строка: должна содержать "${o.includes}"`;if(o.format==="regex")return`Неверная строка: должна соответствовать шаблону ${o.pattern}`;return`Неверный ${g[o.format]??$.format}`}case"not_multiple_of":return`Неверное число: должно быть кратным ${$.divisor}`;case"unrecognized_keys":return`Нераспознанн${$.keys.length>1?"ые":"ый"} ключ${$.keys.length>1?"и":""}: ${i($.keys,", ")}`;case"invalid_key":return`Неверный ключ в ${$.origin}`;case"invalid_union":return"Неверные входные данные";case"invalid_element":return`Неверное значение в ${$.origin}`;default:return"Неверные входные данные"}}};function og(){return{localeError:d_()}}var a_=()=>{let r={string:{unit:"znakov",verb:"imeti"},file:{unit:"bajtov",verb:"imeti"},array:{unit:"elementov",verb:"imeti"},set:{unit:"elementov",verb:"imeti"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"število";case"object":{if(Array.isArray($))return"tabela";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"vnos",email:"e-poštni naslov",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO datum in čas",date:"ISO datum",time:"ISO čas",duration:"ISO trajanje",ipv4:"IPv4 naslov",ipv6:"IPv6 naslov",cidrv4:"obseg IPv4",cidrv6:"obseg IPv6",base64:"base64 kodiran niz",base64url:"base64url kodiran niz",json_string:"JSON niz",e164:"E.164 številka",jwt:"JWT",template_literal:"vnos"};return($)=>{switch($.code){case"invalid_type":return`Neveljaven vnos: pričakovano ${$.expected}, prejeto ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Neveljaven vnos: pričakovano ${D($.values[0])}`;return`Neveljavna možnost: pričakovano eno izmed ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Preveliko: pričakovano, da bo ${$.origin??"vrednost"} imelo ${o}${$.maximum.toString()} ${U.unit??"elementov"}`;return`Preveliko: pričakovano, da bo ${$.origin??"vrednost"} ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Premajhno: pričakovano, da bo ${$.origin} imelo ${o}${$.minimum.toString()} ${U.unit}`;return`Premajhno: pričakovano, da bo ${$.origin} ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Neveljaven niz: mora se začeti z "${o.prefix}"`;if(o.format==="ends_with")return`Neveljaven niz: mora se končati z "${o.suffix}"`;if(o.format==="includes")return`Neveljaven niz: mora vsebovati "${o.includes}"`;if(o.format==="regex")return`Neveljaven niz: mora ustrezati vzorcu ${o.pattern}`;return`Neveljaven ${g[o.format]??$.format}`}case"not_multiple_of":return`Neveljavno število: mora biti večkratnik ${$.divisor}`;case"unrecognized_keys":return`Neprepoznan${$.keys.length>1?"i ključi":" ključ"}: ${i($.keys,", ")}`;case"invalid_key":return`Neveljaven ključ v ${$.origin}`;case"invalid_union":return"Neveljaven vnos";case"invalid_element":return`Neveljavna vrednost v ${$.origin}`;default:return"Neveljaven vnos"}}};function gg(){return{localeError:a_()}}var e_=()=>{let r={string:{unit:"tecken",verb:"att ha"},file:{unit:"bytes",verb:"att ha"},array:{unit:"objekt",verb:"att innehålla"},set:{unit:"objekt",verb:"att innehålla"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"antal";case"object":{if(Array.isArray($))return"lista";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"reguljärt uttryck",email:"e-postadress",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO-datum och tid",date:"ISO-datum",time:"ISO-tid",duration:"ISO-varaktighet",ipv4:"IPv4-intervall",ipv6:"IPv6-intervall",cidrv4:"IPv4-spektrum",cidrv6:"IPv6-spektrum",base64:"base64-kodad sträng",base64url:"base64url-kodad sträng",json_string:"JSON-sträng",e164:"E.164-nummer",jwt:"JWT",template_literal:"mall-literal"};return($)=>{switch($.code){case"invalid_type":return`Ogiltig inmatning: förväntat ${$.expected}, fick ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Ogiltig inmatning: förväntat ${D($.values[0])}`;return`Ogiltigt val: förväntade en av ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`För stor(t): förväntade ${$.origin??"värdet"} att ha ${o}${$.maximum.toString()} ${U.unit??"element"}`;return`För stor(t): förväntat ${$.origin??"värdet"} att ha ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`För lite(t): förväntade ${$.origin??"värdet"} att ha ${o}${$.minimum.toString()} ${U.unit}`;return`För lite(t): förväntade ${$.origin??"värdet"} att ha ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Ogiltig sträng: måste börja med "${o.prefix}"`;if(o.format==="ends_with")return`Ogiltig sträng: måste sluta med "${o.suffix}"`;if(o.format==="includes")return`Ogiltig sträng: måste innehålla "${o.includes}"`;if(o.format==="regex")return`Ogiltig sträng: måste matcha mönstret "${o.pattern}"`;return`Ogiltig(t) ${g[o.format]??$.format}`}case"not_multiple_of":return`Ogiltigt tal: måste vara en multipel av ${$.divisor}`;case"unrecognized_keys":return`${$.keys.length>1?"Okända nycklar":"Okänd nyckel"}: ${i($.keys,", ")}`;case"invalid_key":return`Ogiltig nyckel i ${$.origin??"värdet"}`;case"invalid_union":return"Ogiltig input";case"invalid_element":return`Ogiltigt värde i ${$.origin??"värdet"}`;default:return"Ogiltig input"}}};function Ug(){return{localeError:e_()}}var s_=()=>{let r={string:{unit:"எழுத்துக்கள்",verb:"கொண்டிருக்க வேண்டும்"},file:{unit:"பைட்டுகள்",verb:"கொண்டிருக்க வேண்டும்"},array:{unit:"உறுப்புகள்",verb:"கொண்டிருக்க வேண்டும்"},set:{unit:"உறுப்புகள்",verb:"கொண்டிருக்க வேண்டும்"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"எண் அல்லாதது":"எண்";case"object":{if(Array.isArray($))return"அணி";if($===null)return"வெறுமை";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"உள்ளீடு",email:"மின்னஞ்சல் முகவரி",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO தேதி நேரம்",date:"ISO தேதி",time:"ISO நேரம்",duration:"ISO கால அளவு",ipv4:"IPv4 முகவரி",ipv6:"IPv6 முகவரி",cidrv4:"IPv4 வரம்பு",cidrv6:"IPv6 வரம்பு",base64:"base64-encoded சரம்",base64url:"base64url-encoded சரம்",json_string:"JSON சரம்",e164:"E.164 எண்",jwt:"JWT",template_literal:"input"};return($)=>{switch($.code){case"invalid_type":return`தவறான உள்ளீடு: எதிர்பார்க்கப்பட்டது ${$.expected}, பெறப்பட்டது ${c($.input)}`;case"invalid_value":if($.values.length===1)return`தவறான உள்ளீடு: எதிர்பார்க்கப்பட்டது ${D($.values[0])}`;return`தவறான விருப்பம்: எதிர்பார்க்கப்பட்டது ${i($.values,"|")} இல் ஒன்று`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`மிக பெரியது: எதிர்பார்க்கப்பட்டது ${$.origin??"மதிப்பு"} ${o}${$.maximum.toString()} ${U.unit??"உறுப்புகள்"} ஆக இருக்க வேண்டும்`;return`மிக பெரியது: எதிர்பார்க்கப்பட்டது ${$.origin??"மதிப்பு"} ${o}${$.maximum.toString()} ஆக இருக்க வேண்டும்`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`மிகச் சிறியது: எதிர்பார்க்கப்பட்டது ${$.origin} ${o}${$.minimum.toString()} ${U.unit} ஆக இருக்க வேண்டும்`;return`மிகச் சிறியது: எதிர்பார்க்கப்பட்டது ${$.origin} ${o}${$.minimum.toString()} ஆக இருக்க வேண்டும்`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`தவறான சரம்: "${o.prefix}" இல் தொடங்க வேண்டும்`;if(o.format==="ends_with")return`தவறான சரம்: "${o.suffix}" இல் முடிவடைய வேண்டும்`;if(o.format==="includes")return`தவறான சரம்: "${o.includes}" ஐ உள்ளடக்க வேண்டும்`;if(o.format==="regex")return`தவறான சரம்: ${o.pattern} முறைபாட்டுடன் பொருந்த வேண்டும்`;return`தவறான ${g[o.format]??$.format}`}case"not_multiple_of":return`தவறான எண்: ${$.divisor} இன் பலமாக இருக்க வேண்டும்`;case"unrecognized_keys":return`அடையாளம் தெரியாத விசை${$.keys.length>1?"கள்":""}: ${i($.keys,", ")}`;case"invalid_key":return`${$.origin} இல் தவறான விசை`;case"invalid_union":return"தவறான உள்ளீடு";case"invalid_element":return`${$.origin} இல் தவறான மதிப்பு`;default:return"தவறான உள்ளீடு"}}};function _g(){return{localeError:s_()}}var rw=()=>{let r={string:{unit:"ตัวอักษร",verb:"ควรมี"},file:{unit:"ไบต์",verb:"ควรมี"},array:{unit:"รายการ",verb:"ควรมี"},set:{unit:"รายการ",verb:"ควรมี"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"ไม่ใช่ตัวเลข (NaN)":"ตัวเลข";case"object":{if(Array.isArray($))return"อาร์เรย์ (Array)";if($===null)return"ไม่มีค่า (null)";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"ข้อมูลที่ป้อน",email:"ที่อยู่อีเมล",url:"URL",emoji:"อิโมจิ",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"วันที่เวลาแบบ ISO",date:"วันที่แบบ ISO",time:"เวลาแบบ ISO",duration:"ช่วงเวลาแบบ ISO",ipv4:"ที่อยู่ IPv4",ipv6:"ที่อยู่ IPv6",cidrv4:"ช่วง IP แบบ IPv4",cidrv6:"ช่วง IP แบบ IPv6",base64:"ข้อความแบบ Base64",base64url:"ข้อความแบบ Base64 สำหรับ URL",json_string:"ข้อความแบบ JSON",e164:"เบอร์โทรศัพท์ระหว่างประเทศ (E.164)",jwt:"โทเคน JWT",template_literal:"ข้อมูลที่ป้อน"};return($)=>{switch($.code){case"invalid_type":return`ประเภทข้อมูลไม่ถูกต้อง: ควรเป็น ${$.expected} แต่ได้รับ ${c($.input)}`;case"invalid_value":if($.values.length===1)return`ค่าไม่ถูกต้อง: ควรเป็น ${D($.values[0])}`;return`ตัวเลือกไม่ถูกต้อง: ควรเป็นหนึ่งใน ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"ไม่เกิน":"น้อยกว่า",U=v($.origin);if(U)return`เกินกำหนด: ${$.origin??"ค่า"} ควรมี${o} ${$.maximum.toString()} ${U.unit??"รายการ"}`;return`เกินกำหนด: ${$.origin??"ค่า"} ควรมี${o} ${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?"อย่างน้อย":"มากกว่า",U=v($.origin);if(U)return`น้อยกว่ากำหนด: ${$.origin} ควรมี${o} ${$.minimum.toString()} ${U.unit}`;return`น้อยกว่ากำหนด: ${$.origin} ควรมี${o} ${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`รูปแบบไม่ถูกต้อง: ข้อความต้องขึ้นต้นด้วย "${o.prefix}"`;if(o.format==="ends_with")return`รูปแบบไม่ถูกต้อง: ข้อความต้องลงท้ายด้วย "${o.suffix}"`;if(o.format==="includes")return`รูปแบบไม่ถูกต้อง: ข้อความต้องมี "${o.includes}" อยู่ในข้อความ`;if(o.format==="regex")return`รูปแบบไม่ถูกต้อง: ต้องตรงกับรูปแบบที่กำหนด ${o.pattern}`;return`รูปแบบไม่ถูกต้อง: ${g[o.format]??$.format}`}case"not_multiple_of":return`ตัวเลขไม่ถูกต้อง: ต้องเป็นจำนวนที่หารด้วย ${$.divisor} ได้ลงตัว`;case"unrecognized_keys":return`พบคีย์ที่ไม่รู้จัก: ${i($.keys,", ")}`;case"invalid_key":return`คีย์ไม่ถูกต้องใน ${$.origin}`;case"invalid_union":return"ข้อมูลไม่ถูกต้อง: ไม่ตรงกับรูปแบบยูเนียนที่กำหนดไว้";case"invalid_element":return`ข้อมูลไม่ถูกต้องใน ${$.origin}`;default:return"ข้อมูลไม่ถูกต้อง"}}};function wg(){return{localeError:rw()}}var $w=(r)=>{let v=typeof r;switch(v){case"number":return Number.isNaN(r)?"NaN":"number";case"object":{if(Array.isArray(r))return"array";if(r===null)return"null";if(Object.getPrototypeOf(r)!==Object.prototype&&r.constructor)return r.constructor.name}}return v},vw=()=>{let r={string:{unit:"karakter",verb:"olmalı"},file:{unit:"bayt",verb:"olmalı"},array:{unit:"öğe",verb:"olmalı"},set:{unit:"öğe",verb:"olmalı"}};function v(g){return r[g]??null}let c={regex:"girdi",email:"e-posta adresi",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO tarih ve saat",date:"ISO tarih",time:"ISO saat",duration:"ISO süre",ipv4:"IPv4 adresi",ipv6:"IPv6 adresi",cidrv4:"IPv4 aralığı",cidrv6:"IPv6 aralığı",base64:"base64 ile şifrelenmiş metin",base64url:"base64url ile şifrelenmiş metin",json_string:"JSON dizesi",e164:"E.164 sayısı",jwt:"JWT",template_literal:"Şablon dizesi"};return(g)=>{switch(g.code){case"invalid_type":return`Geçersiz değer: beklenen ${g.expected}, alınan ${$w(g.input)}`;case"invalid_value":if(g.values.length===1)return`Geçersiz değer: beklenen ${D(g.values[0])}`;return`Geçersiz seçenek: aşağıdakilerden biri olmalı: ${i(g.values,"|")}`;case"too_big":{let $=g.inclusive?"<=":"<",o=v(g.origin);if(o)return`Çok büyük: beklenen ${g.origin??"değer"} ${$}${g.maximum.toString()} ${o.unit??"öğe"}`;return`Çok büyük: beklenen ${g.origin??"değer"} ${$}${g.maximum.toString()}`}case"too_small":{let $=g.inclusive?">=":">",o=v(g.origin);if(o)return`Çok küçük: beklenen ${g.origin} ${$}${g.minimum.toString()} ${o.unit}`;return`Çok küçük: beklenen ${g.origin} ${$}${g.minimum.toString()}`}case"invalid_format":{let $=g;if($.format==="starts_with")return`Geçersiz metin: "${$.prefix}" ile başlamalı`;if($.format==="ends_with")return`Geçersiz metin: "${$.suffix}" ile bitmeli`;if($.format==="includes")return`Geçersiz metin: "${$.includes}" içermeli`;if($.format==="regex")return`Geçersiz metin: ${$.pattern} desenine uymalı`;return`Geçersiz ${c[$.format]??g.format}`}case"not_multiple_of":return`Geçersiz sayı: ${g.divisor} ile tam bölünebilmeli`;case"unrecognized_keys":return`Tanınmayan anahtar${g.keys.length>1?"lar":""}: ${i(g.keys,", ")}`;case"invalid_key":return`${g.origin} içinde geçersiz anahtar`;case"invalid_union":return"Geçersiz değer";case"invalid_element":return`${g.origin} içinde geçersiz değer`;default:return"Geçersiz değer"}}};function jg(){return{localeError:vw()}}var cw=()=>{let r={string:{unit:"символів",verb:"матиме"},file:{unit:"байтів",verb:"матиме"},array:{unit:"елементів",verb:"матиме"},set:{unit:"елементів",verb:"матиме"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"число";case"object":{if(Array.isArray($))return"масив";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"вхідні дані",email:"адреса електронної пошти",url:"URL",emoji:"емодзі",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"дата та час ISO",date:"дата ISO",time:"час ISO",duration:"тривалість ISO",ipv4:"адреса IPv4",ipv6:"адреса IPv6",cidrv4:"діапазон IPv4",cidrv6:"діапазон IPv6",base64:"рядок у кодуванні base64",base64url:"рядок у кодуванні base64url",json_string:"рядок JSON",e164:"номер E.164",jwt:"JWT",template_literal:"вхідні дані"};return($)=>{switch($.code){case"invalid_type":return`Неправильні вхідні дані: очікується ${$.expected}, отримано ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Неправильні вхідні дані: очікується ${D($.values[0])}`;return`Неправильна опція: очікується одне з ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Занадто велике: очікується, що ${$.origin??"значення"} ${U.verb} ${o}${$.maximum.toString()} ${U.unit??"елементів"}`;return`Занадто велике: очікується, що ${$.origin??"значення"} буде ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Занадто мале: очікується, що ${$.origin} ${U.verb} ${o}${$.minimum.toString()} ${U.unit}`;return`Занадто мале: очікується, що ${$.origin} буде ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Неправильний рядок: повинен починатися з "${o.prefix}"`;if(o.format==="ends_with")return`Неправильний рядок: повинен закінчуватися на "${o.suffix}"`;if(o.format==="includes")return`Неправильний рядок: повинен містити "${o.includes}"`;if(o.format==="regex")return`Неправильний рядок: повинен відповідати шаблону ${o.pattern}`;return`Неправильний ${g[o.format]??$.format}`}case"not_multiple_of":return`Неправильне число: повинно бути кратним ${$.divisor}`;case"unrecognized_keys":return`Нерозпізнаний ключ${$.keys.length>1?"і":""}: ${i($.keys,", ")}`;case"invalid_key":return`Неправильний ключ у ${$.origin}`;case"invalid_union":return"Неправильні вхідні дані";case"invalid_element":return`Неправильне значення у ${$.origin}`;default:return"Неправильні вхідні дані"}}};function Og(){return{localeError:cw()}}var ow=()=>{let r={string:{unit:"حروف",verb:"ہونا"},file:{unit:"بائٹس",verb:"ہونا"},array:{unit:"آئٹمز",verb:"ہونا"},set:{unit:"آئٹمز",verb:"ہونا"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"نمبر";case"object":{if(Array.isArray($))return"آرے";if($===null)return"نل";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"ان پٹ",email:"ای میل ایڈریس",url:"یو آر ایل",emoji:"ایموجی",uuid:"یو یو آئی ڈی",uuidv4:"یو یو آئی ڈی وی 4",uuidv6:"یو یو آئی ڈی وی 6",nanoid:"نینو آئی ڈی",guid:"جی یو آئی ڈی",cuid:"سی یو آئی ڈی",cuid2:"سی یو آئی ڈی 2",ulid:"یو ایل آئی ڈی",xid:"ایکس آئی ڈی",ksuid:"کے ایس یو آئی ڈی",datetime:"آئی ایس او ڈیٹ ٹائم",date:"آئی ایس او تاریخ",time:"آئی ایس او وقت",duration:"آئی ایس او مدت",ipv4:"آئی پی وی 4 ایڈریس",ipv6:"آئی پی وی 6 ایڈریس",cidrv4:"آئی پی وی 4 رینج",cidrv6:"آئی پی وی 6 رینج",base64:"بیس 64 ان کوڈڈ سٹرنگ",base64url:"بیس 64 یو آر ایل ان کوڈڈ سٹرنگ",json_string:"جے ایس او این سٹرنگ",e164:"ای 164 نمبر",jwt:"جے ڈبلیو ٹی",template_literal:"ان پٹ"};return($)=>{switch($.code){case"invalid_type":return`غلط ان پٹ: ${$.expected} متوقع تھا، ${c($.input)} موصول ہوا`;case"invalid_value":if($.values.length===1)return`غلط ان پٹ: ${D($.values[0])} متوقع تھا`;return`غلط آپشن: ${i($.values,"|")} میں سے ایک متوقع تھا`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`بہت بڑا: ${$.origin??"ویلیو"} کے ${o}${$.maximum.toString()} ${U.unit??"عناصر"} ہونے متوقع تھے`;return`بہت بڑا: ${$.origin??"ویلیو"} کا ${o}${$.maximum.toString()} ہونا متوقع تھا`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`بہت چھوٹا: ${$.origin} کے ${o}${$.minimum.toString()} ${U.unit} ہونے متوقع تھے`;return`بہت چھوٹا: ${$.origin} کا ${o}${$.minimum.toString()} ہونا متوقع تھا`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`غلط سٹرنگ: "${o.prefix}" سے شروع ہونا چاہیے`;if(o.format==="ends_with")return`غلط سٹرنگ: "${o.suffix}" پر ختم ہونا چاہیے`;if(o.format==="includes")return`غلط سٹرنگ: "${o.includes}" شامل ہونا چاہیے`;if(o.format==="regex")return`غلط سٹرنگ: پیٹرن ${o.pattern} سے میچ ہونا چاہیے`;return`غلط ${g[o.format]??$.format}`}case"not_multiple_of":return`غلط نمبر: ${$.divisor} کا مضاعف ہونا چاہیے`;case"unrecognized_keys":return`غیر تسلیم شدہ کی${$.keys.length>1?"ز":""}: ${i($.keys,"، ")}`;case"invalid_key":return`${$.origin} میں غلط کی`;case"invalid_union":return"غلط ان پٹ";case"invalid_element":return`${$.origin} میں غلط ویلیو`;default:return"غلط ان پٹ"}}};function ng(){return{localeError:ow()}}var gw=()=>{let r={string:{unit:"ký tự",verb:"có"},file:{unit:"byte",verb:"có"},array:{unit:"phần tử",verb:"có"},set:{unit:"phần tử",verb:"có"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"số";case"object":{if(Array.isArray($))return"mảng";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"đầu vào",email:"địa chỉ email",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ngày giờ ISO",date:"ngày ISO",time:"giờ ISO",duration:"khoảng thời gian ISO",ipv4:"địa chỉ IPv4",ipv6:"địa chỉ IPv6",cidrv4:"dải IPv4",cidrv6:"dải IPv6",base64:"chuỗi mã hóa base64",base64url:"chuỗi mã hóa base64url",json_string:"chuỗi JSON",e164:"số E.164",jwt:"JWT",template_literal:"đầu vào"};return($)=>{switch($.code){case"invalid_type":return`Đầu vào không hợp lệ: mong đợi ${$.expected}, nhận được ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Đầu vào không hợp lệ: mong đợi ${D($.values[0])}`;return`Tùy chọn không hợp lệ: mong đợi một trong các giá trị ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Quá lớn: mong đợi ${$.origin??"giá trị"} ${U.verb} ${o}${$.maximum.toString()} ${U.unit??"phần tử"}`;return`Quá lớn: mong đợi ${$.origin??"giá trị"} ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Quá nhỏ: mong đợi ${$.origin} ${U.verb} ${o}${$.minimum.toString()} ${U.unit}`;return`Quá nhỏ: mong đợi ${$.origin} ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Chuỗi không hợp lệ: phải bắt đầu bằng "${o.prefix}"`;if(o.format==="ends_with")return`Chuỗi không hợp lệ: phải kết thúc bằng "${o.suffix}"`;if(o.format==="includes")return`Chuỗi không hợp lệ: phải bao gồm "${o.includes}"`;if(o.format==="regex")return`Chuỗi không hợp lệ: phải khớp với mẫu ${o.pattern}`;return`${g[o.format]??$.format} không hợp lệ`}case"not_multiple_of":return`Số không hợp lệ: phải là bội số của ${$.divisor}`;case"unrecognized_keys":return`Khóa không được nhận dạng: ${i($.keys,", ")}`;case"invalid_key":return`Khóa không hợp lệ trong ${$.origin}`;case"invalid_union":return"Đầu vào không hợp lệ";case"invalid_element":return`Giá trị không hợp lệ trong ${$.origin}`;default:return"Đầu vào không hợp lệ"}}};function kg(){return{localeError:gw()}}var Uw=()=>{let r={string:{unit:"字符",verb:"包含"},file:{unit:"字节",verb:"包含"},array:{unit:"项",verb:"包含"},set:{unit:"项",verb:"包含"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"非数字(NaN)":"数字";case"object":{if(Array.isArray($))return"数组";if($===null)return"空值(null)";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"输入",email:"电子邮件",url:"URL",emoji:"表情符号",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO日期时间",date:"ISO日期",time:"ISO时间",duration:"ISO时长",ipv4:"IPv4地址",ipv6:"IPv6地址",cidrv4:"IPv4网段",cidrv6:"IPv6网段",base64:"base64编码字符串",base64url:"base64url编码字符串",json_string:"JSON字符串",e164:"E.164号码",jwt:"JWT",template_literal:"输入"};return($)=>{switch($.code){case"invalid_type":return`无效输入:期望 ${$.expected},实际接收 ${c($.input)}`;case"invalid_value":if($.values.length===1)return`无效输入:期望 ${D($.values[0])}`;return`无效选项:期望以下之一 ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`数值过大:期望 ${$.origin??"值"} ${o}${$.maximum.toString()} ${U.unit??"个元素"}`;return`数值过大:期望 ${$.origin??"值"} ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`数值过小:期望 ${$.origin} ${o}${$.minimum.toString()} ${U.unit}`;return`数值过小:期望 ${$.origin} ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`无效字符串:必须以 "${o.prefix}" 开头`;if(o.format==="ends_with")return`无效字符串:必须以 "${o.suffix}" 结尾`;if(o.format==="includes")return`无效字符串:必须包含 "${o.includes}"`;if(o.format==="regex")return`无效字符串:必须满足正则表达式 ${o.pattern}`;return`无效${g[o.format]??$.format}`}case"not_multiple_of":return`无效数字:必须是 ${$.divisor} 的倍数`;case"unrecognized_keys":return`出现未知的键(key): ${i($.keys,", ")}`;case"invalid_key":return`${$.origin} 中的键(key)无效`;case"invalid_union":return"无效输入";case"invalid_element":return`${$.origin} 中包含无效值(value)`;default:return"无效输入"}}};function ig(){return{localeError:Uw()}}var _w=()=>{let r={string:{unit:"字元",verb:"擁有"},file:{unit:"位元組",verb:"擁有"},array:{unit:"項目",verb:"擁有"},set:{unit:"項目",verb:"擁有"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"number";case"object":{if(Array.isArray($))return"array";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"輸入",email:"郵件地址",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"ISO 日期時間",date:"ISO 日期",time:"ISO 時間",duration:"ISO 期間",ipv4:"IPv4 位址",ipv6:"IPv6 位址",cidrv4:"IPv4 範圍",cidrv6:"IPv6 範圍",base64:"base64 編碼字串",base64url:"base64url 編碼字串",json_string:"JSON 字串",e164:"E.164 數值",jwt:"JWT",template_literal:"輸入"};return($)=>{switch($.code){case"invalid_type":return`無效的輸入值:預期為 ${$.expected},但收到 ${c($.input)}`;case"invalid_value":if($.values.length===1)return`無效的輸入值:預期為 ${D($.values[0])}`;return`無效的選項:預期為以下其中之一 ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`數值過大:預期 ${$.origin??"值"} 應為 ${o}${$.maximum.toString()} ${U.unit??"個元素"}`;return`數值過大:預期 ${$.origin??"值"} 應為 ${o}${$.maximum.toString()}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`數值過小:預期 ${$.origin} 應為 ${o}${$.minimum.toString()} ${U.unit}`;return`數值過小:預期 ${$.origin} 應為 ${o}${$.minimum.toString()}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`無效的字串:必須以 "${o.prefix}" 開頭`;if(o.format==="ends_with")return`無效的字串:必須以 "${o.suffix}" 結尾`;if(o.format==="includes")return`無效的字串:必須包含 "${o.includes}"`;if(o.format==="regex")return`無效的字串:必須符合格式 ${o.pattern}`;return`無效的 ${g[o.format]??$.format}`}case"not_multiple_of":return`無效的數字:必須為 ${$.divisor} 的倍數`;case"unrecognized_keys":return`無法識別的鍵值${$.keys.length>1?"們":""}:${i($.keys,"、")}`;case"invalid_key":return`${$.origin} 中有無效的鍵值`;case"invalid_union":return"無效的輸入值";case"invalid_element":return`${$.origin} 中有無效的值`;default:return"無效的輸入值"}}};function zg(){return{localeError:_w()}}var ww=()=>{let r={string:{unit:"àmi",verb:"ní"},file:{unit:"bytes",verb:"ní"},array:{unit:"nkan",verb:"ní"},set:{unit:"nkan",verb:"ní"}};function v($){return r[$]??null}let c=($)=>{let o=typeof $;switch(o){case"number":return Number.isNaN($)?"NaN":"nọ́mbà";case"object":{if(Array.isArray($))return"akopọ";if($===null)return"null";if(Object.getPrototypeOf($)!==Object.prototype&&$.constructor)return $.constructor.name}}return o},g={regex:"ẹ̀rọ ìbáwọlé",email:"àdírẹ́sì ìmẹ́lì",url:"URL",emoji:"emoji",uuid:"UUID",uuidv4:"UUIDv4",uuidv6:"UUIDv6",nanoid:"nanoid",guid:"GUID",cuid:"cuid",cuid2:"cuid2",ulid:"ULID",xid:"XID",ksuid:"KSUID",datetime:"àkókò ISO",date:"ọjọ́ ISO",time:"àkókò ISO",duration:"àkókò tó pé ISO",ipv4:"àdírẹ́sì IPv4",ipv6:"àdírẹ́sì IPv6",cidrv4:"àgbègbè IPv4",cidrv6:"àgbègbè IPv6",base64:"ọ̀rọ̀ tí a kọ́ ní base64",base64url:"ọ̀rọ̀ base64url",json_string:"ọ̀rọ̀ JSON",e164:"nọ́mbà E.164",jwt:"JWT",template_literal:"ẹ̀rọ ìbáwọlé"};return($)=>{switch($.code){case"invalid_type":return`Ìbáwọlé aṣìṣe: a ní láti fi ${$.expected}, àmọ̀ a rí ${c($.input)}`;case"invalid_value":if($.values.length===1)return`Ìbáwọlé aṣìṣe: a ní láti fi ${D($.values[0])}`;return`Àṣàyàn aṣìṣe: yan ọ̀kan lára ${i($.values,"|")}`;case"too_big":{let o=$.inclusive?"<=":"<",U=v($.origin);if(U)return`Tó pọ̀ jù: a ní láti jẹ́ pé ${$.origin??"iye"} ${U.verb} ${o}${$.maximum} ${U.unit}`;return`Tó pọ̀ jù: a ní láti jẹ́ ${o}${$.maximum}`}case"too_small":{let o=$.inclusive?">=":">",U=v($.origin);if(U)return`Kéré ju: a ní láti jẹ́ pé ${$.origin} ${U.verb} ${o}${$.minimum} ${U.unit}`;return`Kéré ju: a ní láti jẹ́ ${o}${$.minimum}`}case"invalid_format":{let o=$;if(o.format==="starts_with")return`Ọ̀rọ̀ aṣìṣe: gbọ́dọ̀ bẹ̀rẹ̀ pẹ̀lú "${o.prefix}"`;if(o.format==="ends_with")return`Ọ̀rọ̀ aṣìṣe: gbọ́dọ̀ parí pẹ̀lú "${o.suffix}"`;if(o.format==="includes")return`Ọ̀rọ̀ aṣìṣe: gbọ́dọ̀ ní "${o.includes}"`;if(o.format==="regex")return`Ọ̀rọ̀ aṣìṣe: gbọ́dọ̀ bá àpẹẹrẹ mu ${o.pattern}`;return`Aṣìṣe: ${g[o.format]??$.format}`}case"not_multiple_of":return`Nọ́mbà aṣìṣe: gbọ́dọ̀ jẹ́ èyà pípín ti ${$.divisor}`;case"unrecognized_keys":return`Bọtìnì àìmọ̀: ${i($.keys,", ")}`;case"invalid_key":return`Bọtìnì aṣìṣe nínú ${$.origin}`;case"invalid_union":return"Ìbáwọlé aṣìṣe";case"invalid_element":return`Iye aṣìṣe nínú ${$.origin}`;default:return"Ìbáwọlé aṣìṣe"}}};function bg(){return{localeError:ww()}}var Dg=Symbol("ZodOutput"),Sg=Symbol("ZodInput");class Zr{constructor(){this._map=new Map,this._idmap=new Map}add(r,...v){let c=v[0];if(this._map.set(r,c),c&&typeof c==="object"&&"id"in c){if(this._idmap.has(c.id))throw Error(`ID ${c.id} already exists in the registry`);this._idmap.set(c.id,r)}return this}clear(){return this._map=new Map,this._idmap=new Map,this}remove(r){let v=this._map.get(r);if(v&&typeof v==="object"&&"id"in v)this._idmap.delete(v.id);return this._map.delete(r),this}get(r){let v=r._zod.parent;if(v){let c={...this.get(v)??{}};delete c.id;let g={...c,...this._map.get(r)};return Object.keys(g).length?g:void 0}return this._map.get(r)}has(r){return this._map.has(r)}}function Y$(){return new Zr}var Z=Y$();function Pg(r,v){return new r({type:"string",...z(v)})}function Ig(r,v){return new r({type:"string",coerce:!0,...z(v)})}function u$(r,v){return new r({type:"string",format:"email",check:"string_format",abort:!1,...z(v)})}function qr(r,v){return new r({type:"string",format:"guid",check:"string_format",abort:!1,...z(v)})}function H$(r,v){return new r({type:"string",format:"uuid",check:"string_format",abort:!1,...z(v)})}function N$(r,v){return new r({type:"string",format:"uuid",check:"string_format",abort:!1,version:"v4",...z(v)})}function B$(r,v){return new r({type:"string",format:"uuid",check:"string_format",abort:!1,version:"v6",...z(v)})}function M$(r,v){return new r({type:"string",format:"uuid",check:"string_format",abort:!1,version:"v7",...z(v)})}function t$(r,v){return new r({type:"string",format:"url",check:"string_format",abort:!1,...z(v)})}function E$(r,v){return new r({type:"string",format:"emoji",check:"string_format",abort:!1,...z(v)})}function F$(r,v){return new r({type:"string",format:"nanoid",check:"string_format",abort:!1,...z(v)})}function V$(r,v){return new r({type:"string",format:"cuid",check:"string_format",abort:!1,...z(v)})}function m$(r,v){return new r({type:"string",format:"cuid2",check:"string_format",abort:!1,...z(v)})}function R$(r,v){return new r({type:"string",format:"ulid",check:"string_format",abort:!1,...z(v)})}function T$(r,v){return new r({type:"string",format:"xid",check:"string_format",abort:!1,...z(v)})}function l$(r,v){return new r({type:"string",format:"ksuid",check:"string_format",abort:!1,...z(v)})}function Z$(r,v){return new r({type:"string",format:"ipv4",check:"string_format",abort:!1,...z(v)})}function q$(r,v){return new r({type:"string",format:"ipv6",check:"string_format",abort:!1,...z(v)})}function C$(r,v){return new r({type:"string",format:"cidrv4",check:"string_format",abort:!1,...z(v)})}function h$(r,v){return new r({type:"string",format:"cidrv6",check:"string_format",abort:!1,...z(v)})}function f$(r,v){return new r({type:"string",format:"base64",check:"string_format",abort:!1,...z(v)})}function y$(r,v){return new r({type:"string",format:"base64url",check:"string_format",abort:!1,...z(v)})}function p$(r,v){return new r({type:"string",format:"e164",check:"string_format",abort:!1,...z(v)})}function d$(r,v){return new r({type:"string",format:"jwt",check:"string_format",abort:!1,...z(v)})}var xg={Any:null,Minute:-1,Second:0,Millisecond:3,Microsecond:6};function Jg(r,v){return new r({type:"string",format:"datetime",check:"string_format",offset:!1,local:!1,precision:null,...z(v)})}function Xg(r,v){return new r({type:"string",format:"date",check:"string_format",...z(v)})}function Wg(r,v){return new r({type:"string",format:"time",check:"string_format",precision:null,...z(v)})}function Kg(r,v){return new r({type:"string",format:"duration",check:"string_format",...z(v)})}function Gg(r,v){return new r({type:"number",checks:[],...z(v)})}function Ag(r,v){return new r({type:"number",coerce:!0,checks:[],...z(v)})}function Lg(r,v){return new r({type:"number",check:"number_format",abort:!1,format:"safeint",...z(v)})}function Qg(r,v){return new r({type:"number",check:"number_format",abort:!1,format:"float32",...z(v)})}function Yg(r,v){return new r({type:"number",check:"number_format",abort:!1,format:"float64",...z(v)})}function ug(r,v){return new r({type:"number",check:"number_format",abort:!1,format:"int32",...z(v)})}function Hg(r,v){return new r({type:"number",check:"number_format",abort:!1,format:"uint32",...z(v)})}function Ng(r,v){return new r({type:"boolean",...z(v)})}function Bg(r,v){return new r({type:"boolean",coerce:!0,...z(v)})}function Mg(r,v){return new r({type:"bigint",...z(v)})}function tg(r,v){return new r({type:"bigint",coerce:!0,...z(v)})}function Eg(r,v){return new r({type:"bigint",check:"bigint_format",abort:!1,format:"int64",...z(v)})}function Fg(r,v){return new r({type:"bigint",check:"bigint_format",abort:!1,format:"uint64",...z(v)})}function Vg(r,v){return new r({type:"symbol",...z(v)})}function mg(r,v){return new r({type:"undefined",...z(v)})}function Rg(r,v){return new r({type:"null",...z(v)})}function Tg(r){return new r({type:"any"})}function Sr(r){return new r({type:"unknown"})}function lg(r,v){return new r({type:"never",...z(v)})}function Zg(r,v){return new r({type:"void",...z(v)})}function qg(r,v){return new r({type:"date",...z(v)})}function Cg(r,v){return new r({type:"date",coerce:!0,...z(v)})}function hg(r,v){return new r({type:"nan",...z(v)})}function h(r,v){return new J$({check:"less_than",...z(v),value:r,inclusive:!1})}function T(r,v){return new J$({check:"less_than",...z(v),value:r,inclusive:!0})}function f(r,v){return new X$({check:"greater_than",...z(v),value:r,inclusive:!1})}function F(r,v){return new X$({check:"greater_than",...z(v),value:r,inclusive:!0})}function fg(r){return f(0,r)}function yg(r){return h(0,r)}function pg(r){return T(0,r)}function dg(r){return F(0,r)}function Ur(r,v){return new Uc({check:"multiple_of",...z(v),value:r})}function Pr(r,v){return new jc({check:"max_size",...z(v),maximum:r})}function _r(r,v){return new Oc({check:"min_size",...z(v),minimum:r})}function Cr(r,v){return new nc({check:"size_equals",...z(v),size:r})}function Ir(r,v){return new kc({check:"max_length",...z(v),maximum:r})}function rr(r,v){return new ic({check:"min_length",...z(v),minimum:r})}function xr(r,v){return new zc({check:"length_equals",...z(v),length:r})}function hr(r,v){return new bc({check:"string_format",format:"regex",...z(v),pattern:r})}function fr(r){return new Dc({check:"string_format",format:"lowercase",...z(r)})}function yr(r){return new Sc({check:"string_format",format:"uppercase",...z(r)})}function pr(r,v){return new Pc({check:"string_format",format:"includes",...z(v),includes:r})}function dr(r,v){return new Ic({check:"string_format",format:"starts_with",...z(v),prefix:r})}function ar(r,v){return new xc({check:"string_format",format:"ends_with",...z(v),suffix:r})}function ag(r,v,c){return new Jc({check:"property",property:r,schema:v,...z(c)})}function er(r,v){return new Xc({check:"mime_type",mime:r,...z(v)})}function y(r){return new Wc({check:"overwrite",tx:r})}function sr(r){return y((v)=>v.normalize(r))}function r$(){return y((r)=>r.trim())}function $$(){return y((r)=>r.toLowerCase())}function v$(){return y((r)=>r.toUpperCase())}function c$(r,v,c){return new r({type:"array",element:v,...z(c)})}function jw(r,v,c){return new r({type:"union",options:v,...z(c)})}function Ow(r,v,c,g){return new r({type:"union",options:c,discriminator:v,...z(g)})}function nw(r,v,c){return new r({type:"intersection",left:v,right:c})}function eg(r,v,c,g){let $=c instanceof J;return new r({type:"tuple",items:v,rest:$?c:null,...z($?g:c)})}function kw(r,v,c,g){return new r({type:"record",keyType:v,valueType:c,...z(g)})}function iw(r,v,c,g){return new r({type:"map",keyType:v,valueType:c,...z(g)})}function zw(r,v,c){return new r({type:"set",valueType:v,...z(c)})}function bw(r,v,c){let g=Array.isArray(v)?Object.fromEntries(v.map(($)=>[$,$])):v;return new r({type:"enum",entries:g,...z(c)})}function Dw(r,v,c){return new r({type:"enum",entries:v,...z(c)})}function Sw(r,v,c){return new r({type:"literal",values:Array.isArray(v)?v:[v],...z(c)})}function sg(r,v){return new r({type:"file",...z(v)})}function Pw(r,v){return new r({type:"transform",transform:v})}function Iw(r,v){return new r({type:"optional",innerType:v})}function xw(r,v){return new r({type:"nullable",innerType:v})}function Jw(r,v,c){return new r({type:"default",innerType:v,get defaultValue(){return typeof c==="function"?c():c}})}function Xw(r,v,c){return new r({type:"nonoptional",innerType:v,...z(c)})}function Ww(r,v){return new r({type:"success",innerType:v})}function Kw(r,v,c){return new r({type:"catch",innerType:v,catchValue:typeof c==="function"?c:()=>c})}function Gw(r,v,c){return new r({type:"pipe",in:v,out:c})}function Aw(r,v){return new r({type:"readonly",innerType:v})}function Lw(r,v,c){return new r({type:"template_literal",parts:v,...z(c)})}function Qw(r,v){return new r({type:"lazy",getter:v})}function Yw(r,v){return new r({type:"promise",innerType:v})}function r4(r,v,c){let g=z(c);return g.abort??(g.abort=!0),new r({type:"custom",check:"custom",fn:v,...g})}function $4(r,v,c){return new r({type:"custom",check:"custom",fn:v,...z(c)})}function v4(r){let v=F6((c)=>{return c.addIssue=(g)=>{if(typeof g==="string")c.issues.push(ir(g,c.value,v._zod.def));else{let $=g;if($.fatal)$.continue=!1;$.code??($.code="custom"),$.input??($.input=c.value),$.inst??($.inst=v),$.continue??($.continue=!v._zod.def.abort),c.issues.push(ir($))}},r(c.value,c)});return v}function F6(r,v){let c=new H({check:"custom",...z(v)});return c._zod.check=r,c}function c4(r,v){let c=z(v),g=c.truthy??["true","1","yes","on","y","enabled"],$=c.falsy??["false","0","no","off","n","disabled"];if(c.case!=="sensitive")g=g.map((I)=>typeof I==="string"?I.toLowerCase():I),$=$.map((I)=>typeof I==="string"?I.toLowerCase():I);let o=new Set(g),U=new Set($),_=r.Pipe??Rr,j=r.Boolean??Fr,n=r.String??or,P=new(r.Transform??mr)({type:"transform",transform:(I,x)=>{let G=I;if(c.case!=="sensitive")G=G.toLowerCase();if(o.has(G))return!0;else if(U.has(G))return!1;else return x.issues.push({code:"invalid_value",expected:"stringbool",values:[...o,...U],input:x.value,inst:P,continue:!1}),{}},error:c.error}),b=new _({type:"pipe",in:new n({type:"string",error:c.error}),out:P,error:c.error});return new _({type:"pipe",in:b,out:new j({type:"boolean",error:c.error}),error:c.error})}function a$(r,v,c,g={}){let $=z(g),o={...z(g),check:"string_format",type:"string",format:v,fn:typeof c==="function"?c:(_)=>c.test(_),...$};if(c instanceof RegExp)o.pattern=c;return new r(o)}class o4{constructor(r){this._def=r,this.def=r}implement(r){if(typeof r!=="function")throw Error("implement() must be called with a function");let v=(...c)=>{let g=this._def.input?b$(this._def.input,c,void 0,{callee:v}):c;if(!Array.isArray(g))throw Error("Invalid arguments schema: not an array or tuple schema.");let $=r(...g);return this._def.output?b$(this._def.output,$,void 0,{callee:v}):$};return v}implementAsync(r){if(typeof r!=="function")throw Error("implement() must be called with a function");let v=async(...c)=>{let g=this._def.input?await S$(this._def.input,c,void 0,{callee:v}):c;if(!Array.isArray(g))throw Error("Invalid arguments schema: not an array or tuple schema.");let $=await r(...g);return this._def.output?S$(this._def.output,$,void 0,{callee:v}):$};return v}input(...r){let v=this.constructor;if(Array.isArray(r[0]))return new v({type:"function",input:new gr({type:"tuple",items:r[0],rest:r[1]}),output:this._def.output});return new v({type:"function",input:r[0],output:this._def.output})}output(r){return new this.constructor({type:"function",input:this._def.input,output:r})}}function g4(r){return new o4({type:"function",input:Array.isArray(r?.input)?eg(gr,r?.input):r?.input??c$(Vr,Sr(Dr)),output:r?.output??Sr(Dr)})}class e${constructor(r){this.counter=0,this.metadataRegistry=r?.metadata??Z,this.target=r?.target??"draft-2020-12",this.unrepresentable=r?.unrepresentable??"throw",this.override=r?.override??(()=>{}),this.io=r?.io??"output",this.seen=new Map}process(r,v={path:[],schemaPath:[]}){var c;let g=r._zod.def,$={guid:"uuid",url:"uri",datetime:"date-time",json_string:"json-string",regex:""},o=this.seen.get(r);if(o){if(o.count++,v.schemaPath.includes(r))o.cycle=v.path;return o.schema}let U={schema:{},count:1,cycle:void 0,path:v.path};this.seen.set(r,U);let _=r._zod.toJSONSchema?.();if(_)U.schema=_;else{let k={...v,schemaPath:[...v.schemaPath,r],path:v.path},P=r._zod.parent;if(P)U.ref=P,this.process(P,k),this.seen.get(P).isParent=!0;else{let b=U.schema;switch(g.type){case"string":{let O=b;O.type="string";let{minimum:I,maximum:x,format:G,patterns:A,contentEncoding:L}=r._zod.bag;if(typeof I==="number")O.minLength=I;if(typeof x==="number")O.maxLength=x;if(G){if(O.format=$[G]??G,O.format==="")delete O.format}if(L)O.contentEncoding=L;if(A&&A.size>0){let Q=[...A];if(Q.length===1)O.pattern=Q[0].source;else if(Q.length>1)U.schema.allOf=[...Q.map((t)=>({...this.target==="draft-7"||this.target==="draft-4"?{type:"string"}:{},pattern:t.source}))]}break}case"number":{let O=b,{minimum:I,maximum:x,format:G,multipleOf:A,exclusiveMaximum:L,exclusiveMinimum:Q}=r._zod.bag;if(typeof G==="string"&&G.includes("int"))O.type="integer";else O.type="number";if(typeof Q==="number")if(this.target==="draft-4")O.minimum=Q,O.exclusiveMinimum=!0;else O.exclusiveMinimum=Q;if(typeof I==="number"){if(O.minimum=I,typeof Q==="number"&&this.target!=="draft-4")if(Q>=I)delete O.minimum;else delete O.exclusiveMinimum}if(typeof L==="number")if(this.target==="draft-4")O.maximum=L,O.exclusiveMaximum=!0;else O.exclusiveMaximum=L;if(typeof x==="number"){if(O.maximum=x,typeof L==="number"&&this.target!=="draft-4")if(L<=x)delete O.maximum;else delete O.exclusiveMaximum}if(typeof A==="number")O.multipleOf=A;break}case"boolean":{let O=b;O.type="boolean";break}case"bigint":{if(this.unrepresentable==="throw")throw Error("BigInt cannot be represented in JSON Schema");break}case"symbol":{if(this.unrepresentable==="throw")throw Error("Symbols cannot be represented in JSON Schema");break}case"null":{b.type="null";break}case"any":break;case"unknown":break;case"undefined":{if(this.unrepresentable==="throw")throw Error("Undefined cannot be represented in JSON Schema");break}case"void":{if(this.unrepresentable==="throw")throw Error("Void cannot be represented in JSON Schema");break}case"never":{b.not={};break}case"date":{if(this.unrepresentable==="throw")throw Error("Date cannot be represented in JSON Schema");break}case"array":{let O=b,{minimum:I,maximum:x}=r._zod.bag;if(typeof I==="number")O.minItems=I;if(typeof x==="number")O.maxItems=x;O.type="array",O.items=this.process(g.element,{...k,path:[...k.path,"items"]});break}case"object":{let O=b;O.type="object",O.properties={};let I=g.shape;for(let A in I)O.properties[A]=this.process(I[A],{...k,path:[...k.path,"properties",A]});let x=new Set(Object.keys(I)),G=new Set([...x].filter((A)=>{let L=g.shape[A]._zod;if(this.io==="input")return L.optin===void 0;else return L.optout===void 0}));if(G.size>0)O.required=Array.from(G);if(g.catchall?._zod.def.type==="never")O.additionalProperties=!1;else if(!g.catchall){if(this.io==="output")O.additionalProperties=!1}else if(g.catchall)O.additionalProperties=this.process(g.catchall,{...k,path:[...k.path,"additionalProperties"]});break}case"union":{let O=b;O.anyOf=g.options.map((I,x)=>this.process(I,{...k,path:[...k.path,"anyOf",x]}));break}case"intersection":{let O=b,I=this.process(g.left,{...k,path:[...k.path,"allOf",0]}),x=this.process(g.right,{...k,path:[...k.path,"allOf",1]}),G=(L)=>("allOf"in L)&&Object.keys(L).length===1,A=[...G(I)?I.allOf:[I],...G(x)?x.allOf:[x]];O.allOf=A;break}case"tuple":{let O=b;O.type="array";let I=g.items.map((A,L)=>this.process(A,{...k,path:[...k.path,"prefixItems",L]}));if(this.target==="draft-2020-12")O.prefixItems=I;else O.items=I;if(g.rest){let A=this.process(g.rest,{...k,path:[...k.path,"items"]});if(this.target==="draft-2020-12")O.items=A;else O.additionalItems=A}if(g.rest)O.items=this.process(g.rest,{...k,path:[...k.path,"items"]});let{minimum:x,maximum:G}=r._zod.bag;if(typeof x==="number")O.minItems=x;if(typeof G==="number")O.maxItems=G;break}case"record":{let O=b;if(O.type="object",this.target!=="draft-4")O.propertyNames=this.process(g.keyType,{...k,path:[...k.path,"propertyNames"]});O.additionalProperties=this.process(g.valueType,{...k,path:[...k.path,"additionalProperties"]});break}case"map":{if(this.unrepresentable==="throw")throw Error("Map cannot be represented in JSON Schema");break}case"set":{if(this.unrepresentable==="throw")throw Error("Set cannot be represented in JSON Schema");break}case"enum":{let O=b,I=Qr(g.entries);if(I.every((x)=>typeof x==="number"))O.type="number";if(I.every((x)=>typeof x==="string"))O.type="string";O.enum=I;break}case"literal":{let O=b,I=[];for(let x of g.values)if(x===void 0){if(this.unrepresentable==="throw")throw Error("Literal `undefined` cannot be represented in JSON Schema")}else if(typeof x==="bigint")if(this.unrepresentable==="throw")throw Error("BigInt literals cannot be represented in JSON Schema");else I.push(Number(x));else I.push(x);if(I.length===0);else if(I.length===1){let x=I[0];if(O.type=x===null?"null":typeof x,this.target==="draft-4")O.enum=[x];else O.const=x}else{if(I.every((x)=>typeof x==="number"))O.type="number";if(I.every((x)=>typeof x==="string"))O.type="string";if(I.every((x)=>typeof x==="boolean"))O.type="string";if(I.every((x)=>x===null))O.type="null";O.enum=I}break}case"file":{let O=b,I={type:"string",format:"binary",contentEncoding:"binary"},{minimum:x,maximum:G,mime:A}=r._zod.bag;if(x!==void 0)I.minLength=x;if(G!==void 0)I.maxLength=G;if(A)if(A.length===1)I.contentMediaType=A[0],Object.assign(O,I);else O.anyOf=A.map((L)=>{return{...I,contentMediaType:L}});else Object.assign(O,I);break}case"transform":{if(this.unrepresentable==="throw")throw Error("Transforms cannot be represented in JSON Schema");break}case"nullable":{let O=this.process(g.innerType,k);b.anyOf=[O,{type:"null"}];break}case"nonoptional":{this.process(g.innerType,k),U.ref=g.innerType;break}case"success":{let O=b;O.type="boolean";break}case"default":{this.process(g.innerType,k),U.ref=g.innerType,b.default=JSON.parse(JSON.stringify(g.defaultValue));break}case"prefault":{if(this.process(g.innerType,k),U.ref=g.innerType,this.io==="input")b._prefault=JSON.parse(JSON.stringify(g.defaultValue));break}case"catch":{this.process(g.innerType,k),U.ref=g.innerType;let O;try{O=g.catchValue(void 0)}catch{throw Error("Dynamic catch values are not supported in JSON Schema")}b.default=O;break}case"nan":{if(this.unrepresentable==="throw")throw Error("NaN cannot be represented in JSON Schema");break}case"template_literal":{let O=b,I=r._zod.pattern;if(!I)throw Error("Pattern not found in template literal");O.type="string",O.pattern=I.source;break}case"pipe":{let O=this.io==="input"?g.in._zod.def.type==="transform"?g.out:g.in:g.out;this.process(O,k),U.ref=O;break}case"readonly":{this.process(g.innerType,k),U.ref=g.innerType,b.readOnly=!0;break}case"promise":{this.process(g.innerType,k),U.ref=g.innerType;break}case"optional":{this.process(g.innerType,k),U.ref=g.innerType;break}case"lazy":{let O=r._zod.innerType;this.process(O,k),U.ref=O;break}case"custom":{if(this.unrepresentable==="throw")throw Error("Custom types cannot be represented in JSON Schema");break}default:}}}let j=this.metadataRegistry.get(r);if(j)Object.assign(U.schema,j);if(this.io==="input"&&M(r))delete U.schema.examples,delete U.schema.default;if(this.io==="input"&&U.schema._prefault)(c=U.schema).default??(c.default=U.schema._prefault);return delete U.schema._prefault,this.seen.get(r).schema}emit(r,v){let c={cycles:v?.cycles??"ref",reused:v?.reused??"inline",external:v?.external??void 0},g=this.seen.get(r);if(!g)throw Error("Unprocessed schema. This is a bug in Zod.");let $=(n)=>{let k=this.target==="draft-2020-12"?"$defs":"definitions";if(c.external){let I=c.external.registry.get(n[0])?.id,x=c.external.uri??((A)=>A);if(I)return{ref:x(I)};let G=n[1].defId??n[1].schema.id??`schema${this.counter++}`;return n[1].defId=G,{defId:G,ref:`${x("__shared")}#/${k}/${G}`}}if(n[1]===g)return{ref:"#"};let b=`${"#"}/${k}/`,O=n[1].schema.id??`__schema${this.counter++}`;return{defId:O,ref:b+O}},o=(n)=>{if(n[1].schema.$ref)return;let k=n[1],{ref:P,defId:b}=$(n);if(k.def={...k.schema},b)k.defId=b;let O=k.schema;for(let I in O)delete O[I];O.$ref=P};if(c.cycles==="throw")for(let n of this.seen.entries()){let k=n[1];if(k.cycle)throw Error(`Cycle detected: #/${k.cycle?.join("/")}/<root>
|
|
1822
20
|
|
|
1823
|
-
// src/verification/number.verify.ts
|
|
1824
|
-
import { EventEmitter as EventEmitter4 } from "events";
|
|
1825
|
-
var VerificationType = /* @__PURE__ */ ((VerificationType2) => {
|
|
1826
|
-
VerificationType2["SMS"] = "sms";
|
|
1827
|
-
VerificationType2["VOICE_CALL"] = "voice_call";
|
|
1828
|
-
VerificationType2["HYBRID"] = "hybrid";
|
|
1829
|
-
return VerificationType2;
|
|
1830
|
-
})(VerificationType || {});
|
|
1831
|
-
var VerificationMethod = /* @__PURE__ */ ((VerificationMethod2) => {
|
|
1832
|
-
VerificationMethod2["SMS"] = "sms";
|
|
1833
|
-
VerificationMethod2["VOICE_CALL"] = "voice_call";
|
|
1834
|
-
VerificationMethod2["MISSED_CALL"] = "missed_call";
|
|
1835
|
-
return VerificationMethod2;
|
|
1836
|
-
})(VerificationMethod || {});
|
|
1837
|
-
var NumberVerifier = class extends EventEmitter4 {
|
|
1838
|
-
constructor(options = {}) {
|
|
1839
|
-
super();
|
|
1840
|
-
this.options = options;
|
|
1841
|
-
this.verificationRequests = /* @__PURE__ */ new Map();
|
|
1842
|
-
this.phoneNumberCache = /* @__PURE__ */ new Map();
|
|
1843
|
-
this.rateLimitTracker = /* @__PURE__ */ new Map();
|
|
1844
|
-
this.dailyAttemptTracker = /* @__PURE__ */ new Map();
|
|
1845
|
-
this.blockedNumbers = /* @__PURE__ */ new Set();
|
|
1846
|
-
this.defaultOptions = {
|
|
1847
|
-
codeLength: 6,
|
|
1848
|
-
codeExpiryMinutes: 5,
|
|
1849
|
-
maxAttempts: 3,
|
|
1850
|
-
maxDailyAttempts: 10,
|
|
1851
|
-
smsTemplate: "\uC778\uC99D\uBC88\uD638: {code}. {expiry}\uBD84 \uB0B4\uC5D0 \uC785\uB825\uD574\uC8FC\uC138\uC694.",
|
|
1852
|
-
voiceTemplate: "\uC778\uC99D\uBC88\uD638\uB294 {code}\uC785\uB2C8\uB2E4. \uB2E4\uC2DC \uD55C \uBC88, {code}\uC785\uB2C8\uB2E4.",
|
|
1853
|
-
rateLimitMinutes: 1,
|
|
1854
|
-
enableVoiceFallback: true,
|
|
1855
|
-
enableMissedCallVerification: false,
|
|
1856
|
-
blockedNumbers: [],
|
|
1857
|
-
allowedCountries: ["KR"]
|
|
1858
|
-
};
|
|
1859
|
-
this.options = { ...this.defaultOptions, ...options };
|
|
1860
|
-
this.options.blockedNumbers?.forEach((number) => {
|
|
1861
|
-
this.blockedNumbers.add(number);
|
|
1862
|
-
});
|
|
1863
|
-
}
|
|
1864
|
-
/**
|
|
1865
|
-
* Start phone number verification process
|
|
1866
|
-
*/
|
|
1867
|
-
async startVerification(senderNumberId, phoneNumber, verificationType = "sms" /* SMS */, metadata = {}) {
|
|
1868
|
-
const phoneInfo = await this.getPhoneNumberInfo(phoneNumber);
|
|
1869
|
-
if (!phoneInfo.isValid) {
|
|
1870
|
-
throw new Error("Invalid phone number format");
|
|
1871
|
-
}
|
|
1872
|
-
if (this.isNumberBlocked(phoneNumber)) {
|
|
1873
|
-
throw new Error("Phone number is blocked");
|
|
1874
|
-
}
|
|
1875
|
-
if (this.isRateLimited(phoneNumber)) {
|
|
1876
|
-
throw new Error("Rate limit exceeded. Please try again later.");
|
|
1877
|
-
}
|
|
1878
|
-
if (this.isDailyLimitExceeded(phoneNumber)) {
|
|
1879
|
-
throw new Error("Daily verification attempt limit exceeded");
|
|
1880
|
-
}
|
|
1881
|
-
const requestId = this.generateRequestId();
|
|
1882
|
-
const verificationCode = this.generateVerificationCode();
|
|
1883
|
-
const expiresAt = new Date(Date.now() + this.options.codeExpiryMinutes * 60 * 1e3);
|
|
1884
|
-
const verificationRequest = {
|
|
1885
|
-
id: requestId,
|
|
1886
|
-
senderNumberId,
|
|
1887
|
-
phoneNumber,
|
|
1888
|
-
verificationType,
|
|
1889
|
-
verificationCode,
|
|
1890
|
-
status: "pending" /* PENDING */,
|
|
1891
|
-
attempts: [],
|
|
1892
|
-
expiresAt,
|
|
1893
|
-
createdAt: /* @__PURE__ */ new Date(),
|
|
1894
|
-
metadata
|
|
1895
|
-
};
|
|
1896
|
-
this.verificationRequests.set(requestId, verificationRequest);
|
|
1897
|
-
this.updateRateLimit(phoneNumber);
|
|
1898
|
-
this.updateDailyAttempts(phoneNumber);
|
|
1899
|
-
this.emit("verification:started", { verificationRequest, phoneInfo });
|
|
1900
|
-
await this.sendVerificationCode(verificationRequest, phoneInfo);
|
|
1901
|
-
return verificationRequest;
|
|
1902
|
-
}
|
|
1903
|
-
/**
|
|
1904
|
-
* Verify the provided code
|
|
1905
|
-
*/
|
|
1906
|
-
async verifyCode(requestId, providedCode) {
|
|
1907
|
-
const request = this.verificationRequests.get(requestId);
|
|
1908
|
-
if (!request) {
|
|
1909
|
-
return {
|
|
1910
|
-
success: false,
|
|
1911
|
-
status: "failed" /* FAILED */,
|
|
1912
|
-
message: "Verification request not found"
|
|
1913
|
-
};
|
|
1914
|
-
}
|
|
1915
|
-
if (request.status === "verified" /* VERIFIED */) {
|
|
1916
|
-
return {
|
|
1917
|
-
success: true,
|
|
1918
|
-
status: "verified" /* VERIFIED */,
|
|
1919
|
-
message: "Already verified"
|
|
1920
|
-
};
|
|
1921
|
-
}
|
|
1922
|
-
if (/* @__PURE__ */ new Date() > request.expiresAt) {
|
|
1923
|
-
request.status = "expired" /* EXPIRED */;
|
|
1924
|
-
this.emit("verification:expired", { verificationRequest: request });
|
|
1925
|
-
return {
|
|
1926
|
-
success: false,
|
|
1927
|
-
status: "expired" /* EXPIRED */,
|
|
1928
|
-
message: "Verification code has expired"
|
|
1929
|
-
};
|
|
1930
|
-
}
|
|
1931
|
-
if (request.status === "blocked" /* BLOCKED */) {
|
|
1932
|
-
return {
|
|
1933
|
-
success: false,
|
|
1934
|
-
status: "blocked" /* BLOCKED */,
|
|
1935
|
-
message: "Verification blocked due to too many failed attempts"
|
|
1936
|
-
};
|
|
1937
|
-
}
|
|
1938
|
-
const isCodeValid = this.validateCode(request.verificationCode, providedCode);
|
|
1939
|
-
if (isCodeValid) {
|
|
1940
|
-
request.status = "verified" /* VERIFIED */;
|
|
1941
|
-
request.completedAt = /* @__PURE__ */ new Date();
|
|
1942
|
-
this.emit("verification:success", { verificationRequest: request });
|
|
1943
|
-
return {
|
|
1944
|
-
success: true,
|
|
1945
|
-
status: "verified" /* VERIFIED */,
|
|
1946
|
-
message: "Phone number verified successfully"
|
|
1947
|
-
};
|
|
1948
|
-
} else {
|
|
1949
|
-
const failedAttempt = {
|
|
1950
|
-
attemptNumber: request.attempts.length + 1,
|
|
1951
|
-
attemptedAt: /* @__PURE__ */ new Date(),
|
|
1952
|
-
method: "sms" /* SMS */,
|
|
1953
|
-
// Assuming SMS for verification attempts
|
|
1954
|
-
status: "failed"
|
|
1955
|
-
};
|
|
1956
|
-
request.attempts.push(failedAttempt);
|
|
1957
|
-
const failedAttempts = request.attempts.filter((a) => a.status === "failed").length;
|
|
1958
|
-
if (failedAttempts >= this.options.maxAttempts) {
|
|
1959
|
-
request.status = "blocked" /* BLOCKED */;
|
|
1960
|
-
this.emit("verification:blocked", { verificationRequest: request });
|
|
1961
|
-
return {
|
|
1962
|
-
success: false,
|
|
1963
|
-
status: "blocked" /* BLOCKED */,
|
|
1964
|
-
message: "Too many failed attempts. Verification blocked."
|
|
1965
|
-
};
|
|
1966
|
-
} else {
|
|
1967
|
-
request.status = "failed" /* FAILED */;
|
|
1968
|
-
this.emit("verification:failed_attempt", {
|
|
1969
|
-
verificationRequest: request,
|
|
1970
|
-
attemptsRemaining: this.options.maxAttempts - failedAttempts
|
|
1971
|
-
});
|
|
1972
|
-
return {
|
|
1973
|
-
success: false,
|
|
1974
|
-
status: "failed" /* FAILED */,
|
|
1975
|
-
message: `Invalid code. ${this.options.maxAttempts - failedAttempts} attempts remaining.`
|
|
1976
|
-
};
|
|
1977
|
-
}
|
|
1978
|
-
}
|
|
1979
|
-
}
|
|
1980
|
-
/**
|
|
1981
|
-
* Resend verification code
|
|
1982
|
-
*/
|
|
1983
|
-
async resendCode(requestId, method) {
|
|
1984
|
-
const request = this.verificationRequests.get(requestId);
|
|
1985
|
-
if (!request) {
|
|
1986
|
-
throw new Error("Verification request not found");
|
|
1987
|
-
}
|
|
1988
|
-
if (request.status === "verified" /* VERIFIED */) {
|
|
1989
|
-
throw new Error("Verification already completed");
|
|
1990
|
-
}
|
|
1991
|
-
if (request.status === "blocked" /* BLOCKED */) {
|
|
1992
|
-
throw new Error("Verification is blocked");
|
|
1993
|
-
}
|
|
1994
|
-
if (this.isRateLimited(request.phoneNumber)) {
|
|
1995
|
-
throw new Error("Rate limit exceeded. Please wait before requesting a new code.");
|
|
1996
|
-
}
|
|
1997
|
-
request.verificationCode = this.generateVerificationCode();
|
|
1998
|
-
request.expiresAt = new Date(Date.now() + this.options.codeExpiryMinutes * 60 * 1e3);
|
|
1999
|
-
request.status = "pending" /* PENDING */;
|
|
2000
|
-
this.updateRateLimit(request.phoneNumber);
|
|
2001
|
-
const phoneInfo = await this.getPhoneNumberInfo(request.phoneNumber);
|
|
2002
|
-
if (method) {
|
|
2003
|
-
await this.sendVerificationByMethod(request, phoneInfo, method);
|
|
2004
|
-
} else {
|
|
2005
|
-
await this.sendVerificationCode(request, phoneInfo);
|
|
2006
|
-
}
|
|
2007
|
-
this.emit("verification:resent", { verificationRequest: request });
|
|
2008
|
-
return request;
|
|
2009
|
-
}
|
|
2010
|
-
/**
|
|
2011
|
-
* Get verification request status
|
|
2012
|
-
*/
|
|
2013
|
-
getVerificationStatus(requestId) {
|
|
2014
|
-
return this.verificationRequests.get(requestId) || null;
|
|
2015
|
-
}
|
|
2016
|
-
/**
|
|
2017
|
-
* Cancel verification request
|
|
2018
|
-
*/
|
|
2019
|
-
async cancelVerification(requestId) {
|
|
2020
|
-
const request = this.verificationRequests.get(requestId);
|
|
2021
|
-
if (!request) {
|
|
2022
|
-
return false;
|
|
2023
|
-
}
|
|
2024
|
-
if (request.status === "verified" /* VERIFIED */) {
|
|
2025
|
-
return false;
|
|
2026
|
-
}
|
|
2027
|
-
this.verificationRequests.delete(requestId);
|
|
2028
|
-
this.emit("verification:cancelled", { verificationRequest: request });
|
|
2029
|
-
return true;
|
|
2030
|
-
}
|
|
2031
|
-
/**
|
|
2032
|
-
* Block a phone number from verification
|
|
2033
|
-
*/
|
|
2034
|
-
blockPhoneNumber(phoneNumber, reason) {
|
|
2035
|
-
this.blockedNumbers.add(phoneNumber);
|
|
2036
|
-
for (const [requestId, request] of this.verificationRequests) {
|
|
2037
|
-
if (request.phoneNumber === phoneNumber && request.status !== "verified" /* VERIFIED */) {
|
|
2038
|
-
request.status = "blocked" /* BLOCKED */;
|
|
2039
|
-
}
|
|
2040
|
-
}
|
|
2041
|
-
this.emit("phone:blocked", { phoneNumber, reason });
|
|
2042
|
-
}
|
|
2043
|
-
/**
|
|
2044
|
-
* Unblock a phone number
|
|
2045
|
-
*/
|
|
2046
|
-
unblockPhoneNumber(phoneNumber) {
|
|
2047
|
-
this.blockedNumbers.delete(phoneNumber);
|
|
2048
|
-
this.emit("phone:unblocked", { phoneNumber });
|
|
2049
|
-
}
|
|
2050
|
-
/**
|
|
2051
|
-
* Get verification statistics
|
|
2052
|
-
*/
|
|
2053
|
-
getVerificationStats() {
|
|
2054
|
-
const requests = Array.from(this.verificationRequests.values());
|
|
2055
|
-
const byStatus = {};
|
|
2056
|
-
const byMethod = {};
|
|
2057
|
-
let totalCompletionTime = 0;
|
|
2058
|
-
let completedCount = 0;
|
|
2059
|
-
requests.forEach((request) => {
|
|
2060
|
-
byStatus[request.status] = (byStatus[request.status] || 0) + 1;
|
|
2061
|
-
if (request.attempts.length > 0) {
|
|
2062
|
-
const primaryMethod = request.attempts[0].method;
|
|
2063
|
-
byMethod[primaryMethod] = (byMethod[primaryMethod] || 0) + 1;
|
|
2064
|
-
}
|
|
2065
|
-
if (request.completedAt) {
|
|
2066
|
-
const completionTime = request.completedAt.getTime() - request.createdAt.getTime();
|
|
2067
|
-
totalCompletionTime += completionTime;
|
|
2068
|
-
completedCount++;
|
|
2069
|
-
}
|
|
2070
|
-
});
|
|
2071
|
-
const successCount = byStatus["verified" /* VERIFIED */] || 0;
|
|
2072
|
-
const successRate = requests.length > 0 ? successCount / requests.length * 100 : 0;
|
|
2073
|
-
return {
|
|
2074
|
-
total: requests.length,
|
|
2075
|
-
byStatus,
|
|
2076
|
-
byMethod,
|
|
2077
|
-
successRate,
|
|
2078
|
-
averageCompletionTime: completedCount > 0 ? totalCompletionTime / completedCount : 0
|
|
2079
|
-
};
|
|
2080
|
-
}
|
|
2081
|
-
/**
|
|
2082
|
-
* Clean up expired verification requests
|
|
2083
|
-
*/
|
|
2084
|
-
cleanup() {
|
|
2085
|
-
const now = /* @__PURE__ */ new Date();
|
|
2086
|
-
let cleanedCount = 0;
|
|
2087
|
-
for (const [requestId, request] of this.verificationRequests) {
|
|
2088
|
-
if (now > request.expiresAt && request.status !== "verified" /* VERIFIED */) {
|
|
2089
|
-
request.status = "expired" /* EXPIRED */;
|
|
2090
|
-
this.verificationRequests.delete(requestId);
|
|
2091
|
-
cleanedCount++;
|
|
2092
|
-
}
|
|
2093
|
-
}
|
|
2094
|
-
const rateWindow = this.options.rateLimitMinutes * 60 * 1e3;
|
|
2095
|
-
for (const [phoneNumber, timestamps] of this.rateLimitTracker) {
|
|
2096
|
-
const validTimestamps = timestamps.filter((ts) => now.getTime() - ts.getTime() < rateWindow);
|
|
2097
|
-
if (validTimestamps.length === 0) {
|
|
2098
|
-
this.rateLimitTracker.delete(phoneNumber);
|
|
2099
|
-
} else {
|
|
2100
|
-
this.rateLimitTracker.set(phoneNumber, validTimestamps);
|
|
2101
|
-
}
|
|
2102
|
-
}
|
|
2103
|
-
return cleanedCount;
|
|
2104
|
-
}
|
|
2105
|
-
// Private Methods
|
|
2106
|
-
async sendVerificationCode(request, phoneInfo) {
|
|
2107
|
-
let method;
|
|
2108
|
-
switch (request.verificationType) {
|
|
2109
|
-
case "sms" /* SMS */:
|
|
2110
|
-
method = "sms" /* SMS */;
|
|
2111
|
-
break;
|
|
2112
|
-
case "voice_call" /* VOICE_CALL */:
|
|
2113
|
-
method = "voice_call" /* VOICE_CALL */;
|
|
2114
|
-
break;
|
|
2115
|
-
case "hybrid" /* HYBRID */:
|
|
2116
|
-
method = phoneInfo.lineType === "landline" ? "voice_call" /* VOICE_CALL */ : "sms" /* SMS */;
|
|
2117
|
-
break;
|
|
2118
|
-
default:
|
|
2119
|
-
method = "sms" /* SMS */;
|
|
2120
|
-
}
|
|
2121
|
-
await this.sendVerificationByMethod(request, phoneInfo, method);
|
|
2122
|
-
}
|
|
2123
|
-
async sendVerificationByMethod(request, phoneInfo, method) {
|
|
2124
|
-
const attempt = {
|
|
2125
|
-
attemptNumber: request.attempts.length + 1,
|
|
2126
|
-
attemptedAt: /* @__PURE__ */ new Date(),
|
|
2127
|
-
method,
|
|
2128
|
-
status: "sent"
|
|
2129
|
-
};
|
|
2130
|
-
const startTime = Date.now();
|
|
2131
|
-
try {
|
|
2132
|
-
switch (method) {
|
|
2133
|
-
case "sms" /* SMS */:
|
|
2134
|
-
await this.sendSMS(request, phoneInfo);
|
|
2135
|
-
break;
|
|
2136
|
-
case "voice_call" /* VOICE_CALL */:
|
|
2137
|
-
await this.sendVoiceCall(request, phoneInfo);
|
|
2138
|
-
break;
|
|
2139
|
-
case "missed_call" /* MISSED_CALL */:
|
|
2140
|
-
await this.sendMissedCall(request, phoneInfo);
|
|
2141
|
-
break;
|
|
2142
|
-
}
|
|
2143
|
-
attempt.status = "delivered";
|
|
2144
|
-
attempt.responseTime = Date.now() - startTime;
|
|
2145
|
-
request.status = "code_sent" /* CODE_SENT */;
|
|
2146
|
-
} catch (error) {
|
|
2147
|
-
attempt.status = "failed";
|
|
2148
|
-
attempt.failureReason = error instanceof Error ? error.message : "Unknown error";
|
|
2149
|
-
attempt.responseTime = Date.now() - startTime;
|
|
2150
|
-
if (method === "sms" /* SMS */ && this.options.enableVoiceFallback && request.attempts.filter((a) => a.method === "voice_call" /* VOICE_CALL */).length === 0) {
|
|
2151
|
-
attempt.status = "failed";
|
|
2152
|
-
request.attempts.push(attempt);
|
|
2153
|
-
await this.sendVerificationByMethod(request, phoneInfo, "voice_call" /* VOICE_CALL */);
|
|
2154
|
-
return;
|
|
2155
|
-
}
|
|
2156
|
-
request.status = "failed" /* FAILED */;
|
|
2157
|
-
throw error;
|
|
2158
|
-
}
|
|
2159
|
-
request.attempts.push(attempt);
|
|
2160
|
-
}
|
|
2161
|
-
async sendSMS(request, phoneInfo) {
|
|
2162
|
-
if (!this.options.smsProvider) {
|
|
2163
|
-
throw new Error("SMS provider not configured");
|
|
2164
|
-
}
|
|
2165
|
-
const message = this.options.smsTemplate.replace("{code}", request.verificationCode).replace("{expiry}", this.options.codeExpiryMinutes.toString());
|
|
2166
|
-
const result = await this.options.smsProvider.sendSMS(request.phoneNumber, message);
|
|
2167
|
-
if (result.status === "failed") {
|
|
2168
|
-
throw new Error(result.error || "SMS sending failed");
|
|
2169
|
-
}
|
|
2170
|
-
}
|
|
2171
|
-
async sendVoiceCall(request, phoneInfo) {
|
|
2172
|
-
if (!this.options.voiceProvider) {
|
|
2173
|
-
throw new Error("Voice provider not configured");
|
|
2174
|
-
}
|
|
2175
|
-
const message = this.options.voiceTemplate.replace("{code}", request.verificationCode.split("").join(" "));
|
|
2176
|
-
const result = await this.options.voiceProvider.makeCall(request.phoneNumber, message);
|
|
2177
|
-
if (result.status === "failed") {
|
|
2178
|
-
throw new Error(result.error || "Voice call failed");
|
|
2179
|
-
}
|
|
2180
|
-
}
|
|
2181
|
-
async sendMissedCall(request, phoneInfo) {
|
|
2182
|
-
if (!this.options.voiceProvider?.makeMissedCall) {
|
|
2183
|
-
throw new Error("Missed call verification not supported");
|
|
2184
|
-
}
|
|
2185
|
-
const result = await this.options.voiceProvider.makeMissedCall(request.phoneNumber);
|
|
2186
|
-
if (result.status === "failed") {
|
|
2187
|
-
throw new Error(result.error || "Missed call failed");
|
|
2188
|
-
}
|
|
2189
|
-
if (result.missedCallNumber) {
|
|
2190
|
-
const codeFromNumber = result.missedCallNumber.slice(-this.options.codeLength);
|
|
2191
|
-
request.verificationCode = codeFromNumber;
|
|
2192
|
-
}
|
|
2193
|
-
}
|
|
2194
|
-
async getPhoneNumberInfo(phoneNumber) {
|
|
2195
|
-
if (this.phoneNumberCache.has(phoneNumber)) {
|
|
2196
|
-
return this.phoneNumberCache.get(phoneNumber);
|
|
2197
|
-
}
|
|
2198
|
-
const phoneInfo = this.parseKoreanPhoneNumber(phoneNumber);
|
|
2199
|
-
this.phoneNumberCache.set(phoneNumber, phoneInfo);
|
|
2200
|
-
return phoneInfo;
|
|
2201
|
-
}
|
|
2202
|
-
parseKoreanPhoneNumber(phoneNumber) {
|
|
2203
|
-
const cleaned = phoneNumber.replace(/\D/g, "");
|
|
2204
|
-
const mobilePattern = /^(010|011|016|017|018|019)(\d{7,8})$/;
|
|
2205
|
-
const landlinePattern = /^(02|031|032|033|041|042|043|044|051|052|053|054|055|061|062|063|064)(\d{7,8})$/;
|
|
2206
|
-
let isValid = false;
|
|
2207
|
-
let isPossible = false;
|
|
2208
|
-
let lineType = "unknown";
|
|
2209
|
-
let carrier;
|
|
2210
|
-
if (mobilePattern.test(cleaned)) {
|
|
2211
|
-
isValid = true;
|
|
2212
|
-
isPossible = true;
|
|
2213
|
-
lineType = "mobile";
|
|
2214
|
-
const prefix = cleaned.substring(0, 3);
|
|
2215
|
-
switch (prefix) {
|
|
2216
|
-
case "010":
|
|
2217
|
-
carrier = "Multiple carriers";
|
|
2218
|
-
break;
|
|
2219
|
-
case "011":
|
|
2220
|
-
carrier = "SK Telecom";
|
|
2221
|
-
break;
|
|
2222
|
-
case "016":
|
|
2223
|
-
carrier = "KT";
|
|
2224
|
-
break;
|
|
2225
|
-
case "017":
|
|
2226
|
-
carrier = "LG U+";
|
|
2227
|
-
break;
|
|
2228
|
-
case "018":
|
|
2229
|
-
carrier = "SK Telecom";
|
|
2230
|
-
break;
|
|
2231
|
-
case "019":
|
|
2232
|
-
carrier = "LG U+";
|
|
2233
|
-
break;
|
|
2234
|
-
}
|
|
2235
|
-
} else if (landlinePattern.test(cleaned)) {
|
|
2236
|
-
isValid = true;
|
|
2237
|
-
isPossible = true;
|
|
2238
|
-
lineType = "landline";
|
|
2239
|
-
} else if (cleaned.length >= 10 && cleaned.length <= 11) {
|
|
2240
|
-
isPossible = true;
|
|
2241
|
-
}
|
|
2242
|
-
return {
|
|
2243
|
-
phoneNumber: cleaned,
|
|
2244
|
-
countryCode: "82",
|
|
2245
|
-
nationalNumber: cleaned,
|
|
2246
|
-
carrier,
|
|
2247
|
-
lineType,
|
|
2248
|
-
isValid,
|
|
2249
|
-
isPossible,
|
|
2250
|
-
region: "KR"
|
|
2251
|
-
};
|
|
2252
|
-
}
|
|
2253
|
-
isNumberBlocked(phoneNumber) {
|
|
2254
|
-
return this.blockedNumbers.has(phoneNumber);
|
|
2255
|
-
}
|
|
2256
|
-
isRateLimited(phoneNumber) {
|
|
2257
|
-
const timestamps = this.rateLimitTracker.get(phoneNumber) || [];
|
|
2258
|
-
const rateWindow = this.options.rateLimitMinutes * 60 * 1e3;
|
|
2259
|
-
const now = /* @__PURE__ */ new Date();
|
|
2260
|
-
const recentAttempts = timestamps.filter((ts) => now.getTime() - ts.getTime() < rateWindow);
|
|
2261
|
-
return recentAttempts.length >= 1;
|
|
2262
|
-
}
|
|
2263
|
-
isDailyLimitExceeded(phoneNumber) {
|
|
2264
|
-
const today = (/* @__PURE__ */ new Date()).toISOString().split("T")[0];
|
|
2265
|
-
const dailyData = this.dailyAttemptTracker.get(phoneNumber);
|
|
2266
|
-
if (!dailyData || dailyData.date !== today) {
|
|
2267
|
-
return false;
|
|
2268
|
-
}
|
|
2269
|
-
return dailyData.count >= this.options.maxDailyAttempts;
|
|
2270
|
-
}
|
|
2271
|
-
updateRateLimit(phoneNumber) {
|
|
2272
|
-
const timestamps = this.rateLimitTracker.get(phoneNumber) || [];
|
|
2273
|
-
timestamps.push(/* @__PURE__ */ new Date());
|
|
2274
|
-
this.rateLimitTracker.set(phoneNumber, timestamps);
|
|
2275
|
-
}
|
|
2276
|
-
updateDailyAttempts(phoneNumber) {
|
|
2277
|
-
const today = (/* @__PURE__ */ new Date()).toISOString().split("T")[0];
|
|
2278
|
-
const dailyData = this.dailyAttemptTracker.get(phoneNumber);
|
|
2279
|
-
if (!dailyData || dailyData.date !== today) {
|
|
2280
|
-
this.dailyAttemptTracker.set(phoneNumber, { date: today, count: 1 });
|
|
2281
|
-
} else {
|
|
2282
|
-
dailyData.count++;
|
|
2283
|
-
}
|
|
2284
|
-
}
|
|
2285
|
-
validateCode(expected, provided) {
|
|
2286
|
-
return expected === provided.replace(/\s/g, "");
|
|
2287
|
-
}
|
|
2288
|
-
generateVerificationCode() {
|
|
2289
|
-
const length = this.options.codeLength;
|
|
2290
|
-
let code = "";
|
|
2291
|
-
for (let i = 0; i < length; i++) {
|
|
2292
|
-
code += Math.floor(Math.random() * 10).toString();
|
|
2293
|
-
}
|
|
2294
|
-
return code;
|
|
2295
|
-
}
|
|
2296
|
-
generateRequestId() {
|
|
2297
|
-
return `phone_verify_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
|
|
2298
|
-
}
|
|
2299
|
-
};
|
|
21
|
+
Set the \`cycles\` parameter to \`"ref"\` to resolve cyclical schemas with defs.`)}for(let n of this.seen.entries()){let k=n[1];if(r===n[0]){o(n);continue}if(c.external){let b=c.external.registry.get(n[0])?.id;if(r!==n[0]&&b){o(n);continue}}if(this.metadataRegistry.get(n[0])?.id){o(n);continue}if(k.cycle){o(n);continue}if(k.count>1){if(c.reused==="ref"){o(n);continue}}}let U=(n,k)=>{let P=this.seen.get(n),b=P.def??P.schema,O={...b};if(P.ref===null)return;let I=P.ref;if(P.ref=null,I){U(I,k);let x=this.seen.get(I).schema;if(x.$ref&&(k.target==="draft-7"||k.target==="draft-4"))b.allOf=b.allOf??[],b.allOf.push(x);else Object.assign(b,x),Object.assign(b,O)}if(!P.isParent)this.override({zodSchema:n,jsonSchema:b,path:P.path??[]})};for(let n of[...this.seen.entries()].reverse())U(n[0],{target:this.target});let _={};if(this.target==="draft-2020-12")_.$schema="https://json-schema.org/draft/2020-12/schema";else if(this.target==="draft-7")_.$schema="http://json-schema.org/draft-07/schema#";else if(this.target==="draft-4")_.$schema="http://json-schema.org/draft-04/schema#";else console.warn(`Invalid target: ${this.target}`);if(c.external?.uri){let n=c.external.registry.get(r)?.id;if(!n)throw Error("Schema is missing an `id` property");_.$id=c.external.uri(n)}Object.assign(_,g.def);let j=c.external?.defs??{};for(let n of this.seen.entries()){let k=n[1];if(k.def&&k.defId)j[k.defId]=k.def}if(c.external);else if(Object.keys(j).length>0)if(this.target==="draft-2020-12")_.$defs=j;else _.definitions=j;try{return JSON.parse(JSON.stringify(_))}catch(n){throw Error("Error converting schema to JSON.")}}}function U4(r,v){if(r instanceof Zr){let g=new e$(v),$={};for(let _ of r._idmap.entries()){let[j,n]=_;g.process(n)}let o={},U={registry:r,uri:v?.uri,defs:$};for(let _ of r._idmap.entries()){let[j,n]=_;o[j]=g.emit(n,{...v,external:U})}if(Object.keys($).length>0){let _=g.target==="draft-2020-12"?"$defs":"definitions";o.__shared={[_]:$}}return{schemas:o}}let c=new e$(v);return c.process(r),c.emit(r,v)}function M(r,v){let c=v??{seen:new Set};if(c.seen.has(r))return!1;c.seen.add(r);let $=r._zod.def;switch($.type){case"string":case"number":case"bigint":case"boolean":case"date":case"symbol":case"undefined":case"null":case"any":case"unknown":case"never":case"void":case"literal":case"enum":case"nan":case"file":case"template_literal":return!1;case"array":return M($.element,c);case"object":{for(let o in $.shape)if(M($.shape[o],c))return!0;return!1}case"union":{for(let o of $.options)if(M(o,c))return!0;return!1}case"intersection":return M($.left,c)||M($.right,c);case"tuple":{for(let o of $.items)if(M(o,c))return!0;if($.rest&&M($.rest,c))return!0;return!1}case"record":return M($.keyType,c)||M($.valueType,c);case"map":return M($.keyType,c)||M($.valueType,c);case"set":return M($.valueType,c);case"promise":case"optional":case"nonoptional":case"nullable":case"readonly":return M($.innerType,c);case"lazy":return M($.getter(),c);case"default":return M($.innerType,c);case"prefault":return M($.innerType,c);case"custom":return!1;case"transform":return!0;case"pipe":return M($.in,c)||M($.out,c);case"success":return!1;case"catch":return!1;default:}throw Error(`Unknown schema type: ${$.type}`)}var V6={};var cv={};a(cv,{time:()=>j4,duration:()=>O4,datetime:()=>_4,date:()=>w4,ZodISOTime:()=>$v,ZodISODuration:()=>vv,ZodISODateTime:()=>s$,ZodISODate:()=>rv});var s$=w("ZodISODateTime",(r,v)=>{Fc.init(r,v),u.init(r,v)});function _4(r){return Jg(s$,r)}var rv=w("ZodISODate",(r,v)=>{Vc.init(r,v),u.init(r,v)});function w4(r){return Xg(rv,r)}var $v=w("ZodISOTime",(r,v)=>{mc.init(r,v),u.init(r,v)});function j4(r){return Wg($v,r)}var vv=w("ZodISODuration",(r,v)=>{Rc.init(r,v),u.init(r,v)});function O4(r){return Kg(vv,r)}var R6=(r,v)=>{Mr.init(r,v),r.name="ZodError",Object.defineProperties(r,{format:{value:(c)=>Er(r,c)},flatten:{value:(c)=>tr(r,c)},addIssue:{value:(c)=>{r.issues.push(c),r.message=JSON.stringify(r.issues,nr,2)}},addIssues:{value:(c)=>{r.issues.push(...c),r.message=JSON.stringify(r.issues,nr,2)}},isEmpty:{get(){return r.issues.length===0}}})},Hw=w("ZodError",R6),Jr=w("ZodError",R6,{Parent:Error});var n4=z$(Jr),k4=D$(Jr),i4=P$(Jr),z4=I$(Jr);var W=w("ZodType",(r,v)=>{return J.init(r,v),r.def=v,Object.defineProperty(r,"_def",{value:v}),r.check=(...c)=>{return r.clone({...v,checks:[...v.checks??[],...c.map((g)=>typeof g==="function"?{_zod:{check:g,def:{check:"custom"},onattach:[]}}:g)]})},r.clone=(c,g)=>E(r,c,g),r.brand=()=>r,r.register=(c,g)=>{return c.add(r,g),r},r.parse=(c,g)=>n4(r,c,g,{callee:r.parse}),r.safeParse=(c,g)=>i4(r,c,g),r.parseAsync=async(c,g)=>k4(r,c,g,{callee:r.parseAsync}),r.safeParseAsync=async(c,g)=>z4(r,c,g),r.spa=r.safeParseAsync,r.refine=(c,g)=>r.check(GU(c,g)),r.superRefine=(c)=>r.check(AU(c)),r.overwrite=(c)=>r.check(y(c)),r.optional=()=>Uv(r),r.nullable=()=>_v(r),r.nullish=()=>Uv(_v(r)),r.nonoptional=(c)=>zU(r,c),r.array=()=>V4(r),r.or=(c)=>R4([r,c]),r.and=(c)=>rU(r,c),r.transform=(c)=>wv(r,Z4(c)),r.default=(c)=>nU(r,c),r.prefault=(c)=>iU(r,c),r.catch=(c)=>SU(r,c),r.pipe=(c)=>wv(r,c),r.readonly=()=>xU(r),r.describe=(c)=>{let g=r.clone();return Z.add(g,{description:c}),g},Object.defineProperty(r,"description",{get(){return Z.get(r)?.description},configurable:!0}),r.meta=(...c)=>{if(c.length===0)return Z.get(r);let g=r.clone();return Z.add(g,c[0]),g},r.isOptional=()=>r.safeParse(void 0).success,r.isNullable=()=>r.safeParse(null).success,r}),S4=w("_ZodString",(r,v)=>{or.init(r,v),W.init(r,v);let c=r._zod.bag;r.format=c.format??null,r.minLength=c.minimum??null,r.maxLength=c.maximum??null,r.regex=(...g)=>r.check(hr(...g)),r.includes=(...g)=>r.check(pr(...g)),r.startsWith=(...g)=>r.check(dr(...g)),r.endsWith=(...g)=>r.check(ar(...g)),r.min=(...g)=>r.check(rr(...g)),r.max=(...g)=>r.check(Ir(...g)),r.length=(...g)=>r.check(xr(...g)),r.nonempty=(...g)=>r.check(rr(1,...g)),r.lowercase=(g)=>r.check(fr(g)),r.uppercase=(g)=>r.check(yr(g)),r.trim=()=>r.check(r$()),r.normalize=(...g)=>r.check(sr(...g)),r.toLowerCase=()=>r.check($$()),r.toUpperCase=()=>r.check(v$())}),g$=w("ZodString",(r,v)=>{or.init(r,v),S4.init(r,v),r.email=(c)=>r.check(u$(P4,c)),r.url=(c)=>r.check(t$(I4,c)),r.jwt=(c)=>r.check(d$(M4,c)),r.emoji=(c)=>r.check(E$(x4,c)),r.guid=(c)=>r.check(qr(ov,c)),r.uuid=(c)=>r.check(H$(d,c)),r.uuidv4=(c)=>r.check(N$(d,c)),r.uuidv6=(c)=>r.check(B$(d,c)),r.uuidv7=(c)=>r.check(M$(d,c)),r.nanoid=(c)=>r.check(F$(J4,c)),r.guid=(c)=>r.check(qr(ov,c)),r.cuid=(c)=>r.check(V$(X4,c)),r.cuid2=(c)=>r.check(m$(W4,c)),r.ulid=(c)=>r.check(R$(K4,c)),r.base64=(c)=>r.check(f$(H4,c)),r.base64url=(c)=>r.check(y$(N4,c)),r.xid=(c)=>r.check(T$(G4,c)),r.ksuid=(c)=>r.check(l$(A4,c)),r.ipv4=(c)=>r.check(Z$(L4,c)),r.ipv6=(c)=>r.check(q$(Q4,c)),r.cidrv4=(c)=>r.check(C$(Y4,c)),r.cidrv6=(c)=>r.check(h$(u4,c)),r.e164=(c)=>r.check(p$(B4,c)),r.datetime=(c)=>r.check(_4(c)),r.date=(c)=>r.check(w4(c)),r.time=(c)=>r.check(j4(c)),r.duration=(c)=>r.check(O4(c))});function b4(r){return Pg(g$,r)}var u=w("ZodStringFormat",(r,v)=>{Y.init(r,v),S4.init(r,v)}),P4=w("ZodEmail",(r,v)=>{Qc.init(r,v),u.init(r,v)});function Bw(r){return u$(P4,r)}var ov=w("ZodGUID",(r,v)=>{Ac.init(r,v),u.init(r,v)});function Mw(r){return qr(ov,r)}var d=w("ZodUUID",(r,v)=>{Lc.init(r,v),u.init(r,v)});function tw(r){return H$(d,r)}function Ew(r){return N$(d,r)}function Fw(r){return B$(d,r)}function Vw(r){return M$(d,r)}var I4=w("ZodURL",(r,v)=>{Yc.init(r,v),u.init(r,v)});function mw(r){return t$(I4,r)}var x4=w("ZodEmoji",(r,v)=>{uc.init(r,v),u.init(r,v)});function Rw(r){return E$(x4,r)}var J4=w("ZodNanoID",(r,v)=>{Hc.init(r,v),u.init(r,v)});function Tw(r){return F$(J4,r)}var X4=w("ZodCUID",(r,v)=>{Nc.init(r,v),u.init(r,v)});function lw(r){return V$(X4,r)}var W4=w("ZodCUID2",(r,v)=>{Bc.init(r,v),u.init(r,v)});function Zw(r){return m$(W4,r)}var K4=w("ZodULID",(r,v)=>{Mc.init(r,v),u.init(r,v)});function qw(r){return R$(K4,r)}var G4=w("ZodXID",(r,v)=>{tc.init(r,v),u.init(r,v)});function Cw(r){return T$(G4,r)}var A4=w("ZodKSUID",(r,v)=>{Ec.init(r,v),u.init(r,v)});function hw(r){return l$(A4,r)}var L4=w("ZodIPv4",(r,v)=>{Tc.init(r,v),u.init(r,v)});function fw(r){return Z$(L4,r)}var Q4=w("ZodIPv6",(r,v)=>{lc.init(r,v),u.init(r,v)});function yw(r){return q$(Q4,r)}var Y4=w("ZodCIDRv4",(r,v)=>{Zc.init(r,v),u.init(r,v)});function pw(r){return C$(Y4,r)}var u4=w("ZodCIDRv6",(r,v)=>{qc.init(r,v),u.init(r,v)});function dw(r){return h$(u4,r)}var H4=w("ZodBase64",(r,v)=>{hc.init(r,v),u.init(r,v)});function aw(r){return f$(H4,r)}var N4=w("ZodBase64URL",(r,v)=>{fc.init(r,v),u.init(r,v)});function ew(r){return y$(N4,r)}var B4=w("ZodE164",(r,v)=>{yc.init(r,v),u.init(r,v)});function sw(r){return p$(B4,r)}var M4=w("ZodJWT",(r,v)=>{pc.init(r,v),u.init(r,v)});function rj(r){return d$(M4,r)}var t4=w("ZodCustomStringFormat",(r,v)=>{dc.init(r,v),u.init(r,v)});function $j(r,v,c={}){return a$(t4,r,v,c)}function vj(r){return a$(t4,"hostname",C.hostname,r)}var U$=w("ZodNumber",(r,v)=>{A$.init(r,v),W.init(r,v),r.gt=(g,$)=>r.check(f(g,$)),r.gte=(g,$)=>r.check(F(g,$)),r.min=(g,$)=>r.check(F(g,$)),r.lt=(g,$)=>r.check(h(g,$)),r.lte=(g,$)=>r.check(T(g,$)),r.max=(g,$)=>r.check(T(g,$)),r.int=(g)=>r.check(D4(g)),r.safe=(g)=>r.check(D4(g)),r.positive=(g)=>r.check(f(0,g)),r.nonnegative=(g)=>r.check(F(0,g)),r.negative=(g)=>r.check(h(0,g)),r.nonpositive=(g)=>r.check(T(0,g)),r.multipleOf=(g,$)=>r.check(Ur(g,$)),r.step=(g,$)=>r.check(Ur(g,$)),r.finite=()=>r;let c=r._zod.bag;r.minValue=Math.max(c.minimum??Number.NEGATIVE_INFINITY,c.exclusiveMinimum??Number.NEGATIVE_INFINITY)??null,r.maxValue=Math.min(c.maximum??Number.POSITIVE_INFINITY,c.exclusiveMaximum??Number.POSITIVE_INFINITY)??null,r.isInt=(c.format??"").includes("int")||Number.isSafeInteger(c.multipleOf??0.5),r.isFinite=!0,r.format=c.format??null});function T6(r){return Gg(U$,r)}var Xr=w("ZodNumberFormat",(r,v)=>{ac.init(r,v),U$.init(r,v)});function D4(r){return Lg(Xr,r)}function cj(r){return Qg(Xr,r)}function oj(r){return Yg(Xr,r)}function gj(r){return ug(Xr,r)}function Uj(r){return Hg(Xr,r)}var _$=w("ZodBoolean",(r,v)=>{Fr.init(r,v),W.init(r,v)});function l6(r){return Ng(_$,r)}var w$=w("ZodBigInt",(r,v)=>{L$.init(r,v),W.init(r,v),r.gte=(g,$)=>r.check(F(g,$)),r.min=(g,$)=>r.check(F(g,$)),r.gt=(g,$)=>r.check(f(g,$)),r.gte=(g,$)=>r.check(F(g,$)),r.min=(g,$)=>r.check(F(g,$)),r.lt=(g,$)=>r.check(h(g,$)),r.lte=(g,$)=>r.check(T(g,$)),r.max=(g,$)=>r.check(T(g,$)),r.positive=(g)=>r.check(f(BigInt(0),g)),r.negative=(g)=>r.check(h(BigInt(0),g)),r.nonpositive=(g)=>r.check(T(BigInt(0),g)),r.nonnegative=(g)=>r.check(F(BigInt(0),g)),r.multipleOf=(g,$)=>r.check(Ur(g,$));let c=r._zod.bag;r.minValue=c.minimum??null,r.maxValue=c.maximum??null,r.format=c.format??null});function _j(r){return Mg(w$,r)}var E4=w("ZodBigIntFormat",(r,v)=>{ec.init(r,v),w$.init(r,v)});function wj(r){return Eg(E4,r)}function jj(r){return Fg(E4,r)}var Z6=w("ZodSymbol",(r,v)=>{sc.init(r,v),W.init(r,v)});function Oj(r){return Vg(Z6,r)}var q6=w("ZodUndefined",(r,v)=>{ro.init(r,v),W.init(r,v)});function nj(r){return mg(q6,r)}var C6=w("ZodNull",(r,v)=>{$o.init(r,v),W.init(r,v)});function h6(r){return Rg(C6,r)}var f6=w("ZodAny",(r,v)=>{vo.init(r,v),W.init(r,v)});function kj(){return Tg(f6)}var y6=w("ZodUnknown",(r,v)=>{Dr.init(r,v),W.init(r,v)});function gv(){return Sr(y6)}var p6=w("ZodNever",(r,v)=>{co.init(r,v),W.init(r,v)});function F4(r){return lg(p6,r)}var d6=w("ZodVoid",(r,v)=>{oo.init(r,v),W.init(r,v)});function ij(r){return Zg(d6,r)}var jv=w("ZodDate",(r,v)=>{go.init(r,v),W.init(r,v),r.min=(g,$)=>r.check(F(g,$)),r.max=(g,$)=>r.check(T(g,$));let c=r._zod.bag;r.minDate=c.minimum?new Date(c.minimum):null,r.maxDate=c.maximum?new Date(c.maximum):null});function zj(r){return qg(jv,r)}var a6=w("ZodArray",(r,v)=>{Vr.init(r,v),W.init(r,v),r.element=v.element,r.min=(c,g)=>r.check(rr(c,g)),r.nonempty=(c)=>r.check(rr(1,c)),r.max=(c,g)=>r.check(Ir(c,g)),r.length=(c,g)=>r.check(xr(c,g)),r.unwrap=()=>r.element});function V4(r,v){return c$(a6,r,v)}function bj(r){let v=r._zod.def.shape;return _U(Object.keys(v))}var Ov=w("ZodObject",(r,v)=>{Uo.init(r,v),W.init(r,v),S.defineLazy(r,"shape",()=>v.shape),r.keyof=()=>gU(Object.keys(r._zod.def.shape)),r.catchall=(c)=>r.clone({...r._zod.def,catchall:c}),r.passthrough=()=>r.clone({...r._zod.def,catchall:gv()}),r.loose=()=>r.clone({...r._zod.def,catchall:gv()}),r.strict=()=>r.clone({...r._zod.def,catchall:F4()}),r.strip=()=>r.clone({...r._zod.def,catchall:void 0}),r.extend=(c)=>{return S.extend(r,c)},r.merge=(c)=>S.merge(r,c),r.pick=(c)=>S.pick(r,c),r.omit=(c)=>S.omit(r,c),r.partial=(...c)=>S.partial(q4,r,c[0]),r.required=(...c)=>S.required(C4,r,c[0])});function Dj(r,v){let c={type:"object",get shape(){return S.assignProp(this,"shape",r?S.objectClone(r):{}),this.shape},...S.normalizeParams(v)};return new Ov(c)}function Sj(r,v){return new Ov({type:"object",get shape(){return S.assignProp(this,"shape",S.objectClone(r)),this.shape},catchall:F4(),...S.normalizeParams(v)})}function Pj(r,v){return new Ov({type:"object",get shape(){return S.assignProp(this,"shape",S.objectClone(r)),this.shape},catchall:gv(),...S.normalizeParams(v)})}var m4=w("ZodUnion",(r,v)=>{Q$.init(r,v),W.init(r,v),r.options=v.options});function R4(r,v){return new m4({type:"union",options:r,...S.normalizeParams(v)})}var e6=w("ZodDiscriminatedUnion",(r,v)=>{m4.init(r,v),_o.init(r,v)});function Ij(r,v,c){return new e6({type:"union",options:v,discriminator:r,...S.normalizeParams(c)})}var s6=w("ZodIntersection",(r,v)=>{wo.init(r,v),W.init(r,v)});function rU(r,v){return new s6({type:"intersection",left:r,right:v})}var $U=w("ZodTuple",(r,v)=>{gr.init(r,v),W.init(r,v),r.rest=(c)=>r.clone({...r._zod.def,rest:c})});function xj(r,v,c){let g=v instanceof J,$=g?c:v;return new $U({type:"tuple",items:r,rest:g?v:null,...S.normalizeParams($)})}var T4=w("ZodRecord",(r,v)=>{jo.init(r,v),W.init(r,v),r.keyType=v.keyType,r.valueType=v.valueType});function vU(r,v,c){return new T4({type:"record",keyType:r,valueType:v,...S.normalizeParams(c)})}function Jj(r,v,c){let g=E(r);return g._zod.values=void 0,new T4({type:"record",keyType:g,valueType:v,...S.normalizeParams(c)})}var cU=w("ZodMap",(r,v)=>{Oo.init(r,v),W.init(r,v),r.keyType=v.keyType,r.valueType=v.valueType});function Xj(r,v,c){return new cU({type:"map",keyType:r,valueType:v,...S.normalizeParams(c)})}var oU=w("ZodSet",(r,v)=>{no.init(r,v),W.init(r,v),r.min=(...c)=>r.check(_r(...c)),r.nonempty=(c)=>r.check(_r(1,c)),r.max=(...c)=>r.check(Pr(...c)),r.size=(...c)=>r.check(Cr(...c))});function Wj(r,v){return new oU({type:"set",valueType:r,...S.normalizeParams(v)})}var o$=w("ZodEnum",(r,v)=>{ko.init(r,v),W.init(r,v),r.enum=v.entries,r.options=Object.values(v.entries);let c=new Set(Object.keys(v.entries));r.extract=(g,$)=>{let o={};for(let U of g)if(c.has(U))o[U]=v.entries[U];else throw Error(`Key ${U} not found in enum`);return new o$({...v,checks:[],...S.normalizeParams($),entries:o})},r.exclude=(g,$)=>{let o={...v.entries};for(let U of g)if(c.has(U))delete o[U];else throw Error(`Key ${U} not found in enum`);return new o$({...v,checks:[],...S.normalizeParams($),entries:o})}});function gU(r,v){let c=Array.isArray(r)?Object.fromEntries(r.map((g)=>[g,g])):r;return new o$({type:"enum",entries:c,...S.normalizeParams(v)})}function Kj(r,v){return new o$({type:"enum",entries:r,...S.normalizeParams(v)})}var UU=w("ZodLiteral",(r,v)=>{io.init(r,v),W.init(r,v),r.values=new Set(v.values),Object.defineProperty(r,"value",{get(){if(v.values.length>1)throw Error("This schema contains multiple valid literal values. Use `.values` instead.");return v.values[0]}})});function _U(r,v){return new UU({type:"literal",values:Array.isArray(r)?r:[r],...S.normalizeParams(v)})}var wU=w("ZodFile",(r,v)=>{zo.init(r,v),W.init(r,v),r.min=(c,g)=>r.check(_r(c,g)),r.max=(c,g)=>r.check(Pr(c,g)),r.mime=(c,g)=>r.check(er(Array.isArray(c)?c:[c],g))});function Gj(r){return sg(wU,r)}var l4=w("ZodTransform",(r,v)=>{mr.init(r,v),W.init(r,v),r._zod.parse=(c,g)=>{c.addIssue=(o)=>{if(typeof o==="string")c.issues.push(S.issue(o,c.value,v));else{let U=o;if(U.fatal)U.continue=!1;U.code??(U.code="custom"),U.input??(U.input=c.value),U.inst??(U.inst=r),c.issues.push(S.issue(U))}};let $=v.transform(c.value,c);if($ instanceof Promise)return $.then((o)=>{return c.value=o,c});return c.value=$,c}});function Z4(r){return new l4({type:"transform",transform:r})}var q4=w("ZodOptional",(r,v)=>{bo.init(r,v),W.init(r,v),r.unwrap=()=>r._zod.def.innerType});function Uv(r){return new q4({type:"optional",innerType:r})}var jU=w("ZodNullable",(r,v)=>{Do.init(r,v),W.init(r,v),r.unwrap=()=>r._zod.def.innerType});function _v(r){return new jU({type:"nullable",innerType:r})}function Aj(r){return Uv(_v(r))}var OU=w("ZodDefault",(r,v)=>{So.init(r,v),W.init(r,v),r.unwrap=()=>r._zod.def.innerType,r.removeDefault=r.unwrap});function nU(r,v){return new OU({type:"default",innerType:r,get defaultValue(){return typeof v==="function"?v():v}})}var kU=w("ZodPrefault",(r,v)=>{Po.init(r,v),W.init(r,v),r.unwrap=()=>r._zod.def.innerType});function iU(r,v){return new kU({type:"prefault",innerType:r,get defaultValue(){return typeof v==="function"?v():v}})}var C4=w("ZodNonOptional",(r,v)=>{Io.init(r,v),W.init(r,v),r.unwrap=()=>r._zod.def.innerType});function zU(r,v){return new C4({type:"nonoptional",innerType:r,...S.normalizeParams(v)})}var bU=w("ZodSuccess",(r,v)=>{xo.init(r,v),W.init(r,v),r.unwrap=()=>r._zod.def.innerType});function Lj(r){return new bU({type:"success",innerType:r})}var DU=w("ZodCatch",(r,v)=>{Jo.init(r,v),W.init(r,v),r.unwrap=()=>r._zod.def.innerType,r.removeCatch=r.unwrap});function SU(r,v){return new DU({type:"catch",innerType:r,catchValue:typeof v==="function"?v:()=>v})}var PU=w("ZodNaN",(r,v)=>{Xo.init(r,v),W.init(r,v)});function Qj(r){return hg(PU,r)}var h4=w("ZodPipe",(r,v)=>{Rr.init(r,v),W.init(r,v),r.in=v.in,r.out=v.out});function wv(r,v){return new h4({type:"pipe",in:r,out:v})}var IU=w("ZodReadonly",(r,v)=>{Wo.init(r,v),W.init(r,v),r.unwrap=()=>r._zod.def.innerType});function xU(r){return new IU({type:"readonly",innerType:r})}var JU=w("ZodTemplateLiteral",(r,v)=>{Ko.init(r,v),W.init(r,v)});function Yj(r,v){return new JU({type:"template_literal",parts:r,...S.normalizeParams(v)})}var XU=w("ZodLazy",(r,v)=>{Ao.init(r,v),W.init(r,v),r.unwrap=()=>r._zod.def.getter()});function WU(r){return new XU({type:"lazy",getter:r})}var KU=w("ZodPromise",(r,v)=>{Go.init(r,v),W.init(r,v),r.unwrap=()=>r._zod.def.innerType});function uj(r){return new KU({type:"promise",innerType:r})}var nv=w("ZodCustom",(r,v)=>{Lo.init(r,v),W.init(r,v)});function Hj(r){let v=new H({check:"custom"});return v._zod.check=r,v}function Nj(r,v){return r4(nv,r??(()=>!0),v)}function GU(r,v={}){return $4(nv,r,v)}function AU(r){return v4(r)}function Bj(r,v={error:`Input not instance of ${r.name}`}){let c=new nv({type:"custom",check:"custom",fn:(g)=>g instanceof r,abort:!0,...S.normalizeParams(v)});return c._zod.bag.Class=r,c}var Mj=(...r)=>c4({Pipe:h4,Boolean:_$,String:g$,Transform:l4},...r);function tj(r){let v=WU(()=>{return R4([b4(r),T6(),l6(),h6(),V4(v),vU(b4(),v)])});return v}function Ej(r,v){return wv(Z4(r),v)}var Fj={invalid_type:"invalid_type",too_big:"too_big",too_small:"too_small",invalid_format:"invalid_format",not_multiple_of:"not_multiple_of",unrecognized_keys:"unrecognized_keys",invalid_union:"invalid_union",invalid_key:"invalid_key",invalid_element:"invalid_element",invalid_value:"invalid_value",custom:"custom"};function Vj(r){B({customError:r})}function mj(){return B().customError}var f4;(function(r){})(f4||(f4={}));var y4={};a(y4,{string:()=>Rj,number:()=>Tj,date:()=>qj,boolean:()=>lj,bigint:()=>Zj});function Rj(r){return Ig(g$,r)}function Tj(r){return Ag(U$,r)}function lj(r){return Bg(_$,r)}function Zj(r){return tg(w$,r)}function qj(r){return Cg(jv,r)}B(Tr());var Wr;((o)=>{o.KAKAO_ALIMTALK="KAKAO_ALIMTALK";o.KAKAO_FRIENDTALK="KAKAO_FRIENDTALK";o.SMS="SMS";o.LMS="LMS";o.MMS="MMS"})(Wr||={});var j$;((U)=>{U.PENDING="PENDING";U.VERIFYING="VERIFYING";U.ACTIVE="ACTIVE";U.SUSPENDED="SUSPENDED";U.BLOCKED="BLOCKED";U.DELETED="DELETED"})(j$||={});var Kr;((o)=>{o.PENDING="PENDING";o.VERIFYING="VERIFYING";o.VERIFIED="VERIFIED";o.REJECTED="REJECTED";o.BLOCKED="BLOCKED"})(Kr||={});var kv;(($)=>{$.BUSINESS="BUSINESS";$.PERSONAL="PERSONAL";$.GOVERNMENT="GOVERNMENT";$.NON_PROFIT="NON_PROFIT"})(kv||={});var O$;((o)=>{o.NOT_REQUIRED="NOT_REQUIRED";o.PENDING="PENDING";o.UNDER_REVIEW="UNDER_REVIEW";o.VERIFIED="VERIFIED";o.REJECTED="REJECTED"})(O$||={});var p4;((o)=>{o.BUSINESS_REGISTRATION="BUSINESS_REGISTRATION";o.BUSINESS_LICENSE="BUSINESS_LICENSE";o.ID_CARD="ID_CARD";o.AUTHORIZATION_LETTER="AUTHORIZATION_LETTER";o.OTHER="OTHER"})(p4||={});var d4;((g)=>{g.UPLOADED="UPLOADED";g.VERIFIED="VERIFIED";g.REJECTED="REJECTED"})(d4||={});var Cj=X.object({name:X.string().min(1).max(100),type:X.nativeEnum(Wr),provider:X.string().min(1),profileKey:X.string().min(1),businessInfo:X.object({name:X.string().min(1),registrationNumber:X.string().min(1),category:X.string().min(1),contactPerson:X.string().min(1),contactEmail:X.string().email(),contactPhone:X.string().regex(/^[0-9-+\s()]+$/)}).optional(),kakaoInfo:X.object({plusFriendId:X.string().min(1),brandName:X.string().min(1),logoUrl:X.string().url().optional(),description:X.string().max(500).optional()}).optional()}),hj=X.object({phoneNumber:X.string().regex(/^[0-9]{10,11}$/),category:X.nativeEnum(kv),businessInfo:X.object({businessName:X.string().min(1),businessRegistrationNumber:X.string().min(1),contactPerson:X.string().min(1),contactEmail:X.string().email()}).optional()}),fj=X.object({provider:X.string().optional(),type:X.nativeEnum(Wr).optional(),status:X.nativeEnum(j$).optional(),verified:X.boolean().optional(),createdAfter:X.date().optional(),createdBefore:X.date().optional()}),yj=X.object({channelId:X.string().optional(),status:X.nativeEnum(Kr).optional(),category:X.nativeEnum(kv).optional(),verified:X.boolean().optional()});class a4{channels=new Map;async createChannel(r){this.validateKakaoChannelRequest(r);let v=this.generateChannelId(),c={id:v,name:r.name,provider:r.provider,type:r.type,status:"PENDING",profileKey:r.profileKey,senderNumbers:[],metadata:{businessInfo:r.businessInfo,kakaoInfo:r.kakaoInfo,limits:{dailyMessageLimit:1e4,monthlyMessageLimit:300000,rateLimit:10},features:{supportsBulkSending:!0,supportsScheduling:!0,supportsButtons:!0,maxButtonCount:5}},verification:{status:r.businessInfo?"PENDING":"NOT_REQUIRED",documents:[]},createdAt:new Date,updatedAt:new Date};if(this.channels.set(v,c),r.businessInfo)await this.initiateBusinessVerification(c);return c}validateKakaoChannelRequest(r){if(r.type!=="KAKAO_ALIMTALK"&&r.type!=="KAKAO_FRIENDTALK")throw Error("Invalid channel type for Kakao channel");if(!r.kakaoInfo?.plusFriendId)throw Error("Plus Friend ID is required for Kakao channels");if(!r.kakaoInfo?.brandName)throw Error("Brand name is required for Kakao channels");if(!this.isValidPlusFriendId(r.kakaoInfo.plusFriendId))throw Error("Invalid Plus Friend ID format")}isValidPlusFriendId(r){return/^@[a-zA-Z0-9_-]{3,30}$/.test(r)}async initiateBusinessVerification(r){r.verification.status="UNDER_REVIEW",r.status="VERIFYING",r.updatedAt=new Date,setTimeout(()=>{this.completeVerification(r.id,!0)},5000)}async completeVerification(r,v,c){let g=this.channels.get(r);if(!g)throw Error("Channel not found");if(v)g.verification.status="VERIFIED",g.verification.verifiedAt=new Date,g.status="ACTIVE";else g.verification.status="REJECTED",g.verification.rejectedAt=new Date,g.verification.rejectionReason=c||"Verification failed",g.status="SUSPENDED";g.updatedAt=new Date}async getChannel(r){return this.channels.get(r)||null}async updateChannel(r,v){let c=this.channels.get(r);if(!c)throw Error("Channel not found");if(v.metadata?.kakaoInfo?.plusFriendId&&!this.isValidPlusFriendId(v.metadata.kakaoInfo.plusFriendId))throw Error("Invalid Plus Friend ID format");return Object.assign(c,v,{updatedAt:new Date}),c}async deleteChannel(r){let v=this.channels.get(r);if(!v)return!1;return v.status="DELETED",v.updatedAt=new Date,!0}async listChannels(r){let v=Array.from(this.channels.values());if(r){if(r.status)v=v.filter((c)=>c.status===r.status);if(r.type)v=v.filter((c)=>c.type===r.type);if(r.verified!==void 0){let c=r.verified?"VERIFIED":"PENDING";v=v.filter((g)=>g.verification.status===c)}}return v.filter((c)=>c.status!=="DELETED")}async suspendChannel(r,v){let c=this.channels.get(r);if(!c)throw Error("Channel not found");c.status="SUSPENDED",c.updatedAt=new Date,console.log(`Channel ${r} suspended: ${v}`)}async reactivateChannel(r){let v=this.channels.get(r);if(!v)throw Error("Channel not found");if(v.verification.status!=="VERIFIED")throw Error("Channel must be verified before reactivation");v.status="ACTIVE",v.updatedAt=new Date}async checkChannelHealth(r){let v=this.channels.get(r);if(!v)throw Error("Channel not found");let c=[],g=[];if(v.status!=="ACTIVE")c.push(`Channel status is ${v.status}`);if(v.verification.status!=="VERIFIED"&&v.verification.status!=="NOT_REQUIRED")c.push(`Channel verification is ${v.verification.status}`);if(v.senderNumbers.length===0)g.push("Add at least one verified sender number");if(!v.metadata.businessInfo)g.push("Complete business information for better deliverability");return{isHealthy:c.length===0,issues:c,recommendations:g}}generateChannelId(){return`kakao_${Date.now()}_${Math.random().toString(36).substr(2,9)}`}}class e4{senderNumbers=new Map;verificationCodes=new Map;async addSenderNumber(r,v){if(this.validatePhoneNumber(v.phoneNumber),this.findSenderNumberByPhone(v.phoneNumber))throw Error("Phone number is already registered");let g=this.generateSenderNumberId(),$={id:g,phoneNumber:v.phoneNumber,status:"PENDING",category:v.category,metadata:{businessName:v.businessInfo?.businessName,businessRegistrationNumber:v.businessInfo?.businessRegistrationNumber,contactPerson:v.businessInfo?.contactPerson,contactEmail:v.businessInfo?.contactEmail},createdAt:new Date,updatedAt:new Date};return this.senderNumbers.set(g,$),await this.initiateVerification($),$}validatePhoneNumber(r){if(!/^(010|011|016|017|018|019)[0-9]{7,8}$/.test(r))throw Error("Invalid Korean phone number format")}findSenderNumberByPhone(r){return Array.from(this.senderNumbers.values()).find((v)=>v.phoneNumber===r)}async initiateVerification(r){let v=this.generateVerificationCode(),c=new Date(Date.now()+300000);this.verificationCodes.set(r.id,{code:v,expiresAt:c}),r.status="VERIFYING",r.verificationCode=v,r.updatedAt=new Date,console.log(`Verification code for ${r.phoneNumber}: ${v}`),await this.sendVerificationSMS(r.phoneNumber,v)}async sendVerificationSMS(r,v){console.log(`Sending SMS to ${r}: Your verification code is ${v}`)}async verifySenderNumber(r,v){let c=this.senderNumbers.get(r);if(!c)throw Error("Sender number not found");let g=this.verificationCodes.get(r);if(!g)throw Error("No verification code found");if(new Date>g.expiresAt)throw Error("Verification code has expired");if(g.code!==v)return!1;return c.status="VERIFIED",c.verifiedAt=new Date,c.updatedAt=new Date,delete c.verificationCode,this.verificationCodes.delete(r),!0}async resendVerificationCode(r){let v=this.senderNumbers.get(r);if(!v)throw Error("Sender number not found");if(v.status!=="VERIFYING")throw Error("Sender number is not in verifying status");let c=this.verificationCodes.get(r);if(c){if(Date.now()-(c.expiresAt.getTime()-300000)<60000)throw Error("Please wait before requesting a new verification code")}await this.initiateVerification(v)}async getSenderNumber(r){return this.senderNumbers.get(r)||null}async listSenderNumbers(r){let v=Array.from(this.senderNumbers.values());if(r){if(r.status)v=v.filter((c)=>c.status===r.status);if(r.category)v=v.filter((c)=>c.category===r.category);if(r.verified!==void 0)if(r.verified)v=v.filter((c)=>c.status==="VERIFIED");else v=v.filter((c)=>c.status!=="VERIFIED")}return v}async updateSenderNumber(r,v){let c=this.senderNumbers.get(r);if(!c)throw Error("Sender number not found");let g={...v};return delete g.id,delete g.phoneNumber,delete g.verifiedAt,delete g.createdAt,Object.assign(c,g,{updatedAt:new Date}),c}async deleteSenderNumber(r){if(!this.senderNumbers.get(r))return!1;if(await this.isSenderNumberInUse(r))throw Error("Cannot delete sender number that is currently in use");return this.senderNumbers.delete(r),this.verificationCodes.delete(r),!0}async isSenderNumberInUse(r){return!1}async blockSenderNumber(r,v){let c=this.senderNumbers.get(r);if(!c)throw Error("Sender number not found");c.status="BLOCKED",c.updatedAt=new Date,console.log(`Sender number ${r} blocked: ${v}`)}async unblockSenderNumber(r){let v=this.senderNumbers.get(r);if(!v)throw Error("Sender number not found");if(v.status!=="BLOCKED")throw Error("Sender number is not blocked");v.status=v.verifiedAt?"VERIFIED":"PENDING",v.updatedAt=new Date}async validateSenderNumberForSending(r){let v=this.senderNumbers.get(r),c=[];if(!v)return c.push("Sender number not found"),{isValid:!1,errors:c};if(v.status!=="VERIFIED")c.push(`Sender number status is ${v.status}, must be verified`);if(!v.verifiedAt)c.push("Sender number has not been verified");if(v.verifiedAt){let g=new Date(Date.now()-31536000000);if(v.verifiedAt<g)c.push("Sender number verification has expired")}return{isValid:c.length===0,errors:c}}generateSenderNumberId(){return`sn_${Date.now()}_${Math.random().toString(36).substr(2,9)}`}generateVerificationCode(){return Math.floor(1e5+Math.random()*900000).toString()}cleanup(){let r=new Date;for(let[v,c]of this.verificationCodes)if(r>c.expiresAt){this.verificationCodes.delete(v);let g=this.senderNumbers.get(v);if(g&&g.status==="VERIFYING")g.status="PENDING",delete g.verificationCode,g.updatedAt=new Date}}}var r6=Symbol.for,wr=Symbol("kCapture"),uU=r6("events.errorMonitor"),pj=Symbol("events.maxEventTargetListeners"),dj=Symbol("events.maxEventTargetListenersWarned"),LU=r6("nodejs.rejection"),aj=r6("nodejs.rejection"),QU=Array.prototype.slice,jr=10,V=function(r){if(this._events===void 0||this._events===this.__proto__._events)this._events={__proto__:null},this._eventsCount=0;if(this._maxListeners??=void 0,this[wr]=r?.captureRejections?Boolean(r?.captureRejections):N[wr])this.emit=$O},N=V.prototype={};N._events=void 0;N._eventsCount=0;N._maxListeners=void 0;N.setMaxListeners=function(r){return $6(r,"setMaxListeners",0),this._maxListeners=r,this};N.constructor=V;N.getMaxListeners=function(){return this?._maxListeners??jr};function HU(r,v){var{_events:c}=r;if(v[0]??=Error("Unhandled error."),!c)throw v[0];var g=c[uU];if(g)for(var $ of QU.call(g))$.apply(r,v);var o=c.error;if(!o)throw v[0];for(var $ of QU.call(o))$.apply(r,v);return!0}function ej(r,v,c,g){v.then(void 0,function($){queueMicrotask(()=>sj(r,$,c,g))})}function sj(r,v,c,g){if(typeof r[LU]==="function")r[LU](v,c,...g);else try{r[wr]=!1,r.emit("error",v)}finally{r[wr]=!0}}var rO=function(r,...v){if(r==="error")return HU(this,v);var{_events:c}=this;if(c===void 0)return!1;var g=c[r];if(g===void 0)return!1;let $=g.length>1?g.slice():g;for(let o=0,{length:U}=$;o<U;o++){let _=$[o];switch(v.length){case 0:_.call(this);break;case 1:_.call(this,v[0]);break;case 2:_.call(this,v[0],v[1]);break;case 3:_.call(this,v[0],v[1],v[2]);break;default:_.apply(this,v);break}}return!0},$O=function(r,...v){if(r==="error")return HU(this,v);var{_events:c}=this;if(c===void 0)return!1;var g=c[r];if(g===void 0)return!1;let $=g.length>1?g.slice():g;for(let o=0,{length:U}=$;o<U;o++){let _=$[o],j;switch(v.length){case 0:j=_.call(this);break;case 1:j=_.call(this,v[0]);break;case 2:j=_.call(this,v[0],v[1]);break;case 3:j=_.call(this,v[0],v[1],v[2]);break;default:j=_.apply(this,v);break}if(j!==void 0&&typeof j?.then==="function"&&j.then===Promise.prototype.then)ej(this,j,r,v)}return!0};N.emit=rO;N.addListener=function(r,v){n$(v);var c=this._events;if(!c)c=this._events={__proto__:null},this._eventsCount=0;else if(c.newListener)this.emit("newListener",r,v.listener??v);var g=c[r];if(!g)c[r]=[v],this._eventsCount++;else{g.push(v);var $=this._maxListeners??jr;if($>0&&g.length>$&&!g.warned)NU(this,r,g)}return this};N.on=N.addListener;N.prependListener=function(r,v){n$(v);var c=this._events;if(!c)c=this._events={__proto__:null},this._eventsCount=0;else if(c.newListener)this.emit("newListener",r,v.listener??v);var g=c[r];if(!g)c[r]=[v],this._eventsCount++;else{g.unshift(v);var $=this._maxListeners??jr;if($>0&&g.length>$&&!g.warned)NU(this,r,g)}return this};function NU(r,v,c){c.warned=!0;let g=Error(`Possible EventEmitter memory leak detected. ${c.length} ${String(v)} listeners added to [${r.constructor.name}]. Use emitter.setMaxListeners() to increase limit`);g.name="MaxListenersExceededWarning",g.emitter=r,g.type=v,g.count=c.length,console.warn(g)}function BU(r,v,...c){this.removeListener(r,v),v.apply(this,c)}N.once=function(r,v){n$(v);let c=BU.bind(this,r,v);return c.listener=v,this.addListener(r,c),this};N.prependOnceListener=function(r,v){n$(v);let c=BU.bind(this,r,v);return c.listener=v,this.prependListener(r,c),this};N.removeListener=function(r,v){n$(v);var{_events:c}=this;if(!c)return this;var g=c[r];if(!g)return this;var $=g.length;let o=-1;for(let U=$-1;U>=0;U--)if(g[U]===v||g[U].listener===v){o=U;break}if(o<0)return this;if(o===0)g.shift();else g.splice(o,1);if(g.length===0)delete c[r],this._eventsCount--;return this};N.off=N.removeListener;N.removeAllListeners=function(r){var{_events:v}=this;if(r&&v){if(v[r])delete v[r],this._eventsCount--}else this._events={__proto__:null};return this};N.listeners=function(r){var{_events:v}=this;if(!v)return[];var c=v[r];if(!c)return[];return c.map((g)=>g.listener??g)};N.rawListeners=function(r){var{_events:v}=this;if(!v)return[];var c=v[r];if(!c)return[];return c.slice()};N.listenerCount=function(r){var{_events:v}=this;if(!v)return 0;return v[r]?.length??0};N.eventNames=function(){return this._eventsCount>0?Reflect.ownKeys(this._events):[]};N[wr]=!1;function vO(r,v,c){var g=c?.signal;if(MU(g,"options.signal"),g?.aborted)throw new s4(void 0,{cause:g?.reason});let{resolve:$,reject:o,promise:U}=$newPromiseCapability(Promise),_=(k)=>{if(r.removeListener(v,j),g!=null)iv(g,"abort",n);o(k)},j=(...k)=>{if(typeof r.removeListener==="function")r.removeListener("error",_);if(g!=null)iv(g,"abort",n);$(k)};if(YU(r,v,j,{once:!0}),v!=="error"&&typeof r.once==="function")r.once("error",_);function n(){iv(r,v,j),iv(r,"error",_),o(new s4(void 0,{cause:g?.reason}))}if(g!=null)YU(g,"abort",n,{once:!0});return U}function cO(r,v){return r.listeners(v)}function oO(r,...v){$6(r,"setMaxListeners",0);var c;if(v&&(c=v.length))for(let g=0;g<c;g++)v[g].setMaxListeners(r);else jr=r}function gO(r,v){return r.listenerCount(v)}function iv(r,v,c,g){if(typeof r.removeListener==="function")r.removeListener(v,c);else r.removeEventListener(v,c,g)}function YU(r,v,c,g){if(typeof r.on==="function")if(g.once)r.once(v,c);else r.on(v,c);else r.addEventListener(v,c,g)}class s4 extends Error{constructor(r="The operation was aborted",v=void 0){if(v!==void 0&&typeof v!=="object")throw Gr("options","Object",v);super(r,v);this.code="ABORT_ERR",this.name="AbortError"}}function Gr(r,v,c){let g=TypeError(`The "${r}" argument must be of type ${v}. Received ${c}`);return g.code="ERR_INVALID_ARG_TYPE",g}function UO(r,v,c){let g=RangeError(`The "${r}" argument is out of range. It must be ${v}. Received ${c}`);return g.code="ERR_OUT_OF_RANGE",g}function MU(r,v){if(r!==void 0&&(r===null||typeof r!=="object"||!("aborted"in r)))throw Gr(v,"AbortSignal",r)}function $6(r,v,c,g){if(typeof r!=="number")throw Gr(v,"number",r);if(c!=null&&r<c||g!=null&&r>g||(c!=null||g!=null)&&Number.isNaN(r))throw UO(v,`${c!=null?`>= ${c}`:""}${c!=null&&g!=null?" && ":""}${g!=null?`<= ${g}`:""}`,r)}function n$(r){if(typeof r!=="function")throw TypeError("The listener must be a function")}function _O(r,v){if(typeof r!=="boolean")throw Gr(v,"boolean",r)}function wO(r){return r?._maxListeners??jr}function jO(r,v){if(r===void 0)throw Gr("signal","AbortSignal",r);if(MU(r,"signal"),typeof v!=="function")throw Gr("listener","function",v);let c;if(r.aborted)queueMicrotask(()=>v());else r.addEventListener("abort",v,{__proto__:null,once:!0}),c=()=>{r.removeEventListener("abort",v)};return{__proto__:null,[Symbol.dispose](){c?.()}}}Object.defineProperties(V,{captureRejections:{get(){return N[wr]},set(r){_O(r,"EventEmitter.captureRejections"),N[wr]=r},enumerable:!0},defaultMaxListeners:{enumerable:!0,get:()=>{return jr},set:(r)=>{$6(r,"defaultMaxListeners",0),jr=r}},kMaxEventTargetListeners:{value:pj,enumerable:!1,configurable:!1,writable:!1},kMaxEventTargetListenersWarned:{value:dj,enumerable:!1,configurable:!1,writable:!1}});Object.assign(V,{once:vO,getEventListeners:cO,getMaxListeners:wO,setMaxListeners:oO,EventEmitter:V,usingDomains:!1,captureRejectionSymbol:aj,errorMonitor:uU,addAbortListener:jO,init:V,listenerCount:gO});class v6 extends V{options;channels=new Map;senderNumbers=new Map;auditLogs=[];cleanupTimer;defaultOptions={enableAuditLog:!0,enableEventEmission:!0,defaultPageSize:20,maxPageSize:100,enableSoftDelete:!0,autoCleanup:!0,cleanupInterval:3600000};constructor(r={}){super();this.options=r;if(this.options={...this.defaultOptions,...r},this.options.autoCleanup)this.startAutoCleanup()}async createChannel(r,v){let c=this.generateChannelId(),g={id:c,name:r.name,provider:r.provider,type:r.type,status:"PENDING",profileKey:r.profileKey,senderNumbers:[],metadata:{businessInfo:r.businessInfo,kakaoInfo:r.kakaoInfo,limits:this.getDefaultLimits(r.type),features:this.getDefaultFeatures(r.type)},verification:{status:r.businessInfo?"PENDING":"NOT_REQUIRED",documents:[]},createdAt:new Date,updatedAt:new Date};if(this.channels.set(c,g),this.options.enableAuditLog)this.addAuditLog("channel",c,"create",v,void 0,g);if(this.options.enableEventEmission)this.emit("channel:created",{channel:g,userId:v});return g}async getChannel(r,v){let c=this.channels.get(r);if(c&&this.options.enableAuditLog)this.addAuditLog("channel",r,"read",v);return c||null}async updateChannel(r,v,c){let g=this.channels.get(r);if(!g)throw Error(`Channel ${r} not found`);let $=this.options.enableAuditLog?{...g}:void 0,o={...g,...v,id:r,updatedAt:new Date};if(this.channels.set(r,o),this.options.enableAuditLog)this.addAuditLog("channel",r,"update",c,$,o);if(this.options.enableEventEmission)this.emit("channel:updated",{channel:o,previousChannel:g,userId:c});return o}async deleteChannel(r,v){let c=this.channels.get(r);if(!c)return!1;if(this.options.enableSoftDelete)c.status="DELETED",c.updatedAt=new Date;else{this.channels.delete(r);for(let[g,$]of this.senderNumbers);}if(this.options.enableAuditLog)this.addAuditLog("channel",r,"delete",v,c);if(this.options.enableEventEmission)this.emit("channel:deleted",{channel:c,userId:v});return!0}async listChannels(r={},v={page:1,limit:this.options.defaultPageSize}){let c=Array.from(this.channels.values());if(r.provider)c=c.filter((k)=>k.provider===r.provider);if(r.type)c=c.filter((k)=>k.type===r.type);if(r.status)c=c.filter((k)=>k.status===r.status);if(r.verified!==void 0){let k=r.verified?"VERIFIED":"PENDING";c=c.filter((P)=>P.verification.status===k)}if(r.createdAfter)c=c.filter((k)=>k.createdAt>=r.createdAfter);if(r.createdBefore)c=c.filter((k)=>k.createdAt<=r.createdBefore);if(!r.status||r.status!=="DELETED")c=c.filter((k)=>k.status!=="DELETED");let g=v.sortBy||"createdAt",$=v.sortOrder||"desc";c.sort((k,P)=>{let b,O;switch(g){case"name":b=k.name,O=P.name;break;case"createdAt":b=k.createdAt.getTime(),O=P.createdAt.getTime();break;case"updatedAt":b=k.updatedAt.getTime(),O=P.updatedAt.getTime();break;default:b=k.createdAt.getTime(),O=P.createdAt.getTime()}if($==="asc")return b<O?-1:b>O?1:0;else return b>O?-1:b<O?1:0});let o=c.length,U=Math.min(v.limit,this.options.maxPageSize),_=Math.max(1,v.page),j=(_-1)*U;return{data:c.slice(j,j+U),total:o,page:_,limit:U,totalPages:Math.ceil(o/U),hasNext:j+U<o,hasPrev:_>1}}async createSenderNumber(r,v,c){let g=this.channels.get(r);if(!g)throw Error(`Channel ${r} not found`);let $=this.generateSenderNumberId(),o={id:$,phoneNumber:v.phoneNumber,status:"PENDING",category:v.category,metadata:{businessName:v.businessInfo?.businessName,businessRegistrationNumber:v.businessInfo?.businessRegistrationNumber,contactPerson:v.businessInfo?.contactPerson,contactEmail:v.businessInfo?.contactEmail},createdAt:new Date,updatedAt:new Date};if(this.senderNumbers.set($,o),g.senderNumbers.push(o),g.updatedAt=new Date,this.options.enableAuditLog)this.addAuditLog("senderNumber",$,"create",c,void 0,o);if(this.options.enableEventEmission)this.emit("senderNumber:created",{senderNumber:o,channelId:r,userId:c});return o}async getSenderNumber(r,v){let c=this.senderNumbers.get(r);if(c&&this.options.enableAuditLog)this.addAuditLog("senderNumber",r,"read",v);return c||null}async updateSenderNumber(r,v,c){let g=this.senderNumbers.get(r);if(!g)throw Error(`Sender number ${r} not found`);let $=this.options.enableAuditLog?{...g}:void 0,o={...g,...v,id:r,updatedAt:new Date};this.senderNumbers.set(r,o);for(let U of this.channels.values()){let _=U.senderNumbers.findIndex((j)=>j.id===r);if(_!==-1){U.senderNumbers[_]=o,U.updatedAt=new Date;break}}if(this.options.enableAuditLog)this.addAuditLog("senderNumber",r,"update",c,$,o);if(this.options.enableEventEmission)this.emit("senderNumber:updated",{senderNumber:o,previousSenderNumber:g,userId:c});return o}async deleteSenderNumber(r,v){let c=this.senderNumbers.get(r);if(!c)return!1;this.senderNumbers.delete(r);for(let g of this.channels.values()){let $=g.senderNumbers.findIndex((o)=>o.id===r);if($!==-1){g.senderNumbers.splice($,1),g.updatedAt=new Date;break}}if(this.options.enableAuditLog)this.addAuditLog("senderNumber",r,"delete",v,c);if(this.options.enableEventEmission)this.emit("senderNumber:deleted",{senderNumber:c,userId:v});return!0}async listSenderNumbers(r={},v={page:1,limit:this.options.defaultPageSize}){let c=Array.from(this.senderNumbers.values());if(r.channelId){let k=this.channels.get(r.channelId);if(k)c=k.senderNumbers;else c=[]}if(r.status)c=c.filter((k)=>k.status===r.status);if(r.category)c=c.filter((k)=>k.category===r.category);if(r.verified!==void 0)if(r.verified)c=c.filter((k)=>k.status==="VERIFIED");else c=c.filter((k)=>k.status!=="VERIFIED");let g=v.sortBy||"createdAt",$=v.sortOrder||"desc";c.sort((k,P)=>{let b,O;switch(g){case"phoneNumber":b=k.phoneNumber,O=P.phoneNumber;break;case"createdAt":b=k.createdAt.getTime(),O=P.createdAt.getTime();break;case"updatedAt":b=k.updatedAt.getTime(),O=P.updatedAt.getTime();break;default:b=k.createdAt.getTime(),O=P.createdAt.getTime()}if($==="asc")return b<O?-1:b>O?1:0;else return b>O?-1:b<O?1:0});let o=c.length,U=Math.min(v.limit,this.options.maxPageSize),_=Math.max(1,v.page),j=(_-1)*U;return{data:c.slice(j,j+U),total:o,page:_,limit:U,totalPages:Math.ceil(o/U),hasNext:j+U<o,hasPrev:_>1}}getAuditLogs(r,v,c=100){let g=[...this.auditLogs];if(r)g=g.filter(($)=>$.entityType===r);if(v)g=g.filter(($)=>$.entityId===v);return g.sort(($,o)=>o.timestamp.getTime()-$.timestamp.getTime()).slice(0,c)}getStatistics(){let r=Array.from(this.channels.values()),v=Array.from(this.senderNumbers.values()),c={},g={},$={};r.forEach((_)=>{c[_.status]=(c[_.status]||0)+1,g[_.type]=(g[_.type]||0)+1,$[_.provider]=($[_.provider]||0)+1});let o={},U={};return v.forEach((_)=>{o[_.status]=(o[_.status]||0)+1,U[_.category]=(U[_.category]||0)+1}),{channels:{total:r.length,byStatus:c,byType:g,byProvider:$},senderNumbers:{total:v.length,byStatus:o,byCategory:U}}}cleanup(){let r=0,v=0,c=new Date(Date.now()-2592000000);for(let[o,U]of this.channels)if(U.status==="DELETED"&&U.updatedAt<c)this.channels.delete(o),r++;let g=new Date(Date.now()-7776000000),$=this.auditLogs.length;return this.auditLogs=this.auditLogs.filter((o)=>o.timestamp>=g),v=$-this.auditLogs.length,{deletedChannels:r,expiredAuditLogs:v}}destroy(){if(this.cleanupTimer)clearInterval(this.cleanupTimer),this.cleanupTimer=void 0;this.removeAllListeners(),this.channels.clear(),this.senderNumbers.clear(),this.auditLogs=[]}addAuditLog(r,v,c,g,$,o){let U={id:this.generateAuditLogId(),entityType:r,entityId:v,action:c,userId:g,timestamp:new Date,changes:$||o?{before:$,after:o}:void 0};if(this.auditLogs.push(U),this.auditLogs.length>1e4)this.auditLogs=this.auditLogs.slice(-1e4)}getDefaultLimits(r){switch(r){case"KAKAO_ALIMTALK":return{dailyMessageLimit:1e4,monthlyMessageLimit:300000,rateLimit:10};case"KAKAO_FRIENDTALK":return{dailyMessageLimit:1000,monthlyMessageLimit:30000,rateLimit:5};case"SMS":case"LMS":case"MMS":return{dailyMessageLimit:1000,monthlyMessageLimit:30000,rateLimit:3};default:return{dailyMessageLimit:1000,monthlyMessageLimit:30000,rateLimit:1}}}getDefaultFeatures(r){switch(r){case"KAKAO_ALIMTALK":return{supportsBulkSending:!0,supportsScheduling:!0,supportsButtons:!0,maxButtonCount:5};case"KAKAO_FRIENDTALK":return{supportsBulkSending:!0,supportsScheduling:!0,supportsButtons:!1,maxButtonCount:0};default:return{supportsBulkSending:!1,supportsScheduling:!1,supportsButtons:!1,maxButtonCount:0}}}startAutoCleanup(){this.cleanupTimer=setInterval(()=>{this.cleanup()},this.options.cleanupInterval)}generateChannelId(){return`ch_${Date.now()}_${Math.random().toString(36).substr(2,9)}`}generateSenderNumberId(){return`sn_${Date.now()}_${Math.random().toString(36).substr(2,9)}`}generateAuditLogId(){return`audit_${Date.now()}_${Math.random().toString(36).substr(2,9)}`}}var zv;((j)=>{j.CHANNEL="channel";j.SENDER_NUMBER="senderNumber";j.TEMPLATE="template";j.MESSAGE="message";j.USER="user";j.ROLE="role";j.AUDIT_LOG="auditLog";j.ANALYTICS="analytics"})(zv||={});var bv;((n)=>{n.CREATE="create";n.READ="read";n.UPDATE="update";n.DELETE="delete";n.VERIFY="verify";n.SUSPEND="suspend";n.ACTIVATE="activate";n.SEND="send";n.MANAGE="manage"})(bv||={});var c6;(($)=>{$.GLOBAL="global";$.ORGANIZATION="organization";$.TEAM="team";$.PERSONAL="personal"})(c6||={});class o6 extends V{users=new Map;roles=new Map;userRoleCache=new Map;permissionCache=new Map;cacheExpiry=new Map;CACHE_DURATION=300000;constructor(){super();this.initializeSystemRoles()}async createUser(r){let v=this.generateUserId(),c={...r,id:v,createdAt:new Date,updatedAt:new Date};return this.users.set(v,c),this.updateUserRoleCache(v,c.roles.map((g)=>g.id)),this.emit("user:created",{user:c}),c}async getUser(r){return this.users.get(r)||null}async updateUser(r,v){let c=this.users.get(r);if(!c)throw Error("User not found");let g={...c,...v,id:r,updatedAt:new Date};if(this.users.set(r,g),v.roles)this.updateUserRoleCache(r,v.roles.map(($)=>$.id));return this.clearUserPermissionCache(r),this.emit("user:updated",{user:g,previousUser:c}),g}async deleteUser(r){let v=this.users.get(r);if(!v)return!1;return this.users.delete(r),this.userRoleCache.delete(r),this.clearUserPermissionCache(r),this.emit("user:deleted",{user:v}),!0}async createRole(r){let v=this.generateRoleId(),c={...r,id:v,createdAt:new Date,updatedAt:new Date};return this.roles.set(v,c),this.emit("role:created",{role:c}),c}async getRole(r){return this.roles.get(r)||null}async updateRole(r,v){let c=this.roles.get(r);if(!c)throw Error("Role not found");if(c.isSystem&&v.permissions)throw Error("Cannot modify permissions of system roles");let g={...c,...v,id:r,updatedAt:new Date};return this.roles.set(r,g),this.clearRolePermissionCache(r),this.emit("role:updated",{role:g,previousRole:c}),g}async deleteRole(r){let v=this.roles.get(r);if(!v)return!1;if(v.isSystem)throw Error("Cannot delete system roles");if(Array.from(this.users.values()).filter((g)=>g.roles.some(($)=>$.id===r)).length>0)throw Error("Cannot delete role that is assigned to users");return this.roles.delete(r),this.emit("role:deleted",{role:v}),!0}async assignRoleToUser(r,v){let c=this.users.get(r),g=this.roles.get(v);if(!c)throw Error("User not found");if(!g)throw Error("Role not found");if(c.roles.some(($)=>$.id===v))return;c.roles.push(g),c.updatedAt=new Date,this.updateUserRoleCache(r,c.roles.map(($)=>$.id)),this.clearUserPermissionCache(r),this.emit("role:assigned",{userId:r,roleId:v})}async removeRoleFromUser(r,v){let c=this.users.get(r);if(!c)throw Error("User not found");let g=c.roles.findIndex(($)=>$.id===v);if(g===-1)return;c.roles.splice(g,1),c.updatedAt=new Date,this.updateUserRoleCache(r,c.roles.map(($)=>$.id)),this.clearUserPermissionCache(r),this.emit("role:removed",{userId:r,roleId:v})}async checkPermission(r){let v=this.getCacheKey(r),c=this.getFromCache(v);if(c)return c;let g=await this.performPermissionCheck(r);return this.setCache(v,g),g}async hasPermission(r,v,c,g,$){return(await this.checkPermission({userId:r,resource:v,action:c,resourceId:g,context:$})).granted}async requirePermission(r,v,c,g,$){if(!await this.hasPermission(r,v,c,g,$))throw Error(`Access denied: ${c} on ${v}`)}async getUserPermissions(r){let v=this.users.get(r);if(!v)return[];let c=[];for(let $ of v.roles)c.push(...$.permissions);return c.filter(($,o,U)=>o===U.findIndex((_)=>_.id===$.id))}async getUserRoles(r){let v=this.users.get(r);return v?v.roles:[]}listUsers(r){let v=Array.from(this.users.values());if(r?.isActive!==void 0)v=v.filter((c)=>c.isActive===r.isActive);if(r?.roleId)v=v.filter((c)=>c.roles.some((g)=>g.id===r.roleId));return v}listRoles(){return Array.from(this.roles.values())}async performPermissionCheck(r){let v=this.users.get(r.userId);if(!v)return{granted:!1,reason:"User not found",matchedPermissions:[],deniedReasons:["User not found"]};if(!v.isActive)return{granted:!1,reason:"User is inactive",matchedPermissions:[],deniedReasons:["User is inactive"]};let c=[],g=[];for(let o of v.roles)for(let U of o.permissions)if(this.doesPermissionMatch(U,r))if(await this.checkConditions(U,r))c.push(U);else g.push(`Conditions not met for permission ${U.id}`);let $=c.length>0;return{granted:$,reason:$?void 0:"No matching permissions found",matchedPermissions:c,deniedReasons:$?[]:g}}doesPermissionMatch(r,v){return r.resource===v.resource&&r.action===v.action}async checkConditions(r,v){if(!r.conditions||r.conditions.length===0)return!0;for(let c of r.conditions)if(!await this.evaluateCondition(c,v))return!1;return!0}async evaluateCondition(r,v){let c;switch(r.field){case"userId":c=v.userId;break;case"organizationId":c=v.context?.organizationId;break;case"teamId":c=v.context?.teamId;break;case"resourceOwnerId":c=v.context?.resourceOwnerId;break;default:c=v.context?.metadata?.[r.field]}switch(r.operator){case"equals":return c===r.value;case"not_equals":return c!==r.value;case"in":return Array.isArray(r.value)&&r.value.includes(c);case"not_in":return Array.isArray(r.value)&&!r.value.includes(c);case"contains":return String(c).includes(String(r.value));case"starts_with":return String(c).startsWith(String(r.value));default:return!1}}initializeSystemRoles(){let r={id:"super-admin",name:"Super Admin",description:"Full system access",isSystem:!0,permissions:[...Object.values(zv).flatMap(($)=>Object.values(bv).map((o)=>({id:`super-admin-${$}-${o}`,resource:$,action:o,scope:"global"})))],createdAt:new Date,updatedAt:new Date},v={id:"channel-admin",name:"Channel Admin",description:"Manage channels and sender numbers",isSystem:!0,permissions:[{id:"channel-admin-channel-manage",resource:"channel",action:"manage",scope:"organization"},{id:"channel-admin-sender-manage",resource:"senderNumber",action:"manage",scope:"organization"}],createdAt:new Date,updatedAt:new Date},c={id:"message-sender",name:"Message Sender",description:"Send messages using configured channels",isSystem:!0,permissions:[{id:"message-sender-channel-read",resource:"channel",action:"read",scope:"organization"},{id:"message-sender-message-send",resource:"message",action:"send",scope:"organization"}],createdAt:new Date,updatedAt:new Date},g={id:"viewer",name:"Viewer",description:"Read-only access",isSystem:!0,permissions:[{id:"viewer-channel-read",resource:"channel",action:"read",scope:"organization"},{id:"viewer-sender-read",resource:"senderNumber",action:"read",scope:"organization"},{id:"viewer-analytics-read",resource:"analytics",action:"read",scope:"organization"}],createdAt:new Date,updatedAt:new Date};this.roles.set(r.id,r),this.roles.set(v.id,v),this.roles.set(c.id,c),this.roles.set(g.id,g)}updateUserRoleCache(r,v){this.userRoleCache.set(r,new Set(v))}clearUserPermissionCache(r){let v=[];for(let c of this.permissionCache.keys())if(c.startsWith(`${r}:`))v.push(c);v.forEach((c)=>{this.permissionCache.delete(c),this.cacheExpiry.delete(c)})}clearRolePermissionCache(r){for(let[v,c]of this.userRoleCache)if(c.has(r))this.clearUserPermissionCache(v)}getCacheKey(r){let v=r.context?JSON.stringify(r.context):"";return`${r.userId}:${r.resource}:${r.action}:${r.resourceId||""}:${v}`}getFromCache(r){let v=this.cacheExpiry.get(r);if(!v||v<Date.now())return this.permissionCache.delete(r),this.cacheExpiry.delete(r),null;return this.permissionCache.get(r)||null}setCache(r,v){this.permissionCache.set(r,v),this.cacheExpiry.set(r,Date.now()+this.CACHE_DURATION)}generateUserId(){return`user_${Date.now()}_${Math.random().toString(36).substr(2,9)}`}generateRoleId(){return`role_${Date.now()}_${Math.random().toString(36).substr(2,9)}`}}class g6{channels=new Map;senderNumbers=new Map;async createChannel(r){let v={...r,id:this.generateChannelId(),createdAt:new Date,updatedAt:new Date};return this.channels.set(v.id,v),v}async getChannel(r){return this.channels.get(r)||null}async listChannels(r){let v=Array.from(this.channels.values());if(r)return v.filter((c)=>c.providerId===r);return v}async updateChannel(r,v){let c=this.channels.get(r);if(!c)throw Error(`Channel ${r} not found`);let g={...c,...v,updatedAt:new Date};return this.channels.set(r,g),g}async deleteChannel(r){this.channels.delete(r);for(let[v,c]of this.senderNumbers.entries())if(c.channelId===r)this.senderNumbers.delete(v)}async addSenderNumber(r,v,c){if(!this.channels.get(r))throw Error(`Channel ${r} not found`);let $={phoneNumber:v,name:c,status:"PENDING",channelId:r};return this.senderNumbers.set(v,$),$}async verifySenderNumber(r){let v=this.senderNumbers.get(r);if(!v)return{success:!1,status:"not_found",error:"Sender number not found"};let c=Math.floor(Math.random()*900000)+1e5;return v.verifiedAt=new Date,v.status="VERIFIED",this.senderNumbers.set(r,v),{success:!0,status:"verified",verificationCode:c.toString()}}async getSenderNumbers(r){let v=Array.from(this.senderNumbers.values());if(r)return v.filter((c)=>c.channelId===r);return v}generateChannelId(){return`ch_${Date.now()}_${Math.random().toString(36).substr(2,9)}`}}class U6 extends V{options;verificationRequests=new Map;documentValidators=new Map;defaultOptions={enableAutoVerification:!0,requiredDocuments:["BUSINESS_REGISTRATION"],autoApprovalThreshold:80,requireManualReview:!1,documentRetentionDays:365,enableExternalAPIs:!1};constructor(r={}){super();this.options=r;this.options={...this.defaultOptions,...r},this.initializeDocumentValidators()}async submitVerification(r,v,c){let g=this.generateRequestId();this.validateRequiredDocuments(c);let $={id:g,channelId:r,businessInfo:v,documents:c.map((o)=>({...o,status:"UPLOADED"})),status:"PENDING",submittedAt:new Date};if(this.verificationRequests.set(g,$),this.emit("verification:submitted",{verificationRequest:$}),this.options.enableAutoVerification)await this.processAutoVerification(g);return $}getVerificationRequest(r){return this.verificationRequests.get(r)||null}getVerificationByChannelId(r){for(let v of this.verificationRequests.values())if(v.channelId===r)return v;return null}async approveVerification(r,v,c){let g=this.verificationRequests.get(r);if(!g)throw Error("Verification request not found");return g.status="VERIFIED",g.reviewedAt=new Date,g.reviewedBy=v,g.reviewNotes=c,g.documents.forEach(($)=>{$.status="VERIFIED"}),this.emit("verification:approved",{verificationRequest:g,reviewerId:v}),g}async rejectVerification(r,v,c){let g=this.verificationRequests.get(r);if(!g)throw Error("Verification request not found");return g.status="REJECTED",g.reviewedAt=new Date,g.reviewedBy=v,g.reviewNotes=c,g.documents.forEach(($)=>{if($.status==="UPLOADED")$.status="REJECTED"}),this.emit("verification:rejected",{verificationRequest:g,reviewerId:v,reason:c}),g}async addDocument(r,v){let c=this.verificationRequests.get(r);if(!c)throw Error("Verification request not found");if(c.status!=="PENDING"&&c.status!=="UNDER_REVIEW")throw Error("Cannot add documents to completed verification");if(v.status="UPLOADED",c.documents.push(v),this.options.enableAutoVerification)await this.processAutoVerification(r);return this.emit("verification:document_added",{verificationRequest:c,document:v}),c}listVerificationRequests(r){let v=Array.from(this.verificationRequests.values());if(r?.status)v=v.filter((c)=>c.status===r.status);if(r?.channelId)v=v.filter((c)=>c.channelId===r.channelId);if(r?.submittedAfter)v=v.filter((c)=>c.submittedAt>=r.submittedAfter);if(r?.submittedBefore)v=v.filter((c)=>c.submittedAt<=r.submittedBefore);return v.sort((c,g)=>g.submittedAt.getTime()-c.submittedAt.getTime())}getVerificationStats(){let r=Array.from(this.verificationRequests.values()),v={},c=0,g=0,$=0;return r.forEach((o)=>{if(v[o.status]=(v[o.status]||0)+1,o.reviewedAt){let U=o.reviewedAt.getTime()-o.submittedAt.getTime();if(c+=U,g++,!o.reviewedBy&&o.status==="VERIFIED")$++}}),{total:r.length,byStatus:v,averageProcessingTime:g>0?c/g:0,autoApprovalRate:g>0?$/g*100:0}}async processAutoVerification(r){let v=this.verificationRequests.get(r);if(!v)return;v.status="UNDER_REVIEW",this.emit("verification:auto_processing_started",{verificationRequest:v});let c=[];try{let g=await this.verifyBusinessRegistration(v.businessInfo);c.push(g);for(let _ of v.documents){let j=await this.validateDocument(_);c.push({checkType:"document_validation",status:j.isValid?"passed":"failed",score:j.confidence,details:`Document validation: ${j.issues.length} issues found`,metadata:{documentId:_.id,issues:j.issues}})}let $=await this.verifyAddress(v.businessInfo.address);c.push($);let o=await this.verifyPhoneNumber(v.businessInfo.contactInfo.phoneNumber);c.push(o),v.autoVerificationResults=c;let U=c.reduce((_,j)=>_+j.score,0)/c.length;if(U>=this.options.autoApprovalThreshold&&!this.options.requireManualReview)v.status="VERIFIED",v.reviewedAt=new Date,v.reviewNotes=`Auto-approved with score: ${U.toFixed(1)}`,v.documents.forEach((_)=>{_.status="VERIFIED"}),this.emit("verification:auto_approved",{verificationRequest:v,score:U});else this.emit("verification:manual_review_required",{verificationRequest:v,score:U})}catch(g){v.status="PENDING",this.emit("verification:auto_processing_failed",{verificationRequest:v,error:g instanceof Error?g.message:"Unknown error"})}}validateRequiredDocuments(r){let v=new Set(r.map((g)=>g.type)),c=this.options.requiredDocuments.filter((g)=>!v.has(g));if(c.length>0)throw Error(`Missing required documents: ${c.join(", ")}`)}async verifyBusinessRegistration(r){let v=this.calculateBusinessRegistrationScore(r);return{checkType:"business_registry",status:v>=70?"passed":v>=50?"warning":"failed",score:v,details:"Business registration verification completed",metadata:{businessName:r.businessName,registrationNumber:r.businessRegistrationNumber}}}calculateBusinessRegistrationScore(r){let v=0;if(/^\d{3}-\d{2}-\d{5}$/.test(r.businessRegistrationNumber))v+=30;if(r.businessName.length>=2&&r.businessName.length<=100)v+=20;let c=new Date,g=new Date(r.establishedDate),$=(c.getTime()-g.getTime())/31536000000;if($>=0&&$<=100)v+=20;if(r.contactInfo.email&&r.contactInfo.phoneNumber)v+=15;if(r.address.street&&r.address.city&&r.address.postalCode)v+=15;return Math.min(100,v)}async validateDocument(r){let v=this.documentValidators.get(r.type);if(!v)return{isValid:!1,confidence:0,issues:[{type:"format",severity:"critical",message:`No validator available for document type: ${r.type}`}]};return await v(r)}async verifyAddress(r){let v=0;if(r.street&&r.city&&r.postalCode)v+=40;if(/^\d{5}$/.test(r.postalCode))v+=30;if(r.country==="KR"||r.country==="Korea")v+=30;return{checkType:"address_verification",status:v>=70?"passed":v>=50?"warning":"failed",score:v,details:"Address verification completed",metadata:{address:r}}}async verifyPhoneNumber(r){let v=/^(010|011|016|017|018|019)[0-9]{7,8}$/.test(r);return{checkType:"phone_verification",status:v?"passed":"failed",score:v?100:0,details:v?"Phone number format is valid":"Invalid phone number format",metadata:{phoneNumber:r}}}initializeDocumentValidators(){this.documentValidators.set("BUSINESS_REGISTRATION",async(v)=>{let c=[],g=80;if(!v.fileName.match(/\.(pdf|jpg|jpeg|png)$/i))c.push({type:"format",severity:"medium",message:"Unsupported file format"}),g-=20;return{isValid:c.length===0||c.every(($)=>$.severity!=="critical"),confidence:Math.max(0,g),issues:c}}),this.documentValidators.set("BUSINESS_LICENSE",async(v)=>{let c=[],g=75;if(!v.fileName.match(/\.(pdf|jpg|jpeg|png)$/i))c.push({type:"format",severity:"medium",message:"Unsupported file format"}),g-=15;return{isValid:c.length===0||c.every(($)=>$.severity!=="critical"),confidence:Math.max(0,g),issues:c}}),this.documentValidators.set("ID_CARD",async(v)=>{let c=[],g=70;if(!v.fileName.match(/\.(jpg|jpeg|png)$/i))c.push({type:"format",severity:"high",message:"ID card should be an image file"}),g-=30;return{isValid:c.length===0||c.every(($)=>$.severity!=="critical"),confidence:Math.max(0,g),issues:c}});let r=async(v)=>{let c=[],g=60;if(!v.fileName||v.fileName.length===0)c.push({type:"format",severity:"critical",message:"File name is required"}),g=0;return{isValid:c.length===0||c.every(($)=>$.severity!=="critical"),confidence:Math.max(0,g),issues:c}};this.documentValidators.set("AUTHORIZATION_LETTER",r),this.documentValidators.set("OTHER",r)}generateRequestId(){return`biz_verify_${Date.now()}_${Math.random().toString(36).substr(2,9)}`}}var _6;((g)=>{g.SMS="sms";g.VOICE_CALL="voice_call";g.HYBRID="hybrid"})(_6||={});var w6;((g)=>{g.SMS="sms";g.VOICE_CALL="voice_call";g.MISSED_CALL="missed_call"})(w6||={});class j6 extends V{options;verificationRequests=new Map;phoneNumberCache=new Map;rateLimitTracker=new Map;dailyAttemptTracker=new Map;blockedNumbers=new Set;defaultOptions={codeLength:6,codeExpiryMinutes:5,maxAttempts:3,maxDailyAttempts:10,smsTemplate:"인증번호: {code}. {expiry}분 내에 입력해주세요.",voiceTemplate:"인증번호는 {code}입니다. 다시 한 번, {code}입니다.",rateLimitMinutes:1,enableVoiceFallback:!0,enableMissedCallVerification:!1,blockedNumbers:[],allowedCountries:["KR"]};constructor(r={}){super();this.options=r;this.options={...this.defaultOptions,...r},this.options.blockedNumbers?.forEach((v)=>{this.blockedNumbers.add(v)})}async startVerification(r,v,c="sms",g={}){let $=await this.getPhoneNumberInfo(v);if(!$.isValid)throw Error("Invalid phone number format");if(this.isNumberBlocked(v))throw Error("Phone number is blocked");if(this.isRateLimited(v))throw Error("Rate limit exceeded. Please try again later.");if(this.isDailyLimitExceeded(v))throw Error("Daily verification attempt limit exceeded");let o=this.generateRequestId(),U=this.generateVerificationCode(),_=new Date(Date.now()+this.options.codeExpiryMinutes*60*1000),j={id:o,senderNumberId:r,phoneNumber:v,verificationType:c,verificationCode:U,status:"pending",attempts:[],expiresAt:_,createdAt:new Date,metadata:g};return this.verificationRequests.set(o,j),this.updateRateLimit(v),this.updateDailyAttempts(v),this.emit("verification:started",{verificationRequest:j,phoneInfo:$}),await this.sendVerificationCode(j,$),j}async verifyCode(r,v){let c=this.verificationRequests.get(r);if(!c)return{success:!1,status:"failed",message:"Verification request not found"};if(c.status==="verified")return{success:!0,status:"verified",message:"Already verified"};if(new Date>c.expiresAt)return c.status="expired",this.emit("verification:expired",{verificationRequest:c}),{success:!1,status:"expired",message:"Verification code has expired"};if(c.status==="blocked")return{success:!1,status:"blocked",message:"Verification blocked due to too many failed attempts"};if(this.validateCode(c.verificationCode,v))return c.status="verified",c.completedAt=new Date,this.emit("verification:success",{verificationRequest:c}),{success:!0,status:"verified",message:"Phone number verified successfully"};else{let $={attemptNumber:c.attempts.length+1,attemptedAt:new Date,method:"sms",status:"failed"};c.attempts.push($);let o=c.attempts.filter((U)=>U.status==="failed").length;if(o>=this.options.maxAttempts)return c.status="blocked",this.emit("verification:blocked",{verificationRequest:c}),{success:!1,status:"blocked",message:"Too many failed attempts. Verification blocked."};else return c.status="failed",this.emit("verification:failed_attempt",{verificationRequest:c,attemptsRemaining:this.options.maxAttempts-o}),{success:!1,status:"failed",message:`Invalid code. ${this.options.maxAttempts-o} attempts remaining.`}}}async resendCode(r,v){let c=this.verificationRequests.get(r);if(!c)throw Error("Verification request not found");if(c.status==="verified")throw Error("Verification already completed");if(c.status==="blocked")throw Error("Verification is blocked");if(this.isRateLimited(c.phoneNumber))throw Error("Rate limit exceeded. Please wait before requesting a new code.");c.verificationCode=this.generateVerificationCode(),c.expiresAt=new Date(Date.now()+this.options.codeExpiryMinutes*60*1000),c.status="pending",this.updateRateLimit(c.phoneNumber);let g=await this.getPhoneNumberInfo(c.phoneNumber);if(v)await this.sendVerificationByMethod(c,g,v);else await this.sendVerificationCode(c,g);return this.emit("verification:resent",{verificationRequest:c}),c}getVerificationStatus(r){return this.verificationRequests.get(r)||null}async cancelVerification(r){let v=this.verificationRequests.get(r);if(!v)return!1;if(v.status==="verified")return!1;return this.verificationRequests.delete(r),this.emit("verification:cancelled",{verificationRequest:v}),!0}blockPhoneNumber(r,v){this.blockedNumbers.add(r);for(let[c,g]of this.verificationRequests)if(g.phoneNumber===r&&g.status!=="verified")g.status="blocked";this.emit("phone:blocked",{phoneNumber:r,reason:v})}unblockPhoneNumber(r){this.blockedNumbers.delete(r),this.emit("phone:unblocked",{phoneNumber:r})}getVerificationStats(){let r=Array.from(this.verificationRequests.values()),v={},c={},g=0,$=0;r.forEach((_)=>{if(v[_.status]=(v[_.status]||0)+1,_.attempts.length>0){let j=_.attempts[0].method;c[j]=(c[j]||0)+1}if(_.completedAt){let j=_.completedAt.getTime()-_.createdAt.getTime();g+=j,$++}});let o=v.verified||0,U=r.length>0?o/r.length*100:0;return{total:r.length,byStatus:v,byMethod:c,successRate:U,averageCompletionTime:$>0?g/$:0}}cleanup(){let r=new Date,v=0;for(let[g,$]of this.verificationRequests)if(r>$.expiresAt&&$.status!=="verified")$.status="expired",this.verificationRequests.delete(g),v++;let c=this.options.rateLimitMinutes*60*1000;for(let[g,$]of this.rateLimitTracker){let o=$.filter((U)=>r.getTime()-U.getTime()<c);if(o.length===0)this.rateLimitTracker.delete(g);else this.rateLimitTracker.set(g,o)}return v}async sendVerificationCode(r,v){let c;switch(r.verificationType){case"sms":c="sms";break;case"voice_call":c="voice_call";break;case"hybrid":c=v.lineType==="landline"?"voice_call":"sms";break;default:c="sms"}await this.sendVerificationByMethod(r,v,c)}async sendVerificationByMethod(r,v,c){let g={attemptNumber:r.attempts.length+1,attemptedAt:new Date,method:c,status:"sent"},$=Date.now();try{switch(c){case"sms":await this.sendSMS(r,v);break;case"voice_call":await this.sendVoiceCall(r,v);break;case"missed_call":await this.sendMissedCall(r,v);break}g.status="delivered",g.responseTime=Date.now()-$,r.status="code_sent"}catch(o){if(g.status="failed",g.failureReason=o instanceof Error?o.message:"Unknown error",g.responseTime=Date.now()-$,c==="sms"&&this.options.enableVoiceFallback&&r.attempts.filter((U)=>U.method==="voice_call").length===0){g.status="failed",r.attempts.push(g),await this.sendVerificationByMethod(r,v,"voice_call");return}throw r.status="failed",o}r.attempts.push(g)}async sendSMS(r,v){if(!this.options.smsProvider)throw Error("SMS provider not configured");let c=this.options.smsTemplate.replace("{code}",r.verificationCode).replace("{expiry}",this.options.codeExpiryMinutes.toString()),g=await this.options.smsProvider.sendSMS(r.phoneNumber,c);if(g.status==="failed")throw Error(g.error||"SMS sending failed")}async sendVoiceCall(r,v){if(!this.options.voiceProvider)throw Error("Voice provider not configured");let c=this.options.voiceTemplate.replace("{code}",r.verificationCode.split("").join(" ")),g=await this.options.voiceProvider.makeCall(r.phoneNumber,c);if(g.status==="failed")throw Error(g.error||"Voice call failed")}async sendMissedCall(r,v){if(!this.options.voiceProvider?.makeMissedCall)throw Error("Missed call verification not supported");let c=await this.options.voiceProvider.makeMissedCall(r.phoneNumber);if(c.status==="failed")throw Error(c.error||"Missed call failed");if(c.missedCallNumber){let g=c.missedCallNumber.slice(-this.options.codeLength);r.verificationCode=g}}async getPhoneNumberInfo(r){if(this.phoneNumberCache.has(r))return this.phoneNumberCache.get(r);let v=this.parseKoreanPhoneNumber(r);return this.phoneNumberCache.set(r,v),v}parseKoreanPhoneNumber(r){let v=r.replace(/\D/g,""),c=/^(010|011|016|017|018|019)(\d{7,8})$/,g=/^(02|031|032|033|041|042|043|044|051|052|053|054|055|061|062|063|064)(\d{7,8})$/,$=!1,o=!1,U="unknown",_;if(c.test(v))switch($=!0,o=!0,U="mobile",v.substring(0,3)){case"010":_="Multiple carriers";break;case"011":_="SK Telecom";break;case"016":_="KT";break;case"017":_="LG U+";break;case"018":_="SK Telecom";break;case"019":_="LG U+";break}else if(g.test(v))$=!0,o=!0,U="landline";else if(v.length>=10&&v.length<=11)o=!0;return{phoneNumber:v,countryCode:"82",nationalNumber:v,carrier:_,lineType:U,isValid:$,isPossible:o,region:"KR"}}isNumberBlocked(r){return this.blockedNumbers.has(r)}isRateLimited(r){let v=this.rateLimitTracker.get(r)||[],c=this.options.rateLimitMinutes*60*1000,g=new Date;return v.filter((o)=>g.getTime()-o.getTime()<c).length>=1}isDailyLimitExceeded(r){let v=new Date().toISOString().split("T")[0],c=this.dailyAttemptTracker.get(r);if(!c||c.date!==v)return!1;return c.count>=this.options.maxDailyAttempts}updateRateLimit(r){let v=this.rateLimitTracker.get(r)||[];v.push(new Date),this.rateLimitTracker.set(r,v)}updateDailyAttempts(r){let v=new Date().toISOString().split("T")[0],c=this.dailyAttemptTracker.get(r);if(!c||c.date!==v)this.dailyAttemptTracker.set(r,{date:v,count:1});else c.count++}validateCode(r,v){return r===v.replace(/\s/g,"")}generateVerificationCode(){let r=this.options.codeLength,v="";for(let c=0;c<r;c++)v+=Math.floor(Math.random()*10).toString();return v}generateRequestId(){return`phone_verify_${Date.now()}_${Math.random().toString(36).substr(2,9)}`}}
|
|
2300
22
|
|
|
2301
|
-
|
|
2302
|
-
|
|
2303
|
-
constructor() {
|
|
2304
|
-
this.channels = /* @__PURE__ */ new Map();
|
|
2305
|
-
this.senderNumbers = /* @__PURE__ */ new Map();
|
|
2306
|
-
}
|
|
2307
|
-
async createChannel(channel) {
|
|
2308
|
-
const newChannel = {
|
|
2309
|
-
...channel,
|
|
2310
|
-
id: this.generateChannelId(),
|
|
2311
|
-
createdAt: /* @__PURE__ */ new Date(),
|
|
2312
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
2313
|
-
};
|
|
2314
|
-
this.channels.set(newChannel.id, newChannel);
|
|
2315
|
-
return newChannel;
|
|
2316
|
-
}
|
|
2317
|
-
async getChannel(channelId) {
|
|
2318
|
-
return this.channels.get(channelId) || null;
|
|
2319
|
-
}
|
|
2320
|
-
async listChannels(providerId) {
|
|
2321
|
-
const channels = Array.from(this.channels.values());
|
|
2322
|
-
if (providerId) {
|
|
2323
|
-
return channels.filter((c) => c.providerId === providerId);
|
|
2324
|
-
}
|
|
2325
|
-
return channels;
|
|
2326
|
-
}
|
|
2327
|
-
async updateChannel(channelId, updates) {
|
|
2328
|
-
const channel = this.channels.get(channelId);
|
|
2329
|
-
if (!channel) {
|
|
2330
|
-
throw new Error(`Channel ${channelId} not found`);
|
|
2331
|
-
}
|
|
2332
|
-
const updatedChannel = {
|
|
2333
|
-
...channel,
|
|
2334
|
-
...updates,
|
|
2335
|
-
updatedAt: /* @__PURE__ */ new Date()
|
|
2336
|
-
};
|
|
2337
|
-
this.channels.set(channelId, updatedChannel);
|
|
2338
|
-
return updatedChannel;
|
|
2339
|
-
}
|
|
2340
|
-
async deleteChannel(channelId) {
|
|
2341
|
-
this.channels.delete(channelId);
|
|
2342
|
-
for (const [key, senderNumber] of this.senderNumbers.entries()) {
|
|
2343
|
-
if (senderNumber.channelId === channelId) {
|
|
2344
|
-
this.senderNumbers.delete(key);
|
|
2345
|
-
}
|
|
2346
|
-
}
|
|
2347
|
-
}
|
|
2348
|
-
async addSenderNumber(channelId, phoneNumber, name) {
|
|
2349
|
-
const channel = this.channels.get(channelId);
|
|
2350
|
-
if (!channel) {
|
|
2351
|
-
throw new Error(`Channel ${channelId} not found`);
|
|
2352
|
-
}
|
|
2353
|
-
const senderNumber = {
|
|
2354
|
-
phoneNumber,
|
|
2355
|
-
name,
|
|
2356
|
-
status: "PENDING" /* PENDING */,
|
|
2357
|
-
channelId
|
|
2358
|
-
};
|
|
2359
|
-
this.senderNumbers.set(phoneNumber, senderNumber);
|
|
2360
|
-
return senderNumber;
|
|
2361
|
-
}
|
|
2362
|
-
async verifySenderNumber(phoneNumber) {
|
|
2363
|
-
const senderNumber = this.senderNumbers.get(phoneNumber);
|
|
2364
|
-
if (!senderNumber) {
|
|
2365
|
-
return {
|
|
2366
|
-
success: false,
|
|
2367
|
-
status: "not_found",
|
|
2368
|
-
error: "Sender number not found"
|
|
2369
|
-
};
|
|
2370
|
-
}
|
|
2371
|
-
const verificationCode = Math.floor(Math.random() * 9e5) + 1e5;
|
|
2372
|
-
senderNumber.verifiedAt = /* @__PURE__ */ new Date();
|
|
2373
|
-
senderNumber.status = "VERIFIED" /* VERIFIED */;
|
|
2374
|
-
this.senderNumbers.set(phoneNumber, senderNumber);
|
|
2375
|
-
return {
|
|
2376
|
-
success: true,
|
|
2377
|
-
status: "verified",
|
|
2378
|
-
verificationCode: verificationCode.toString()
|
|
2379
|
-
};
|
|
2380
|
-
}
|
|
2381
|
-
async getSenderNumbers(channelId) {
|
|
2382
|
-
const senderNumbers = Array.from(this.senderNumbers.values());
|
|
2383
|
-
if (channelId) {
|
|
2384
|
-
return senderNumbers.filter((s) => s.channelId === channelId);
|
|
2385
|
-
}
|
|
2386
|
-
return senderNumbers;
|
|
2387
|
-
}
|
|
2388
|
-
generateChannelId() {
|
|
2389
|
-
return `ch_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
|
|
2390
|
-
}
|
|
2391
|
-
};
|
|
2392
|
-
export {
|
|
2393
|
-
ActionType,
|
|
2394
|
-
BusinessVerifier,
|
|
2395
|
-
ChannelCRUD,
|
|
2396
|
-
ChannelCreateRequestSchema,
|
|
2397
|
-
ChannelFiltersSchema,
|
|
2398
|
-
ChannelService,
|
|
2399
|
-
ChannelStatus,
|
|
2400
|
-
ChannelType,
|
|
2401
|
-
DocumentStatus,
|
|
2402
|
-
DocumentType,
|
|
2403
|
-
KakaoChannelManager,
|
|
2404
|
-
KakaoSenderNumberManager,
|
|
2405
|
-
NumberVerifier,
|
|
2406
|
-
PermissionManager,
|
|
2407
|
-
PermissionScope,
|
|
2408
|
-
ResourceType,
|
|
2409
|
-
SenderNumberCategory,
|
|
2410
|
-
SenderNumberCreateRequestSchema,
|
|
2411
|
-
SenderNumberFiltersSchema,
|
|
2412
|
-
SenderNumberStatus,
|
|
2413
|
-
VerificationMethod,
|
|
2414
|
-
VerificationStatus,
|
|
2415
|
-
VerificationType
|
|
2416
|
-
};
|
|
2417
|
-
//# sourceMappingURL=index.js.map
|
|
23
|
+
//# debugId=213F7E232E530A4B64756E2164756E21
|
|
24
|
+
//# sourceMappingURL=index.js.map
|