@exyconn/common 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (88) hide show
  1. package/README.md +259 -0
  2. package/dist/client/http/index.d.mts +85 -0
  3. package/dist/client/http/index.d.ts +85 -0
  4. package/dist/client/http/index.js +127 -0
  5. package/dist/client/http/index.js.map +1 -0
  6. package/dist/client/http/index.mjs +109 -0
  7. package/dist/client/http/index.mjs.map +1 -0
  8. package/dist/client/index.d.mts +7 -0
  9. package/dist/client/index.d.ts +7 -0
  10. package/dist/client/index.js +964 -0
  11. package/dist/client/index.js.map +1 -0
  12. package/dist/client/index.mjs +889 -0
  13. package/dist/client/index.mjs.map +1 -0
  14. package/dist/client/logger/index.d.mts +53 -0
  15. package/dist/client/logger/index.d.ts +53 -0
  16. package/dist/client/logger/index.js +120 -0
  17. package/dist/client/logger/index.js.map +1 -0
  18. package/dist/client/logger/index.mjs +116 -0
  19. package/dist/client/logger/index.mjs.map +1 -0
  20. package/dist/client/utils/index.d.mts +285 -0
  21. package/dist/client/utils/index.d.ts +285 -0
  22. package/dist/client/utils/index.js +403 -0
  23. package/dist/client/utils/index.js.map +1 -0
  24. package/dist/client/utils/index.mjs +362 -0
  25. package/dist/client/utils/index.mjs.map +1 -0
  26. package/dist/index-BNdT-2X4.d.ts +229 -0
  27. package/dist/index-CcrANHAQ.d.mts +59 -0
  28. package/dist/index-ClWtDfwk.d.ts +833 -0
  29. package/dist/index-DSW6JfD-.d.mts +833 -0
  30. package/dist/index-Du0LLt9f.d.mts +229 -0
  31. package/dist/index-iTKxFa78.d.ts +59 -0
  32. package/dist/index.d.mts +171 -0
  33. package/dist/index.d.ts +171 -0
  34. package/dist/index.js +3806 -0
  35. package/dist/index.js.map +1 -0
  36. package/dist/index.mjs +3792 -0
  37. package/dist/index.mjs.map +1 -0
  38. package/dist/response.types-D--UhLJq.d.mts +67 -0
  39. package/dist/response.types-D--UhLJq.d.ts +67 -0
  40. package/dist/server/db/index.d.mts +38 -0
  41. package/dist/server/db/index.d.ts +38 -0
  42. package/dist/server/db/index.js +68 -0
  43. package/dist/server/db/index.js.map +1 -0
  44. package/dist/server/db/index.mjs +60 -0
  45. package/dist/server/db/index.mjs.map +1 -0
  46. package/dist/server/enums/index.d.mts +46 -0
  47. package/dist/server/enums/index.d.ts +46 -0
  48. package/dist/server/enums/index.js +48 -0
  49. package/dist/server/enums/index.js.map +1 -0
  50. package/dist/server/enums/index.mjs +43 -0
  51. package/dist/server/enums/index.mjs.map +1 -0
  52. package/dist/server/index.d.mts +9 -0
  53. package/dist/server/index.d.ts +9 -0
  54. package/dist/server/index.js +569 -0
  55. package/dist/server/index.js.map +1 -0
  56. package/dist/server/index.mjs +523 -0
  57. package/dist/server/index.mjs.map +1 -0
  58. package/dist/server/logger/index.d.mts +34 -0
  59. package/dist/server/logger/index.d.ts +34 -0
  60. package/dist/server/logger/index.js +125 -0
  61. package/dist/server/logger/index.js.map +1 -0
  62. package/dist/server/logger/index.mjs +113 -0
  63. package/dist/server/logger/index.mjs.map +1 -0
  64. package/dist/server/middleware/index.d.mts +56 -0
  65. package/dist/server/middleware/index.d.ts +56 -0
  66. package/dist/server/middleware/index.js +128 -0
  67. package/dist/server/middleware/index.js.map +1 -0
  68. package/dist/server/middleware/index.mjs +118 -0
  69. package/dist/server/middleware/index.mjs.map +1 -0
  70. package/dist/server/response/index.d.mts +86 -0
  71. package/dist/server/response/index.d.ts +86 -0
  72. package/dist/server/response/index.js +140 -0
  73. package/dist/server/response/index.js.map +1 -0
  74. package/dist/server/response/index.mjs +126 -0
  75. package/dist/server/response/index.mjs.map +1 -0
  76. package/dist/server/utils/index.d.mts +69 -0
  77. package/dist/server/utils/index.d.ts +69 -0
  78. package/dist/server/utils/index.js +114 -0
  79. package/dist/server/utils/index.js.map +1 -0
  80. package/dist/server/utils/index.mjs +106 -0
  81. package/dist/server/utils/index.mjs.map +1 -0
  82. package/dist/shared/index.d.mts +4 -0
  83. package/dist/shared/index.d.ts +4 -0
  84. package/dist/shared/index.js +933 -0
  85. package/dist/shared/index.js.map +1 -0
  86. package/dist/shared/index.mjs +612 -0
  87. package/dist/shared/index.mjs.map +1 -0
  88. package/package.json +202 -0
