@goplusvn/core 0.1.1 → 0.1.3
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/package.json +31 -175
- package/dist/audit/index.d.mts +0 -115
- package/dist/audit/index.d.ts +0 -115
- package/dist/audit/index.js +0 -204
- package/dist/audit/index.js.map +0 -1
- package/dist/audit/index.mjs +0 -200
- package/dist/audit/index.mjs.map +0 -1
- package/dist/auth/index.d.mts +0 -86
- package/dist/auth/index.d.ts +0 -86
- package/dist/auth/index.js +0 -210
- package/dist/auth/index.js.map +0 -1
- package/dist/auth/index.mjs +0 -198
- package/dist/auth/index.mjs.map +0 -1
- package/dist/button-1dWvP9Ib.d.mts +0 -30
- package/dist/button-1dWvP9Ib.d.ts +0 -30
- package/dist/calendar-2QzdEo1z.d.mts +0 -20
- package/dist/calendar-2QzdEo1z.d.ts +0 -20
- package/dist/code-generation/index.d.mts +0 -30
- package/dist/code-generation/index.d.ts +0 -30
- package/dist/code-generation/index.js +0 -31
- package/dist/code-generation/index.js.map +0 -1
- package/dist/code-generation/index.mjs +0 -28
- package/dist/code-generation/index.mjs.map +0 -1
- package/dist/configs/index.d.mts +0 -175
- package/dist/configs/index.d.ts +0 -175
- package/dist/configs/index.js +0 -254
- package/dist/configs/index.js.map +0 -1
- package/dist/configs/index.mjs +0 -233
- package/dist/configs/index.mjs.map +0 -1
- package/dist/crud/index.d.mts +0 -646
- package/dist/crud/index.d.ts +0 -646
- package/dist/crud/index.js +0 -11772
- package/dist/crud/index.js.map +0 -1
- package/dist/crud/index.mjs +0 -11665
- package/dist/crud/index.mjs.map +0 -1
- package/dist/crud/server.d.mts +0 -20
- package/dist/crud/server.d.ts +0 -20
- package/dist/crud/server.js +0 -123
- package/dist/crud/server.js.map +0 -1
- package/dist/crud/server.mjs +0 -120
- package/dist/crud/server.mjs.map +0 -1
- package/dist/data-table-skeleton-12NA8Mjx.d.mts +0 -39
- package/dist/data-table-skeleton-12NA8Mjx.d.ts +0 -39
- package/dist/dialog-bKfjZMTd.d.mts +0 -22
- package/dist/dialog-bKfjZMTd.d.ts +0 -22
- package/dist/dynamic-icon-DrGIiu2N.d.mts +0 -10
- package/dist/dynamic-icon-DrGIiu2N.d.ts +0 -10
- package/dist/home/index.d.mts +0 -269
- package/dist/home/index.d.ts +0 -269
- package/dist/home/index.js +0 -1678
- package/dist/home/index.js.map +0 -1
- package/dist/home/index.mjs +0 -1635
- package/dist/home/index.mjs.map +0 -1
- package/dist/hooks/index.d.mts +0 -7
- package/dist/hooks/index.d.ts +0 -7
- package/dist/hooks/index.js +0 -8316
- package/dist/hooks/index.js.map +0 -1
- package/dist/hooks/index.mjs +0 -8255
- package/dist/hooks/index.mjs.map +0 -1
- package/dist/index-50hpiPrV.d.ts +0 -116
- package/dist/index-B9zQVEVi.d.mts +0 -116
- package/dist/index.d.mts +0 -5
- package/dist/index.d.ts +0 -5
- package/dist/index.js +0 -123
- package/dist/index.js.map +0 -1
- package/dist/index.mjs +0 -118
- package/dist/index.mjs.map +0 -1
- package/dist/infrastructure/index.d.mts +0 -423
- package/dist/infrastructure/index.d.ts +0 -423
- package/dist/infrastructure/index.js +0 -633
- package/dist/infrastructure/index.js.map +0 -1
- package/dist/infrastructure/index.mjs +0 -619
- package/dist/infrastructure/index.mjs.map +0 -1
- package/dist/label-DWTEkNPo.d.ts +0 -226
- package/dist/label-LPpdcoBx.d.mts +0 -226
- package/dist/layout/index.d.mts +0 -48
- package/dist/layout/index.d.ts +0 -48
- package/dist/layout/index.js +0 -117
- package/dist/layout/index.js.map +0 -1
- package/dist/layout/index.mjs +0 -90
- package/dist/layout/index.mjs.map +0 -1
- package/dist/navigation/index.d.mts +0 -16
- package/dist/navigation/index.d.ts +0 -16
- package/dist/navigation/index.js +0 -53
- package/dist/navigation/index.js.map +0 -1
- package/dist/navigation/index.mjs +0 -50
- package/dist/navigation/index.mjs.map +0 -1
- package/dist/notification/index.d.mts +0 -105
- package/dist/notification/index.d.ts +0 -105
- package/dist/notification/index.js +0 -278
- package/dist/notification/index.js.map +0 -1
- package/dist/notification/index.mjs +0 -274
- package/dist/notification/index.mjs.map +0 -1
- package/dist/organization/index.d.mts +0 -99
- package/dist/organization/index.d.ts +0 -99
- package/dist/organization/index.js +0 -360
- package/dist/organization/index.js.map +0 -1
- package/dist/organization/index.mjs +0 -352
- package/dist/organization/index.mjs.map +0 -1
- package/dist/plugin/index.d.mts +0 -83
- package/dist/plugin/index.d.ts +0 -83
- package/dist/plugin/index.js +0 -86
- package/dist/plugin/index.js.map +0 -1
- package/dist/plugin/index.mjs +0 -84
- package/dist/plugin/index.mjs.map +0 -1
- package/dist/providers/index.d.mts +0 -25
- package/dist/providers/index.d.ts +0 -25
- package/dist/providers/index.js +0 -84
- package/dist/providers/index.js.map +0 -1
- package/dist/providers/index.mjs +0 -77
- package/dist/providers/index.mjs.map +0 -1
- package/dist/rbac/index.d.mts +0 -226
- package/dist/rbac/index.d.ts +0 -226
- package/dist/rbac/index.js +0 -4784
- package/dist/rbac/index.js.map +0 -1
- package/dist/rbac/index.mjs +0 -4722
- package/dist/rbac/index.mjs.map +0 -1
- package/dist/rbac/permissions.d.mts +0 -26
- package/dist/rbac/permissions.d.ts +0 -26
- package/dist/rbac/permissions.js +0 -94
- package/dist/rbac/permissions.js.map +0 -1
- package/dist/rbac/permissions.mjs +0 -90
- package/dist/rbac/permissions.mjs.map +0 -1
- package/dist/rbac/server.d.mts +0 -1
- package/dist/rbac/server.d.ts +0 -1
- package/dist/rbac/server.js +0 -128
- package/dist/rbac/server.js.map +0 -1
- package/dist/rbac/server.mjs +0 -124
- package/dist/rbac/server.mjs.map +0 -1
- package/dist/schemas/index.d.mts +0 -1257
- package/dist/schemas/index.d.ts +0 -1257
- package/dist/schemas/index.js +0 -572
- package/dist/schemas/index.js.map +0 -1
- package/dist/schemas/index.mjs +0 -523
- package/dist/schemas/index.mjs.map +0 -1
- package/dist/server-QuYCTa89.d.mts +0 -83
- package/dist/server-QuYCTa89.d.ts +0 -83
- package/dist/sonner-C74GlRDQ.d.mts +0 -71
- package/dist/sonner-C74GlRDQ.d.ts +0 -71
- package/dist/status-BOXZgIqX.d.mts +0 -12
- package/dist/status-BOXZgIqX.d.ts +0 -12
- package/dist/system/index.d.mts +0 -77
- package/dist/system/index.d.ts +0 -77
- package/dist/system/index.js +0 -102
- package/dist/system/index.js.map +0 -1
- package/dist/system/index.mjs +0 -100
- package/dist/system/index.mjs.map +0 -1
- package/dist/tabs-C6FfBwPY.d.mts +0 -18
- package/dist/tabs-C6FfBwPY.d.ts +0 -18
- package/dist/tenant-provider-B8eC_Wpb.d.mts +0 -27
- package/dist/tenant-provider-B8eC_Wpb.d.ts +0 -27
- package/dist/types/index.d.mts +0 -469
- package/dist/types/index.d.ts +0 -469
- package/dist/types/index.js +0 -25
- package/dist/types/index.js.map +0 -1
- package/dist/types/index.mjs +0 -21
- package/dist/types/index.mjs.map +0 -1
- package/dist/ui/auth.d.mts +0 -39
- package/dist/ui/auth.d.ts +0 -39
- package/dist/ui/auth.js +0 -4941
- package/dist/ui/auth.js.map +0 -1
- package/dist/ui/auth.mjs +0 -4896
- package/dist/ui/auth.mjs.map +0 -1
- package/dist/ui/crud.d.mts +0 -2
- package/dist/ui/crud.d.ts +0 -2
- package/dist/ui/crud.js +0 -4
- package/dist/ui/crud.js.map +0 -1
- package/dist/ui/crud.mjs +0 -3
- package/dist/ui/crud.mjs.map +0 -1
- package/dist/ui/data-display.d.mts +0 -596
- package/dist/ui/data-display.d.ts +0 -596
- package/dist/ui/data-display.js +0 -5307
- package/dist/ui/data-display.js.map +0 -1
- package/dist/ui/data-display.mjs +0 -5212
- package/dist/ui/data-display.mjs.map +0 -1
- package/dist/ui/feedback.d.mts +0 -55
- package/dist/ui/feedback.d.ts +0 -55
- package/dist/ui/feedback.js +0 -2608
- package/dist/ui/feedback.js.map +0 -1
- package/dist/ui/feedback.mjs +0 -2526
- package/dist/ui/feedback.mjs.map +0 -1
- package/dist/ui/forms.d.mts +0 -309
- package/dist/ui/forms.d.ts +0 -309
- package/dist/ui/forms.js +0 -4656
- package/dist/ui/forms.js.map +0 -1
- package/dist/ui/forms.mjs +0 -4571
- package/dist/ui/forms.mjs.map +0 -1
- package/dist/ui/index.d.mts +0 -331
- package/dist/ui/index.d.ts +0 -331
- package/dist/ui/index.js +0 -16953
- package/dist/ui/index.js.map +0 -1
- package/dist/ui/index.mjs +0 -16598
- package/dist/ui/index.mjs.map +0 -1
- package/dist/ui/primitives/client.d.mts +0 -61
- package/dist/ui/primitives/client.d.ts +0 -61
- package/dist/ui/primitives/client.js +0 -3408
- package/dist/ui/primitives/client.js.map +0 -1
- package/dist/ui/primitives/client.mjs +0 -3256
- package/dist/ui/primitives/client.mjs.map +0 -1
- package/dist/ui/primitives.d.mts +0 -113
- package/dist/ui/primitives.d.ts +0 -113
- package/dist/ui/primitives.js +0 -3356
- package/dist/ui/primitives.js.map +0 -1
- package/dist/ui/primitives.mjs +0 -3227
- package/dist/ui/primitives.mjs.map +0 -1
- package/dist/user/index.d.mts +0 -228
- package/dist/user/index.d.ts +0 -228
- package/dist/user/index.js +0 -4306
- package/dist/user/index.js.map +0 -1
- package/dist/user/index.mjs +0 -4260
- package/dist/user/index.mjs.map +0 -1
- package/dist/utils/index.d.mts +0 -205
- package/dist/utils/index.d.ts +0 -205
- package/dist/utils/index.js +0 -574
- package/dist/utils/index.js.map +0 -1
- package/dist/utils/index.mjs +0 -514
- package/dist/utils/index.mjs.map +0 -1
- package/dist/workflow/index.d.mts +0 -40
- package/dist/workflow/index.d.ts +0 -40
- package/dist/workflow/index.js +0 -3710
- package/dist/workflow/index.js.map +0 -1
- package/dist/workflow/index.mjs +0 -3677
- package/dist/workflow/index.mjs.map +0 -1
|
@@ -1,619 +0,0 @@
|
|
|
1
|
-
// src/infrastructure/logger/logger.ts
|
|
2
|
-
var LOG_LEVELS = {
|
|
3
|
-
trace: 0,
|
|
4
|
-
debug: 1,
|
|
5
|
-
info: 2,
|
|
6
|
-
warn: 3,
|
|
7
|
-
error: 4
|
|
8
|
-
};
|
|
9
|
-
function getLogLevel() {
|
|
10
|
-
const envLevel = process.env.LOG_LEVEL?.toLowerCase();
|
|
11
|
-
if (envLevel && LOG_LEVELS[envLevel] !== void 0) {
|
|
12
|
-
return envLevel;
|
|
13
|
-
}
|
|
14
|
-
return process.env.NODE_ENV === "production" ? "info" : "debug";
|
|
15
|
-
}
|
|
16
|
-
function formatMessage(level, name, message, context) {
|
|
17
|
-
const timestamp = (/* @__PURE__ */ new Date()).toISOString();
|
|
18
|
-
const contextStr = context ? ` ${JSON.stringify(context)}` : "";
|
|
19
|
-
return `${timestamp} [${level.toUpperCase()}] [${name}] ${message}${contextStr}`;
|
|
20
|
-
}
|
|
21
|
-
function shouldLog(level, minLevel) {
|
|
22
|
-
return LOG_LEVELS[level] >= LOG_LEVELS[minLevel];
|
|
23
|
-
}
|
|
24
|
-
var ConsoleLogger = class {
|
|
25
|
-
constructor(options = {}) {
|
|
26
|
-
this.name = options.name || "App";
|
|
27
|
-
this.level = options.level || getLogLevel();
|
|
28
|
-
}
|
|
29
|
-
trace(message, context) {
|
|
30
|
-
if (shouldLog("trace", this.level)) {
|
|
31
|
-
console.log(formatMessage("trace", this.name, message, context));
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
debug(message, context) {
|
|
35
|
-
if (shouldLog("debug", this.level)) {
|
|
36
|
-
console.log(formatMessage("debug", this.name, message, context));
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
info(message, context) {
|
|
40
|
-
if (shouldLog("info", this.level)) {
|
|
41
|
-
console.info(formatMessage("info", this.name, message, context));
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
warn(message, context) {
|
|
45
|
-
if (shouldLog("warn", this.level)) {
|
|
46
|
-
console.warn(formatMessage("warn", this.name, message, context));
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
error(message, context) {
|
|
50
|
-
if (shouldLog("error", this.level)) {
|
|
51
|
-
console.error(formatMessage("error", this.name, message, context));
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
};
|
|
55
|
-
function createLogger(nameOrOptions = {}) {
|
|
56
|
-
const options = typeof nameOrOptions === "string" ? { name: nameOrOptions } : nameOrOptions;
|
|
57
|
-
return new ConsoleLogger(options);
|
|
58
|
-
}
|
|
59
|
-
var logger = createLogger("App");
|
|
60
|
-
|
|
61
|
-
// src/infrastructure/cache/cache.ts
|
|
62
|
-
var MemoryCache = class {
|
|
63
|
-
constructor(options) {
|
|
64
|
-
this.store = /* @__PURE__ */ new Map();
|
|
65
|
-
this.name = options.name;
|
|
66
|
-
this.defaultTtl = options.ttl || 3600;
|
|
67
|
-
this.maxSize = options.max || 1e3;
|
|
68
|
-
this.prefix = options.prefix || "";
|
|
69
|
-
}
|
|
70
|
-
getFullKey(key) {
|
|
71
|
-
return this.prefix ? `${this.prefix}:${this.name}:${key}` : `${this.name}:${key}`;
|
|
72
|
-
}
|
|
73
|
-
isExpired(entry) {
|
|
74
|
-
if (entry.expireAt === null) return false;
|
|
75
|
-
return Date.now() > entry.expireAt;
|
|
76
|
-
}
|
|
77
|
-
cleanup() {
|
|
78
|
-
for (const [key, entry] of this.store.entries()) {
|
|
79
|
-
if (this.isExpired(entry)) {
|
|
80
|
-
this.store.delete(key);
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
async get(key) {
|
|
85
|
-
const fullKey = this.getFullKey(key);
|
|
86
|
-
const entry = this.store.get(fullKey);
|
|
87
|
-
if (!entry) return void 0;
|
|
88
|
-
if (this.isExpired(entry)) {
|
|
89
|
-
this.store.delete(fullKey);
|
|
90
|
-
return void 0;
|
|
91
|
-
}
|
|
92
|
-
return entry.value;
|
|
93
|
-
}
|
|
94
|
-
async set(key, value, ttl) {
|
|
95
|
-
const fullKey = this.getFullKey(key);
|
|
96
|
-
const ttlSeconds = ttl ?? this.defaultTtl;
|
|
97
|
-
if (this.store.size >= this.maxSize) {
|
|
98
|
-
this.cleanup();
|
|
99
|
-
if (this.store.size >= this.maxSize) {
|
|
100
|
-
const firstKey = this.store.keys().next().value;
|
|
101
|
-
if (firstKey) this.store.delete(firstKey);
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
this.store.set(fullKey, {
|
|
105
|
-
value,
|
|
106
|
-
expireAt: ttlSeconds > 0 ? Date.now() + ttlSeconds * 1e3 : null
|
|
107
|
-
});
|
|
108
|
-
}
|
|
109
|
-
async del(key) {
|
|
110
|
-
const fullKey = this.getFullKey(key);
|
|
111
|
-
this.store.delete(fullKey);
|
|
112
|
-
}
|
|
113
|
-
async has(key) {
|
|
114
|
-
const value = await this.get(key);
|
|
115
|
-
return value !== void 0;
|
|
116
|
-
}
|
|
117
|
-
async reset() {
|
|
118
|
-
const prefix = this.getFullKey("");
|
|
119
|
-
for (const key of this.store.keys()) {
|
|
120
|
-
if (key.startsWith(prefix)) {
|
|
121
|
-
this.store.delete(key);
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
async keys() {
|
|
126
|
-
this.cleanup();
|
|
127
|
-
const prefix = this.getFullKey("");
|
|
128
|
-
const result = [];
|
|
129
|
-
for (const key of this.store.keys()) {
|
|
130
|
-
if (key.startsWith(prefix)) {
|
|
131
|
-
result.push(key.slice(prefix.length));
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
return result;
|
|
135
|
-
}
|
|
136
|
-
/** Get cache info for admin dashboard */
|
|
137
|
-
getInfo() {
|
|
138
|
-
return {
|
|
139
|
-
name: this.name,
|
|
140
|
-
ttl: this.defaultTtl,
|
|
141
|
-
maxSize: this.maxSize
|
|
142
|
-
};
|
|
143
|
-
}
|
|
144
|
-
};
|
|
145
|
-
|
|
146
|
-
// src/infrastructure/cache/cache-manager.ts
|
|
147
|
-
var CacheManagerImpl = class {
|
|
148
|
-
constructor(options = {}) {
|
|
149
|
-
this.caches = /* @__PURE__ */ new Map();
|
|
150
|
-
this.options = {
|
|
151
|
-
defaultTtl: options.defaultTtl || 3600,
|
|
152
|
-
prefix: options.prefix || ""
|
|
153
|
-
};
|
|
154
|
-
}
|
|
155
|
-
create(options) {
|
|
156
|
-
const existing = this.caches.get(options.name);
|
|
157
|
-
if (existing) {
|
|
158
|
-
return existing;
|
|
159
|
-
}
|
|
160
|
-
const cache = new MemoryCache({
|
|
161
|
-
...options,
|
|
162
|
-
ttl: options.ttl || this.options.defaultTtl,
|
|
163
|
-
prefix: this.options.prefix
|
|
164
|
-
});
|
|
165
|
-
this.caches.set(options.name, cache);
|
|
166
|
-
return cache;
|
|
167
|
-
}
|
|
168
|
-
get(name) {
|
|
169
|
-
return this.caches.get(name);
|
|
170
|
-
}
|
|
171
|
-
async flushAll() {
|
|
172
|
-
const promises = [];
|
|
173
|
-
for (const cache of this.caches.values()) {
|
|
174
|
-
promises.push(cache.reset());
|
|
175
|
-
}
|
|
176
|
-
await Promise.all(promises);
|
|
177
|
-
}
|
|
178
|
-
/** Get all cache names */
|
|
179
|
-
getAllCaches() {
|
|
180
|
-
return Array.from(this.caches.keys());
|
|
181
|
-
}
|
|
182
|
-
/** Get stats for all caches (for admin dashboard) */
|
|
183
|
-
async getStats() {
|
|
184
|
-
const stats = [];
|
|
185
|
-
for (const [name, cache] of this.caches.entries()) {
|
|
186
|
-
const keys = await cache.keys();
|
|
187
|
-
stats.push({
|
|
188
|
-
name,
|
|
189
|
-
itemCount: keys.length,
|
|
190
|
-
ttl: cache.getInfo().ttl
|
|
191
|
-
});
|
|
192
|
-
}
|
|
193
|
-
return stats;
|
|
194
|
-
}
|
|
195
|
-
/** Clear a specific cache by name */
|
|
196
|
-
async clearCache(name) {
|
|
197
|
-
const cache = this.caches.get(name);
|
|
198
|
-
if (cache) {
|
|
199
|
-
await cache.reset();
|
|
200
|
-
return true;
|
|
201
|
-
}
|
|
202
|
-
return false;
|
|
203
|
-
}
|
|
204
|
-
};
|
|
205
|
-
var globalForCache = globalThis;
|
|
206
|
-
var cacheManager = globalForCache.coreCacheManager ?? new CacheManagerImpl();
|
|
207
|
-
if (process.env.NODE_ENV !== "production") {
|
|
208
|
-
globalForCache.coreCacheManager = cacheManager;
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
// src/infrastructure/event-bus/event-bus.ts
|
|
212
|
-
var logger2 = createLogger("EventBus");
|
|
213
|
-
var EventBusImpl = class {
|
|
214
|
-
constructor() {
|
|
215
|
-
this.handlers = /* @__PURE__ */ new Map();
|
|
216
|
-
this.onceHandlers = /* @__PURE__ */ new Map();
|
|
217
|
-
}
|
|
218
|
-
on(event, handler) {
|
|
219
|
-
if (!this.handlers.has(event)) {
|
|
220
|
-
this.handlers.set(event, /* @__PURE__ */ new Set());
|
|
221
|
-
}
|
|
222
|
-
this.handlers.get(event).add(handler);
|
|
223
|
-
logger2.debug(`Subscribed to event: ${event}`);
|
|
224
|
-
return {
|
|
225
|
-
unsubscribe: () => {
|
|
226
|
-
this.handlers.get(event)?.delete(handler);
|
|
227
|
-
}
|
|
228
|
-
};
|
|
229
|
-
}
|
|
230
|
-
once(event, handler) {
|
|
231
|
-
if (!this.onceHandlers.has(event)) {
|
|
232
|
-
this.onceHandlers.set(event, /* @__PURE__ */ new Set());
|
|
233
|
-
}
|
|
234
|
-
this.onceHandlers.get(event).add(handler);
|
|
235
|
-
return {
|
|
236
|
-
unsubscribe: () => {
|
|
237
|
-
this.onceHandlers.get(event)?.delete(handler);
|
|
238
|
-
}
|
|
239
|
-
};
|
|
240
|
-
}
|
|
241
|
-
emit(event, data) {
|
|
242
|
-
logger2.debug(`Emitting event: ${event}`);
|
|
243
|
-
const handlers = this.handlers.get(event);
|
|
244
|
-
const onceHandlers = this.onceHandlers.get(event);
|
|
245
|
-
if (handlers) {
|
|
246
|
-
for (const handler of handlers) {
|
|
247
|
-
try {
|
|
248
|
-
handler(data);
|
|
249
|
-
} catch (error) {
|
|
250
|
-
logger2.error(`Error in event handler for ${event}`, {
|
|
251
|
-
error: String(error)
|
|
252
|
-
});
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
}
|
|
256
|
-
if (onceHandlers) {
|
|
257
|
-
for (const handler of onceHandlers) {
|
|
258
|
-
try {
|
|
259
|
-
handler(data);
|
|
260
|
-
} catch (error) {
|
|
261
|
-
logger2.error(`Error in once handler for ${event}`, {
|
|
262
|
-
error: String(error)
|
|
263
|
-
});
|
|
264
|
-
}
|
|
265
|
-
}
|
|
266
|
-
this.onceHandlers.delete(event);
|
|
267
|
-
}
|
|
268
|
-
}
|
|
269
|
-
async emitAsync(event, data) {
|
|
270
|
-
logger2.debug(`Emitting async event: ${event}`);
|
|
271
|
-
const handlers = this.handlers.get(event);
|
|
272
|
-
const onceHandlers = this.onceHandlers.get(event);
|
|
273
|
-
const promises = [];
|
|
274
|
-
if (handlers) {
|
|
275
|
-
for (const handler of handlers) {
|
|
276
|
-
promises.push(
|
|
277
|
-
Promise.resolve(handler(data)).catch((error) => {
|
|
278
|
-
logger2.error(`Error in async handler for ${event}`, {
|
|
279
|
-
error: String(error)
|
|
280
|
-
});
|
|
281
|
-
})
|
|
282
|
-
);
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
if (onceHandlers) {
|
|
286
|
-
for (const handler of onceHandlers) {
|
|
287
|
-
promises.push(
|
|
288
|
-
Promise.resolve(handler(data)).catch((error) => {
|
|
289
|
-
logger2.error(`Error in async once handler for ${event}`, {
|
|
290
|
-
error: String(error)
|
|
291
|
-
});
|
|
292
|
-
})
|
|
293
|
-
);
|
|
294
|
-
}
|
|
295
|
-
this.onceHandlers.delete(event);
|
|
296
|
-
}
|
|
297
|
-
await Promise.all(promises);
|
|
298
|
-
}
|
|
299
|
-
off(event) {
|
|
300
|
-
this.handlers.delete(event);
|
|
301
|
-
this.onceHandlers.delete(event);
|
|
302
|
-
logger2.debug(`Removed all handlers for event: ${event}`);
|
|
303
|
-
}
|
|
304
|
-
removeAllListeners() {
|
|
305
|
-
this.handlers.clear();
|
|
306
|
-
this.onceHandlers.clear();
|
|
307
|
-
logger2.debug("Removed all event listeners");
|
|
308
|
-
}
|
|
309
|
-
};
|
|
310
|
-
var eventBus = new EventBusImpl();
|
|
311
|
-
|
|
312
|
-
// src/infrastructure/cron/cron-manager.ts
|
|
313
|
-
var logger3 = createLogger("CronJobManager");
|
|
314
|
-
var SimpleCronJob = class {
|
|
315
|
-
constructor(options) {
|
|
316
|
-
this.intervalId = null;
|
|
317
|
-
this.running = false;
|
|
318
|
-
this.name = options.name;
|
|
319
|
-
this.cronTime = options.cronTime;
|
|
320
|
-
this.onTick = options.onTick;
|
|
321
|
-
this.intervalMs = this.parseInterval(options.cronTime);
|
|
322
|
-
if (options.start) {
|
|
323
|
-
this.start();
|
|
324
|
-
}
|
|
325
|
-
}
|
|
326
|
-
/**
|
|
327
|
-
* Parse simple cron expressions to interval
|
|
328
|
-
* Supports:
|
|
329
|
-
* - '* * * * *' - every minute
|
|
330
|
-
* - '0 * * * *' - every hour
|
|
331
|
-
* - '0 0 * * *' - every day at midnight
|
|
332
|
-
* - Also supports simple intervals: '5m', '1h', '1d'
|
|
333
|
-
*/
|
|
334
|
-
parseInterval(cronTime) {
|
|
335
|
-
const simpleMatch = cronTime.match(/^(\d+)([smhd])$/);
|
|
336
|
-
if (simpleMatch) {
|
|
337
|
-
const value = parseInt(simpleMatch[1], 10);
|
|
338
|
-
const unit = simpleMatch[2];
|
|
339
|
-
switch (unit) {
|
|
340
|
-
case "s":
|
|
341
|
-
return value * 1e3;
|
|
342
|
-
case "m":
|
|
343
|
-
return value * 60 * 1e3;
|
|
344
|
-
case "h":
|
|
345
|
-
return value * 60 * 60 * 1e3;
|
|
346
|
-
case "d":
|
|
347
|
-
return value * 24 * 60 * 60 * 1e3;
|
|
348
|
-
}
|
|
349
|
-
}
|
|
350
|
-
const parts = cronTime.split(" ");
|
|
351
|
-
if (parts.length >= 5) {
|
|
352
|
-
const [minute, hour, dayOfMonth, ,] = parts;
|
|
353
|
-
if (minute === "*" && hour === "*") {
|
|
354
|
-
return 60 * 1e3;
|
|
355
|
-
}
|
|
356
|
-
if (minute !== "*" && hour === "*") {
|
|
357
|
-
return 60 * 60 * 1e3;
|
|
358
|
-
}
|
|
359
|
-
if (minute !== "*" && hour !== "*" && dayOfMonth === "*") {
|
|
360
|
-
return 24 * 60 * 60 * 1e3;
|
|
361
|
-
}
|
|
362
|
-
}
|
|
363
|
-
logger3.warn(
|
|
364
|
-
`Could not parse cron expression "${cronTime}", defaulting to every minute`
|
|
365
|
-
);
|
|
366
|
-
return 60 * 1e3;
|
|
367
|
-
}
|
|
368
|
-
start() {
|
|
369
|
-
if (this.running) return;
|
|
370
|
-
logger3.info(`Starting cron job: ${this.name}`, {
|
|
371
|
-
interval: `${this.intervalMs}ms`
|
|
372
|
-
});
|
|
373
|
-
this.running = true;
|
|
374
|
-
this.intervalId = setInterval(async () => {
|
|
375
|
-
try {
|
|
376
|
-
await this.onTick();
|
|
377
|
-
} catch (error) {
|
|
378
|
-
logger3.error(`Cron job "${this.name}" failed`, {
|
|
379
|
-
error: String(error)
|
|
380
|
-
});
|
|
381
|
-
}
|
|
382
|
-
}, this.intervalMs);
|
|
383
|
-
}
|
|
384
|
-
stop() {
|
|
385
|
-
if (!this.running || !this.intervalId) return;
|
|
386
|
-
logger3.info(`Stopping cron job: ${this.name}`);
|
|
387
|
-
clearInterval(this.intervalId);
|
|
388
|
-
this.intervalId = null;
|
|
389
|
-
this.running = false;
|
|
390
|
-
}
|
|
391
|
-
isRunning() {
|
|
392
|
-
return this.running;
|
|
393
|
-
}
|
|
394
|
-
nextDate() {
|
|
395
|
-
if (!this.running) return null;
|
|
396
|
-
return new Date(Date.now() + this.intervalMs);
|
|
397
|
-
}
|
|
398
|
-
};
|
|
399
|
-
var CronJobManagerImpl = class {
|
|
400
|
-
constructor() {
|
|
401
|
-
this.jobs = /* @__PURE__ */ new Map();
|
|
402
|
-
}
|
|
403
|
-
addJob(options) {
|
|
404
|
-
if (this.jobs.has(options.name)) {
|
|
405
|
-
logger3.warn(`Job "${options.name}" already exists, removing old one`);
|
|
406
|
-
this.removeJob(options.name);
|
|
407
|
-
}
|
|
408
|
-
const job = new SimpleCronJob(options);
|
|
409
|
-
this.jobs.set(options.name, job);
|
|
410
|
-
logger3.info(`Added cron job: ${options.name}`, {
|
|
411
|
-
cronTime: options.cronTime
|
|
412
|
-
});
|
|
413
|
-
return job;
|
|
414
|
-
}
|
|
415
|
-
removeJob(name) {
|
|
416
|
-
const job = this.jobs.get(name);
|
|
417
|
-
if (job) {
|
|
418
|
-
job.stop();
|
|
419
|
-
this.jobs.delete(name);
|
|
420
|
-
logger3.info(`Removed cron job: ${name}`);
|
|
421
|
-
}
|
|
422
|
-
}
|
|
423
|
-
getJob(name) {
|
|
424
|
-
return this.jobs.get(name);
|
|
425
|
-
}
|
|
426
|
-
getAllJobs() {
|
|
427
|
-
return Array.from(this.jobs.values());
|
|
428
|
-
}
|
|
429
|
-
startAll() {
|
|
430
|
-
for (const job of this.jobs.values()) {
|
|
431
|
-
job.start();
|
|
432
|
-
}
|
|
433
|
-
logger3.info(`Started ${this.jobs.size} cron jobs`);
|
|
434
|
-
}
|
|
435
|
-
stopAll() {
|
|
436
|
-
for (const job of this.jobs.values()) {
|
|
437
|
-
job.stop();
|
|
438
|
-
}
|
|
439
|
-
logger3.info(`Stopped ${this.jobs.size} cron jobs`);
|
|
440
|
-
}
|
|
441
|
-
/** Get info for all jobs (for admin dashboard) */
|
|
442
|
-
getJobsInfo() {
|
|
443
|
-
const info = [];
|
|
444
|
-
for (const job of this.jobs.values()) {
|
|
445
|
-
info.push({
|
|
446
|
-
name: job.name,
|
|
447
|
-
cronTime: job.cronTime,
|
|
448
|
-
isRunning: job.isRunning(),
|
|
449
|
-
nextDate: job.nextDate()
|
|
450
|
-
});
|
|
451
|
-
}
|
|
452
|
-
return info;
|
|
453
|
-
}
|
|
454
|
-
/** Toggle a job on/off */
|
|
455
|
-
toggleJob(name) {
|
|
456
|
-
const job = this.jobs.get(name);
|
|
457
|
-
if (!job) return false;
|
|
458
|
-
if (job.isRunning()) {
|
|
459
|
-
job.stop();
|
|
460
|
-
} else {
|
|
461
|
-
job.start();
|
|
462
|
-
}
|
|
463
|
-
return true;
|
|
464
|
-
}
|
|
465
|
-
};
|
|
466
|
-
var cronJobManager = new CronJobManagerImpl();
|
|
467
|
-
|
|
468
|
-
// src/infrastructure/api-service.ts
|
|
469
|
-
var APIService = class {
|
|
470
|
-
constructor(baseURL, options = {}) {
|
|
471
|
-
this.baseURL = baseURL;
|
|
472
|
-
this.options = options;
|
|
473
|
-
}
|
|
474
|
-
// --------------------------------------------------------
|
|
475
|
-
// Core HTTP Methods
|
|
476
|
-
// --------------------------------------------------------
|
|
477
|
-
/**
|
|
478
|
-
* Makes a GET request to the specified endpoint
|
|
479
|
-
*/
|
|
480
|
-
async get(endpoint = "", config = {}) {
|
|
481
|
-
const url = this.buildURL(endpoint, config.params);
|
|
482
|
-
return this.request("GET", url, void 0, config);
|
|
483
|
-
}
|
|
484
|
-
/**
|
|
485
|
-
* Makes a POST request with JSON body
|
|
486
|
-
*/
|
|
487
|
-
async post(endpoint = "", data, config = {}) {
|
|
488
|
-
const url = this.buildURL(endpoint);
|
|
489
|
-
return this.request("POST", url, data, config);
|
|
490
|
-
}
|
|
491
|
-
/**
|
|
492
|
-
* Makes a PUT request with JSON body
|
|
493
|
-
*/
|
|
494
|
-
async put(endpoint = "", data, config = {}) {
|
|
495
|
-
const url = this.buildURL(endpoint);
|
|
496
|
-
return this.request("PUT", url, data, config);
|
|
497
|
-
}
|
|
498
|
-
/**
|
|
499
|
-
* Makes a PATCH request with JSON body
|
|
500
|
-
*/
|
|
501
|
-
async patch(endpoint = "", data, config = {}) {
|
|
502
|
-
const url = this.buildURL(endpoint);
|
|
503
|
-
return this.request("PATCH", url, data, config);
|
|
504
|
-
}
|
|
505
|
-
/**
|
|
506
|
-
* Makes a DELETE request
|
|
507
|
-
*/
|
|
508
|
-
async delete(endpoint = "", data, config = {}) {
|
|
509
|
-
const url = this.buildURL(endpoint);
|
|
510
|
-
return this.request("DELETE", url, data, config);
|
|
511
|
-
}
|
|
512
|
-
// --------------------------------------------------------
|
|
513
|
-
// Internal Helpers
|
|
514
|
-
// --------------------------------------------------------
|
|
515
|
-
/**
|
|
516
|
-
* Build full URL with query params
|
|
517
|
-
*/
|
|
518
|
-
buildURL(endpoint, params) {
|
|
519
|
-
const url = `${this.baseURL}${endpoint}`;
|
|
520
|
-
if (!params || Object.keys(params).length === 0) return url;
|
|
521
|
-
const searchParams = new URLSearchParams();
|
|
522
|
-
for (const [key, value] of Object.entries(params)) {
|
|
523
|
-
if (value !== void 0 && value !== null && value !== "") {
|
|
524
|
-
searchParams.append(key, String(value));
|
|
525
|
-
}
|
|
526
|
-
}
|
|
527
|
-
const queryString = searchParams.toString();
|
|
528
|
-
return queryString ? `${url}?${queryString}` : url;
|
|
529
|
-
}
|
|
530
|
-
/**
|
|
531
|
-
* Core request method — all HTTP methods funnel through here.
|
|
532
|
-
* Handles: headers, body, timeout, error handling, 401 redirect.
|
|
533
|
-
*/
|
|
534
|
-
async request(method, url, data, config = {}) {
|
|
535
|
-
this.options.onRequest?.(method, url);
|
|
536
|
-
const headers = {
|
|
537
|
-
"Content-Type": "application/json",
|
|
538
|
-
...this.options.defaultHeaders,
|
|
539
|
-
...config.headers
|
|
540
|
-
};
|
|
541
|
-
const fetchOptions = {
|
|
542
|
-
method,
|
|
543
|
-
headers,
|
|
544
|
-
credentials: "include",
|
|
545
|
-
// Send cookies (same as axios withCredentials)
|
|
546
|
-
signal: config.signal
|
|
547
|
-
};
|
|
548
|
-
if (data !== void 0 && method !== "GET") {
|
|
549
|
-
fetchOptions.body = JSON.stringify(data);
|
|
550
|
-
}
|
|
551
|
-
try {
|
|
552
|
-
const response = await fetch(url, fetchOptions);
|
|
553
|
-
this.options.onResponse?.(method, url, response.status);
|
|
554
|
-
if (response.status === 401) {
|
|
555
|
-
const error = {
|
|
556
|
-
message: "Unauthorized",
|
|
557
|
-
status: 401,
|
|
558
|
-
code: "UNAUTHORIZED"
|
|
559
|
-
};
|
|
560
|
-
this.options.onUnauthorized?.();
|
|
561
|
-
this.options.onError?.(error);
|
|
562
|
-
throw error;
|
|
563
|
-
}
|
|
564
|
-
if (!response.ok) {
|
|
565
|
-
let errorBody;
|
|
566
|
-
try {
|
|
567
|
-
errorBody = await response.json();
|
|
568
|
-
} catch {
|
|
569
|
-
errorBody = await response.text();
|
|
570
|
-
}
|
|
571
|
-
const error = {
|
|
572
|
-
message: typeof errorBody === "object" && errorBody !== null && "message" in errorBody ? String(errorBody.message) : `HTTP Error ${response.status}`,
|
|
573
|
-
status: response.status,
|
|
574
|
-
code: typeof errorBody === "object" && errorBody !== null && "code" in errorBody ? String(errorBody.code) : void 0,
|
|
575
|
-
details: errorBody
|
|
576
|
-
};
|
|
577
|
-
this.options.onError?.(error);
|
|
578
|
-
throw error;
|
|
579
|
-
}
|
|
580
|
-
if (response.status === 204) {
|
|
581
|
-
return void 0;
|
|
582
|
-
}
|
|
583
|
-
const responseData = await response.json();
|
|
584
|
-
return responseData;
|
|
585
|
-
} catch (error) {
|
|
586
|
-
if (this.isAPIError(error)) {
|
|
587
|
-
throw error;
|
|
588
|
-
}
|
|
589
|
-
const apiError = {
|
|
590
|
-
message: error instanceof Error ? error.message : "Network error",
|
|
591
|
-
status: 0,
|
|
592
|
-
code: "NETWORK_ERROR"
|
|
593
|
-
};
|
|
594
|
-
this.options.onError?.(apiError);
|
|
595
|
-
throw apiError;
|
|
596
|
-
}
|
|
597
|
-
}
|
|
598
|
-
/**
|
|
599
|
-
* Type guard for APIError
|
|
600
|
-
*/
|
|
601
|
-
isAPIError(error) {
|
|
602
|
-
return typeof error === "object" && error !== null && "message" in error && "status" in error;
|
|
603
|
-
}
|
|
604
|
-
};
|
|
605
|
-
var defaultClientOptions = {
|
|
606
|
-
onUnauthorized: () => {
|
|
607
|
-
if (typeof window !== "undefined") {
|
|
608
|
-
const currentPath = window.location.pathname;
|
|
609
|
-
window.location.replace(`/login?next_path=${encodeURIComponent(currentPath)}`);
|
|
610
|
-
}
|
|
611
|
-
}
|
|
612
|
-
};
|
|
613
|
-
function isAPIError(error) {
|
|
614
|
-
return typeof error === "object" && error !== null && "message" in error && "status" in error && typeof error.status === "number";
|
|
615
|
-
}
|
|
616
|
-
|
|
617
|
-
export { APIService, CacheManagerImpl, CronJobManagerImpl, EventBusImpl, MemoryCache, SimpleCronJob, cacheManager, createLogger, cronJobManager, defaultClientOptions, eventBus, isAPIError, logger };
|
|
618
|
-
//# sourceMappingURL=index.mjs.map
|
|
619
|
-
//# sourceMappingURL=index.mjs.map
|