@@ -0,0 +1,612 @@
1
+ import { parseISO, isValid, format, formatDistance, formatDistanceToNow, isToday, isYesterday, isTomorrow, isThisWeek, isThisYear, intervalToDuration, formatDuration, differenceInMinutes, addYears, addMonths, addWeeks, addDays, addHours, addMinutes, subYears, subMonths, subWeeks, subDays, subHours, subMinutes, differenceInYears, differenceInMonths, differenceInWeeks, differenceInDays, differenceInHours, differenceInSeconds, eachDayOfInterval, eachWeekOfInterval, eachMonthOfInterval, endOfDay, startOfDay, endOfWeek, startOfWeek, endOfMonth, startOfMonth, endOfYear, startOfYear, isAfter, isEqual, isBefore, getDay, setHours, setMinutes, setSeconds, getSeconds, getMinutes, getHours } from 'date-fns';
2
+ export { addDays, addHours, addMinutes, addMonths, addWeeks, addYears, differenceInDays, differenceInHours, differenceInMinutes, differenceInMonths, differenceInSeconds, differenceInWeeks, differenceInYears, eachDayOfInterval, eachMonthOfInterval, eachWeekOfInterval, endOfDay, endOfMonth, endOfWeek, endOfYear, format, formatDistance, formatDistanceToNow, formatDuration, formatRelative, getDate, getDay, getHours, getMinutes, getMonth, getSeconds, getYear, intervalToDuration, isAfter, isBefore, isEqual, isFuture, isPast, isSameDay, isSameMonth, isSameWeek, isSameYear, isThisMonth, isThisWeek, isThisYear, isToday, isTomorrow, isValid, isYesterday, parseISO, setHours, setMinutes, setSeconds, startOfDay, startOfMonth, startOfWeek, startOfYear, subDays, subHours, subMinutes, subMonths, subWeeks, subYears } from 'date-fns';
3
+ import { formatInTimeZone, toZonedTime, fromZonedTime } from 'date-fns-tz';
4
+ export { formatInTimeZone, fromZonedTime, toZonedTime } from 'date-fns-tz';
5
+
6
+ // src/shared/config/env.ts
7
+ var getEnv = (key, defaultValue) => {
8
+ const value = process.env[key];
9
+ if (value === void 0) {
10
+ if (defaultValue !== void 0) {
11
+ return defaultValue;
12
+ }
13
+ throw new Error(`Environment variable ${key} is required but not defined`);
14
+ }
15
+ if (typeof defaultValue === "number") {
16
+ return Number(value);
17
+ }
18
+ if (typeof defaultValue === "boolean") {
19
+ return value === "true" || value === "1";
20
+ }
21
+ return value;
22
+ };
23
+ var getEnvOptional = (key, defaultValue) => {
24
+ const value = process.env[key];
25
+ if (value === void 0) {
26
+ return defaultValue;
27
+ }
28
+ if (typeof defaultValue === "number") {
29
+ return Number(value);
30
+ }
31
+ if (typeof defaultValue === "boolean") {
32
+ return value === "true" || value === "1";
33
+ }
34
+ return value;
35
+ };
36
+ var isProd = () => {
37
+ return process.env.NODE_ENV === "production";
38
+ };
39
+ var isDev = () => {
40
+ return process.env.NODE_ENV === "development";
41
+ };
42
+ var isTest = () => {
43
+ return process.env.NODE_ENV === "test";
44
+ };
45
+ var validateEnv = (requiredVars) => {
46
+ const missing = requiredVars.filter((key) => !process.env[key]);
47
+ if (missing.length > 0) {
48
+ throw new Error(
49
+ `Missing required environment variables: ${missing.join(", ")}`
50
+ );
51
+ }
52
+ };
53
+
54
+ // src/shared/constants/status-codes.ts
55
+ var HTTP_STATUS = {
56
+ // Success
57
+ OK: 200,
58
+ CREATED: 201,
59
+ ACCEPTED: 202,
60
+ NO_CONTENT: 204,
61
+ // Redirection
62
+ MOVED_PERMANENTLY: 301,
63
+ FOUND: 302,
64
+ NOT_MODIFIED: 304,
65
+ TEMPORARY_REDIRECT: 307,
66
+ PERMANENT_REDIRECT: 308,
67
+ // Client Errors
68
+ BAD_REQUEST: 400,
69
+ UNAUTHORIZED: 401,
70
+ FORBIDDEN: 403,
71
+ NOT_FOUND: 404,
72
+ METHOD_NOT_ALLOWED: 405,
73
+ CONFLICT: 409,
74
+ GONE: 410,
75
+ UNPROCESSABLE_ENTITY: 422,
76
+ TOO_MANY_REQUESTS: 429,
77
+ // Server Errors
78
+ INTERNAL_SERVER_ERROR: 500,
79
+ NOT_IMPLEMENTED: 501,
80
+ BAD_GATEWAY: 502,
81
+ SERVICE_UNAVAILABLE: 503,
82
+ GATEWAY_TIMEOUT: 504
83
+ };
84
+ var HTTP_STATUS_MESSAGES = {
85
+ [HTTP_STATUS.OK]: "OK",
86
+ [HTTP_STATUS.CREATED]: "Created",
87
+ [HTTP_STATUS.ACCEPTED]: "Accepted",
88
+ [HTTP_STATUS.NO_CONTENT]: "No Content",
89
+ [HTTP_STATUS.BAD_REQUEST]: "Bad Request",
90
+ [HTTP_STATUS.UNAUTHORIZED]: "Unauthorized",
91
+ [HTTP_STATUS.FORBIDDEN]: "Forbidden",
92
+ [HTTP_STATUS.NOT_FOUND]: "Not Found",
93
+ [HTTP_STATUS.METHOD_NOT_ALLOWED]: "Method Not Allowed",
94
+ [HTTP_STATUS.CONFLICT]: "Conflict",
95
+ [HTTP_STATUS.UNPROCESSABLE_ENTITY]: "Unprocessable Entity",
96
+ [HTTP_STATUS.TOO_MANY_REQUESTS]: "Too Many Requests",
97
+ [HTTP_STATUS.INTERNAL_SERVER_ERROR]: "Internal Server Error",
98
+ [HTTP_STATUS.SERVICE_UNAVAILABLE]: "Service Unavailable"
99
+ };
100
+ var STATUS = {
101
+ ACTIVE: "active",
102
+ INACTIVE: "inactive",
103
+ PENDING: "pending",
104
+ APPROVED: "approved",
105
+ REJECTED: "rejected",
106
+ DELETED: "deleted",
107
+ ARCHIVED: "archived",
108
+ DRAFT: "draft",
109
+ PUBLISHED: "published",
110
+ SUSPENDED: "suspended"
111
+ };
112
+ var USER_STATUS = {
113
+ ACTIVE: "active",
114
+ INACTIVE: "inactive",
115
+ PENDING: "pending",
116
+ SUSPENDED: "suspended",
117
+ BANNED: "banned"
118
+ };
119
+ var ROLES = {
120
+ ADMIN: "admin",
121
+ USER: "user",
122
+ MODERATOR: "moderator",
123
+ GUEST: "guest",
124
+ SUPER_ADMIN: "super_admin"
125
+ };
126
+ var PAGINATION = {
127
+ DEFAULT_PAGE: 1,
128
+ DEFAULT_LIMIT: 10,
129
+ MAX_LIMIT: 100
130
+ };
131
+ var TOKEN_TYPES = {
132
+ ACCESS: "access",
133
+ REFRESH: "refresh",
134
+ RESET_PASSWORD: "reset_password",
135
+ EMAIL_VERIFICATION: "email_verification"
136
+ };
137
+ var parseDate = (date) => {
138
+ if (date instanceof Date) return date;
139
+ if (typeof date === "string") return parseISO(date);
140
+ return new Date(date);
141
+ };
142
+ var isValidDate = (date) => {
143
+ const parsed = parseDate(date);
144
+ return isValid(parsed);
145
+ };
146
+ var DATE_FORMATS = {
147
+ // Date only
148
+ DATE_SHORT: "MM/dd/yyyy",
149
+ // 01/15/2026
150
+ DATE_MEDIUM: "MMM d, yyyy",
151
+ // Jan 15, 2026
152
+ DATE_LONG: "MMMM d, yyyy",
153
+ // January 15, 2026
154
+ DATE_FULL: "EEEE, MMMM d, yyyy",
155
+ // Friday, January 15, 2026
156
+ DATE_ISO: "yyyy-MM-dd",
157
+ // 2026-01-15
158
+ // Time only
159
+ TIME_SHORT: "h:mm a",
160
+ // 3:30 PM
161
+ TIME_MEDIUM: "h:mm:ss a",
162
+ // 3:30:45 PM
163
+ TIME_24H: "HH:mm",
164
+ // 15:30
165
+ TIME_24H_FULL: "HH:mm:ss",
166
+ // 15:30:45
167
+ // Date and time
168
+ DATETIME_SHORT: "MM/dd/yyyy h:mm a",
169
+ // 01/15/2026 3:30 PM
170
+ DATETIME_MEDIUM: "MMM d, yyyy h:mm a",
171
+ // Jan 15, 2026 3:30 PM
172
+ DATETIME_LONG: "MMMM d, yyyy h:mm a",
173
+ // January 15, 2026 3:30 PM
174
+ DATETIME_FULL: "EEEE, MMMM d, yyyy h:mm a",
175
+ // Friday, January 15, 2026 3:30 PM
176
+ DATETIME_ISO: "yyyy-MM-dd'T'HH:mm:ss",
177
+ // 2026-01-15T15:30:45
178
+ // Special formats
179
+ MONTH_YEAR: "MMMM yyyy",
180
+ // January 2026
181
+ MONTH_DAY: "MMM d",
182
+ // Jan 15
183
+ DAY_MONTH: "d MMM",
184
+ // 15 Jan
185
+ WEEKDAY: "EEEE",
186
+ // Friday
187
+ WEEKDAY_SHORT: "EEE"
188
+ // Fri
189
+ };
190
+ var formatDate = (date, formatStr = DATE_FORMATS.DATE_MEDIUM) => {
191
+ return format(parseDate(date), formatStr);
192
+ };
193
+ var formatDateTime = (date, formatStr = DATE_FORMATS.DATETIME_MEDIUM) => {
194
+ return format(parseDate(date), formatStr);
195
+ };
196
+ var formatDateInTimezone = (date, timezone, formatStr = DATE_FORMATS.DATETIME_MEDIUM) => {
197
+ return formatInTimeZone(parseDate(date), timezone, formatStr);
198
+ };
199
+ var formatRelativeTime = (date, baseDate) => {
200
+ const parsed = parseDate(date);
201
+ if (baseDate) {
202
+ return formatDistance(parsed, parseDate(baseDate), { addSuffix: true });
203
+ }
204
+ return formatDistanceToNow(parsed, { addSuffix: true });
205
+ };
206
+ var formatSmartDate = (date) => {
207
+ const parsed = parseDate(date);
208
+ if (isToday(parsed)) {
209
+ return `Today at ${format(parsed, DATE_FORMATS.TIME_SHORT)}`;
210
+ }
211
+ if (isYesterday(parsed)) {
212
+ return `Yesterday at ${format(parsed, DATE_FORMATS.TIME_SHORT)}`;
213
+ }
214
+ if (isTomorrow(parsed)) {
215
+ return `Tomorrow at ${format(parsed, DATE_FORMATS.TIME_SHORT)}`;
216
+ }
217
+ if (isThisWeek(parsed)) {
218
+ return format(parsed, "EEEE 'at' h:mm a");
219
+ }
220
+ if (isThisYear(parsed)) {
221
+ return format(parsed, "MMM d 'at' h:mm a");
222
+ }
223
+ return format(parsed, DATE_FORMATS.DATETIME_MEDIUM);
224
+ };
225
+ var formatDateRange = (start, end) => {
226
+ const duration = intervalToDuration({
227
+ start: parseDate(start),
228
+ end: parseDate(end)
229
+ });
230
+ return formatDuration(duration, {
231
+ format: ["years", "months", "days", "hours", "minutes"]
232
+ });
233
+ };
234
+ var toTimezone = (date, timezone) => {
235
+ return toZonedTime(parseDate(date), timezone);
236
+ };
237
+ var fromTimezone = (date, timezone) => {
238
+ return fromZonedTime(parseDate(date), timezone);
239
+ };
240
+ var nowInTimezone = (timezone) => {
241
+ return toZonedTime(/* @__PURE__ */ new Date(), timezone);
242
+ };
243
+ var getTimezoneDifference = (timezone1, timezone2) => {
244
+ const now = /* @__PURE__ */ new Date();
245
+ const time1 = toZonedTime(now, timezone1);
246
+ const time2 = toZonedTime(now, timezone2);
247
+ const diffMinutes = differenceInMinutes(time1, time2);
248
+ const hours = Math.floor(Math.abs(diffMinutes) / 60);
249
+ const minutes = Math.abs(diffMinutes) % 60;
250
+ const sign = diffMinutes >= 0 ? "+" : "-";
251
+ if (minutes === 0) {
252
+ return `${sign}${hours}h`;
253
+ }
254
+ return `${sign}${hours}h ${minutes}m`;
255
+ };
256
+ var addTime = (date, amount, unit) => {
257
+ const parsed = parseDate(date);
258
+ switch (unit) {
259
+ case "minutes":
260
+ return addMinutes(parsed, amount);
261
+ case "hours":
262
+ return addHours(parsed, amount);
263
+ case "days":
264
+ return addDays(parsed, amount);
265
+ case "weeks":
266
+ return addWeeks(parsed, amount);
267
+ case "months":
268
+ return addMonths(parsed, amount);
269
+ case "years":
270
+ return addYears(parsed, amount);
271
+ }
272
+ };
273
+ var subtractTime = (date, amount, unit) => {
274
+ const parsed = parseDate(date);
275
+ switch (unit) {
276
+ case "minutes":
277
+ return subMinutes(parsed, amount);
278
+ case "hours":
279
+ return subHours(parsed, amount);
280
+ case "days":
281
+ return subDays(parsed, amount);
282
+ case "weeks":
283
+ return subWeeks(parsed, amount);
284
+ case "months":
285
+ return subMonths(parsed, amount);
286
+ case "years":
287
+ return subYears(parsed, amount);
288
+ }
289
+ };
290
+ var getDateDifference = (date1, date2, unit) => {
291
+ const d1 = parseDate(date1);
292
+ const d2 = parseDate(date2);
293
+ switch (unit) {
294
+ case "seconds":
295
+ return differenceInSeconds(d1, d2);
296
+ case "minutes":
297
+ return differenceInMinutes(d1, d2);
298
+ case "hours":
299
+ return differenceInHours(d1, d2);
300
+ case "days":
301
+ return differenceInDays(d1, d2);
302
+ case "weeks":
303
+ return differenceInWeeks(d1, d2);
304
+ case "months":
305
+ return differenceInMonths(d1, d2);
306
+ case "years":
307
+ return differenceInYears(d1, d2);
308
+ }
309
+ };
310
+ var getDaysInRange = (start, end) => {
311
+ return eachDayOfInterval({
312
+ start: parseDate(start),
313
+ end: parseDate(end)
314
+ });
315
+ };
316
+ var getWeeksInRange = (start, end) => {
317
+ return eachWeekOfInterval({
318
+ start: parseDate(start),
319
+ end: parseDate(end)
320
+ });
321
+ };
322
+ var getMonthsInRange = (start, end) => {
323
+ return eachMonthOfInterval({
324
+ start: parseDate(start),
325
+ end: parseDate(end)
326
+ });
327
+ };
328
+ var getDayBoundaries = (date) => {
329
+ const parsed = parseDate(date);
330
+ return {
331
+ start: startOfDay(parsed),
332
+ end: endOfDay(parsed)
333
+ };
334
+ };
335
+ var getWeekBoundaries = (date, weekStartsOn = 0) => {
336
+ const parsed = parseDate(date);
337
+ return {
338
+ start: startOfWeek(parsed, { weekStartsOn }),
339
+ end: endOfWeek(parsed, { weekStartsOn })
340
+ };
341
+ };
342
+ var getMonthBoundaries = (date) => {
343
+ const parsed = parseDate(date);
344
+ return {
345
+ start: startOfMonth(parsed),
346
+ end: endOfMonth(parsed)
347
+ };
348
+ };
349
+ var getYearBoundaries = (date) => {
350
+ const parsed = parseDate(date);
351
+ return {
352
+ start: startOfYear(parsed),
353
+ end: endOfYear(parsed)
354
+ };
355
+ };
356
+ var isDateBetween = (date, start, end) => {
357
+ const d = parseDate(date);
358
+ const s = parseDate(start);
359
+ const e = parseDate(end);
360
+ return (isAfter(d, s) || isEqual(d, s)) && (isBefore(d, e) || isEqual(d, e));
361
+ };
362
+ var doDateRangesOverlap = (range1Start, range1End, range2Start, range2End) => {
363
+ const r1s = parseDate(range1Start);
364
+ const r1e = parseDate(range1End);
365
+ const r2s = parseDate(range2Start);
366
+ const r2e = parseDate(range2End);
367
+ return isBefore(r1s, r2e) && isAfter(r1e, r2s);
368
+ };
369
+ var getAge = (birthDate) => {
370
+ return differenceInYears(/* @__PURE__ */ new Date(), parseDate(birthDate));
371
+ };
372
+ var isWeekend = (date) => {
373
+ const day = getDay(parseDate(date));
374
+ return day === 0 || day === 6;
375
+ };
376
+ var isWeekday = (date) => {
377
+ return !isWeekend(date);
378
+ };
379
+ var daysUntil = (date) => {
380
+ return differenceInDays(parseDate(date), /* @__PURE__ */ new Date());
381
+ };
382
+ var daysSince = (date) => {
383
+ return differenceInDays(/* @__PURE__ */ new Date(), parseDate(date));
384
+ };
385
+ var toDateInputValue = (date) => {
386
+ return format(parseDate(date), DATE_FORMATS.DATE_ISO);
387
+ };
388
+ var toDateTimeInputValue = (date) => {
389
+ return format(parseDate(date), "yyyy-MM-dd'T'HH:mm");
390
+ };
391
+ var toTimeInputValue = (date) => {
392
+ return format(parseDate(date), DATE_FORMATS.TIME_24H);
393
+ };
394
+ var setTime = (date, hours, minutes, seconds = 0) => {
395
+ let result = parseDate(date);
396
+ result = setHours(result, hours);
397
+ result = setMinutes(result, minutes);
398
+ result = setSeconds(result, seconds);
399
+ return result;
400
+ };
401
+ var combineDateAndTime = (dateInput, timeInput) => {
402
+ const date = parseDate(dateInput);
403
+ const time = parseDate(timeInput);
404
+ return setTime(date, getHours(time), getMinutes(time), getSeconds(time));
405
+ };
406
+ var date_time_default = {
407
+ // Core
408
+ parseDate,
409
+ isValidDate,
410
+ DATE_FORMATS,
411
+ // Format
412
+ formatDate,
413
+ formatDateTime,
414
+ formatDateInTimezone,
415
+ formatRelativeTime,
416
+ formatSmartDate,
417
+ formatDateRange,
418
+ // Timezone
419
+ toTimezone,
420
+ fromTimezone,
421
+ nowInTimezone,
422
+ getTimezoneDifference,
423
+ // Arithmetic
424
+ addTime,
425
+ subtractTime,
426
+ getDateDifference,
427
+ // Ranges
428
+ getDaysInRange,
429
+ getWeeksInRange,
430
+ getMonthsInRange,
431
+ // Boundaries
432
+ getDayBoundaries,
433
+ getWeekBoundaries,
434
+ getMonthBoundaries,
435
+ getYearBoundaries,
436
+ // Comparison
437
+ isDateBetween,
438
+ doDateRangesOverlap,
439
+ // Utilities
440
+ getAge,
441
+ isWeekend,
442
+ isWeekday,
443
+ daysUntil,
444
+ daysSince,
445
+ toDateInputValue,
446
+ toDateTimeInputValue,
447
+ toTimeInputValue,
448
+ setTime,
449
+ combineDateAndTime
450
+ };
451
+
452
+ // src/shared/validation/index.ts
453
+ var VALIDATION_PATTERNS = {
454
+ /** Email pattern (RFC 5322 simplified) */
455
+ EMAIL: /^[^\s@]+@[^\s@]+\.[^\s@]+$/,
456
+ /** Strong password: min 8 chars, uppercase, lowercase, number, special char */
457
+ PASSWORD_STRONG: /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[@$!%*?&])[A-Za-z\d@$!%*?&]{8,}$/,
458
+ /** Medium password: min 8 chars, uppercase, lowercase, number */
459
+ PASSWORD_MEDIUM: /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)[A-Za-z\d@$!%*?&]{8,}$/,
460
+ /** Basic password: min 8 chars */
461
+ PASSWORD_BASIC: /^.{8,}$/,
462
+ /** Phone number (international) */
463
+ PHONE_INTERNATIONAL: /^\+?[\d\s\-().]{10,}$/,
464
+ /** Phone number (US) */
465
+ PHONE_US: /^\(?([0-9]{3})\)?[-. ]?([0-9]{3})[-. ]?([0-9]{4})$/,
466
+ /** Phone number (India) */
467
+ PHONE_INDIA: /^[6-9]\d{9}$/,
468
+ /** URL pattern */
469
+ URL: /^(https?:\/\/)?([\da-z.-]+)\.([a-z.]{2,6})([/\w .-]*)*\/?$/,
470
+ /** URL with required protocol */
471
+ URL_STRICT: /^https?:\/\/([\da-z.-]+)\.([a-z.]{2,6})([/\w .-]*)*\/?$/,
472
+ /** Alphanumeric only */
473
+ ALPHANUMERIC: /^[a-zA-Z0-9]+$/,
474
+ /** Letters only */
475
+ LETTERS_ONLY: /^[a-zA-Z]+$/,
476
+ /** Numbers only */
477
+ NUMBERS_ONLY: /^\d+$/,
478
+ /** Slug pattern (kebab-case) */
479
+ SLUG: /^[a-z0-9]+(?:-[a-z0-9]+)*$/,
480
+ /** Username pattern (alphanumeric, underscore, hyphen) */
481
+ USERNAME: /^[a-zA-Z0-9_-]{3,30}$/,
482
+ /** Credit card (basic validation) */
483
+ CREDIT_CARD: /^\d{13,19}$/,
484
+ /** CVV (3 or 4 digits) */
485
+ CVV: /^\d{3,4}$/,
486
+ /** ZIP code (US) */
487
+ ZIP_US: /^\d{5}(-\d{4})?$/,
488
+ /** Postal code (India) */
489
+ POSTAL_INDIA: /^\d{6}$/,
490
+ /** IP Address (IPv4) */
491
+ IPV4: /^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/,
492
+ /** Hex color */
493
+ HEX_COLOR: /^#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/,
494
+ /** Date (YYYY-MM-DD) */
495
+ DATE_ISO: /^\d{4}-\d{2}-\d{2}$/,
496
+ /** Time (HH:MM or HH:MM:SS) */
497
+ TIME: /^([01]\d|2[0-3]):([0-5]\d)(:[0-5]\d)?$/
498
+ };
499
+ var isValidEmail = (email) => {
500
+ return VALIDATION_PATTERNS.EMAIL.test(email.trim());
501
+ };
502
+ var isValidPassword = (password, strength = "medium") => {
503
+ switch (strength) {
504
+ case "strong":
505
+ return VALIDATION_PATTERNS.PASSWORD_STRONG.test(password);
506
+ case "medium":
507
+ return VALIDATION_PATTERNS.PASSWORD_MEDIUM.test(password);
508
+ case "basic":
509
+ default:
510
+ return VALIDATION_PATTERNS.PASSWORD_BASIC.test(password);
511
+ }
512
+ };
513
+ var isValidPhone = (phone, format2 = "international") => {
514
+ const cleaned = phone.replace(/\s/g, "");
515
+ switch (format2) {
516
+ case "us":
517
+ return VALIDATION_PATTERNS.PHONE_US.test(cleaned);
518
+ case "india":
519
+ return VALIDATION_PATTERNS.PHONE_INDIA.test(cleaned);
520
+ case "international":
521
+ default:
522
+ return VALIDATION_PATTERNS.PHONE_INTERNATIONAL.test(cleaned);
523
+ }
524
+ };
525
+ var isValidUrl = (url, requireProtocol = false) => {
526
+ if (requireProtocol) {
527
+ return VALIDATION_PATTERNS.URL_STRICT.test(url);
528
+ }
529
+ return VALIDATION_PATTERNS.URL.test(url);
530
+ };
531
+ var isValidUsername = (username) => {
532
+ return VALIDATION_PATTERNS.USERNAME.test(username);
533
+ };
534
+ var isValidSlug = (slug) => {
535
+ return VALIDATION_PATTERNS.SLUG.test(slug);
536
+ };
537
+ var VALIDATION_MESSAGES = {
538
+ // Required fields
539
+ REQUIRED: "This field is required",
540
+ REQUIRED_FIELD: (field) => `${field} is required`,
541
+ // Email
542
+ EMAIL_INVALID: "Please enter a valid email address",
543
+ EMAIL_REQUIRED: "Email is required",
544
+ // Password
545
+ PASSWORD_REQUIRED: "Password is required",
546
+ PASSWORD_MIN_LENGTH: (length) => `Password must be at least ${length} characters`,
547
+ PASSWORD_WEAK: "Password is too weak",
548
+ PASSWORD_MEDIUM: "Password must contain uppercase, lowercase, and number",
549
+ PASSWORD_STRONG: "Password must contain uppercase, lowercase, number, and special character",
550
+ PASSWORD_MISMATCH: "Passwords do not match",
551
+ // Name
552
+ NAME_REQUIRED: "Name is required",
553
+ FIRST_NAME_REQUIRED: "First name is required",
554
+ LAST_NAME_REQUIRED: "Last name is required",
555
+ NAME_MIN_LENGTH: (length) => `Name must be at least ${length} characters`,
556
+ NAME_MAX_LENGTH: (length) => `Name must be at most ${length} characters`,
557
+ // Phone
558
+ PHONE_INVALID: "Please enter a valid phone number",
559
+ PHONE_REQUIRED: "Phone number is required",
560
+ // URL
561
+ URL_INVALID: "Please enter a valid URL",
562
+ // Username
563
+ USERNAME_INVALID: "Username can only contain letters, numbers, underscores, and hyphens",
564
+ USERNAME_MIN_LENGTH: "Username must be at least 3 characters",
565
+ USERNAME_MAX_LENGTH: "Username must be at most 30 characters",
566
+ USERNAME_TAKEN: "This username is already taken",
567
+ // General
568
+ MIN_LENGTH: (field, length) => `${field} must be at least ${length} characters`,
569
+ MAX_LENGTH: (field, length) => `${field} must be at most ${length} characters`,
570
+ MIN_VALUE: (field, value) => `${field} must be at least ${value}`,
571
+ MAX_VALUE: (field, value) => `${field} must be at most ${value}`,
572
+ INVALID_FORMAT: "Invalid format",
573
+ TERMS_REQUIRED: "You must accept the terms and conditions"
574
+ };
575
+ var VALIDATION_RULES = {
576
+ email: {
577
+ pattern: VALIDATION_PATTERNS.EMAIL,
578
+ message: VALIDATION_MESSAGES.EMAIL_INVALID
579
+ },
580
+ password: {
581
+ minLength: 8,
582
+ pattern: VALIDATION_PATTERNS.PASSWORD_MEDIUM,
583
+ message: VALIDATION_MESSAGES.PASSWORD_MEDIUM
584
+ },
585
+ passwordStrong: {
586
+ minLength: 8,
587
+ pattern: VALIDATION_PATTERNS.PASSWORD_STRONG,
588
+ message: VALIDATION_MESSAGES.PASSWORD_STRONG
589
+ },
590
+ name: {
591
+ minLength: 2,
592
+ maxLength: 50
593
+ },
594
+ username: {
595
+ minLength: 3,
596
+ maxLength: 30,
597
+ pattern: VALIDATION_PATTERNS.USERNAME,
598
+ message: VALIDATION_MESSAGES.USERNAME_INVALID
599
+ },
600
+ phone: {
601
+ pattern: VALIDATION_PATTERNS.PHONE_INTERNATIONAL,
602
+ message: VALIDATION_MESSAGES.PHONE_INVALID
603
+ },
604
+ url: {
605
+ pattern: VALIDATION_PATTERNS.URL,
606
+ message: VALIDATION_MESSAGES.URL_INVALID
607
+ }
608
+ };
609
+
610
+ export { DATE_FORMATS, HTTP_STATUS, HTTP_STATUS_MESSAGES, PAGINATION, ROLES, STATUS, TOKEN_TYPES, USER_STATUS, VALIDATION_MESSAGES, VALIDATION_PATTERNS, VALIDATION_RULES, addTime, combineDateAndTime, date_time_default as dateTime, daysSince, daysUntil, doDateRangesOverlap, formatDate, formatDateInTimezone, formatDateRange, formatDateTime, formatRelativeTime, formatSmartDate, fromTimezone, getAge, getDateDifference, getDayBoundaries, getDaysInRange, getEnv, getEnvOptional, getMonthBoundaries, getMonthsInRange, getTimezoneDifference, getWeekBoundaries, getWeeksInRange, getYearBoundaries, isDateBetween, isDev, isProd, isTest, isValidDate, isValidEmail, isValidPassword, isValidPhone, isValidSlug, isValidUrl, isValidUsername, isWeekday, isWeekend, nowInTimezone, parseDate, setTime, subtractTime, toDateInputValue, toDateTimeInputValue, toTimeInputValue, toTimezone, validateEnv };
611
+ //# sourceMappingURL=index.mjs.map
612
+ //# sourceMappingURL=index.mjs.map