@xylex-group/athena 0.1.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.
package/dist/react.mjs ADDED
@@ -0,0 +1,279 @@
1
+ import { useState, useMemo, useCallback } from 'react';
2
+
3
+ // src/gateway/use-athena-gateway.ts
4
+
5
+ // src/gateway/client.ts
6
+ var DEFAULT_BASE_URL = "https://athena-db.com";
7
+ var DEFAULT_CLIENT = "railway_direct";
8
+ function parseResponseText(text) {
9
+ if (!text) return null;
10
+ try {
11
+ return JSON.parse(text);
12
+ } catch {
13
+ return text;
14
+ }
15
+ }
16
+ function normalizeHeaderValue(value) {
17
+ return value ? value : void 0;
18
+ }
19
+ function buildHeaders(config, options) {
20
+ const mergedStripNulls = options?.stripNulls ?? config.stripNulls ?? true;
21
+ const finalClient = options?.client ?? config.client ?? DEFAULT_CLIENT;
22
+ const finalApiKey = options?.apiKey ?? config.apiKey;
23
+ const finalSupabaseUrl = options?.supabaseUrl ?? config.supabaseUrl;
24
+ const finalSupabaseKey = options?.supabaseKey ?? config.supabaseKey;
25
+ const finalPublishEvent = options?.publishEvent ?? config.publishEvent;
26
+ const extraHeaders = {
27
+ ...config.headers ?? {},
28
+ ...options?.headers ?? {}
29
+ };
30
+ const headers = {
31
+ "Content-Type": "application/json"
32
+ };
33
+ if (options?.userId ?? config.userId) {
34
+ headers["X-User-Id"] = options?.userId ?? config.userId ?? "";
35
+ }
36
+ if (options?.companyId ?? config.companyId) {
37
+ headers["X-Company-Id"] = options?.companyId ?? config.companyId ?? "";
38
+ }
39
+ if (options?.organizationId ?? config.organizationId) {
40
+ headers["X-Organization-Id"] = options?.organizationId ?? config.organizationId ?? "";
41
+ }
42
+ if (finalClient) {
43
+ headers["X-Athena-Client"] = finalClient;
44
+ }
45
+ if (typeof mergedStripNulls === "boolean") {
46
+ headers["X-Strip-Nulls"] = mergedStripNulls ? "true" : "false";
47
+ }
48
+ if (finalPublishEvent) {
49
+ headers["X-Publish-Event"] = finalPublishEvent;
50
+ }
51
+ if (finalApiKey) {
52
+ headers["apikey"] = finalApiKey;
53
+ headers["x-api-key"] = headers["x-api-key"] ?? finalApiKey;
54
+ }
55
+ if (finalSupabaseUrl) {
56
+ headers["x-supabase-url"] = finalSupabaseUrl;
57
+ }
58
+ if (finalSupabaseKey) {
59
+ headers["x-supabase-key"] = finalSupabaseKey;
60
+ }
61
+ Object.entries(extraHeaders).forEach(([key, value]) => {
62
+ const normalized = normalizeHeaderValue(value);
63
+ if (normalized) {
64
+ headers[key] = normalized;
65
+ }
66
+ });
67
+ return headers;
68
+ }
69
+ async function callAthena(config, endpoint, method, payload, options) {
70
+ const baseUrl = (options?.baseUrl ?? config.baseUrl ?? DEFAULT_BASE_URL).replace(/\/$/, "");
71
+ const url = `${baseUrl}${endpoint}`;
72
+ const headers = buildHeaders(config, options);
73
+ try {
74
+ const response = await fetch(url, {
75
+ method,
76
+ headers,
77
+ body: JSON.stringify(payload)
78
+ });
79
+ const rawText = await response.text();
80
+ const parsed = parseResponseText(rawText ?? "");
81
+ const parsedPayload = parsed;
82
+ const parsedError = parsedPayload && typeof parsedPayload === "object" ? parsedPayload.error ?? parsedPayload.message : void 0;
83
+ const hasError = typeof parsedError === "string" && parsedError.length > 0 ? parsedError : void 0;
84
+ return {
85
+ ok: response.ok,
86
+ status: response.status,
87
+ data: parsed ?? null,
88
+ error: hasError,
89
+ raw: parsed
90
+ };
91
+ } catch (callError) {
92
+ const message = callError instanceof Error ? callError.message : String(callError);
93
+ return {
94
+ ok: false,
95
+ status: 0,
96
+ data: null,
97
+ error: message,
98
+ raw: null
99
+ };
100
+ }
101
+ }
102
+ function createAthenaGatewayClient(config = {}) {
103
+ return {
104
+ baseUrl: (config.baseUrl ?? DEFAULT_BASE_URL).replace(/\/$/, ""),
105
+ buildHeaders(options) {
106
+ return buildHeaders(config, options);
107
+ },
108
+ fetchGateway(payload, options) {
109
+ return callAthena(config, "/gateway/fetch", "POST", payload, options);
110
+ },
111
+ insertGateway(payload, options) {
112
+ return callAthena(config, "/gateway/insert", "PUT", payload, options);
113
+ },
114
+ updateGateway(payload, options) {
115
+ return callAthena(config, "/gateway/update", "POST", payload, options);
116
+ },
117
+ deleteGateway(payload, options) {
118
+ return callAthena(config, "/gateway/delete", "DELETE", payload, options);
119
+ }
120
+ };
121
+ }
122
+
123
+ // src/gateway/use-athena-gateway.ts
124
+ function useAthenaGateway(config) {
125
+ const [isLoading, setIsLoading] = useState(false);
126
+ const [error, setError] = useState(null);
127
+ const [lastRequest, setLastRequest] = useState(
128
+ null
129
+ );
130
+ const [lastResponse, setLastResponse] = useState(null);
131
+ const client = useMemo(
132
+ () => createAthenaGatewayClient({
133
+ client: config?.client,
134
+ baseUrl: config?.baseUrl,
135
+ apiKey: config?.apiKey,
136
+ supabaseUrl: config?.supabaseUrl,
137
+ supabaseKey: config?.supabaseKey,
138
+ publishEvent: config?.publishEvent,
139
+ stripNulls: config?.stripNulls,
140
+ headers: config?.headers,
141
+ userId: config?.userId,
142
+ companyId: config?.companyId,
143
+ organizationId: config?.organizationId
144
+ }),
145
+ [
146
+ config?.baseUrl,
147
+ config?.client,
148
+ config?.apiKey,
149
+ config?.supabaseUrl,
150
+ config?.supabaseKey,
151
+ config?.publishEvent,
152
+ config?.stripNulls,
153
+ config?.headers,
154
+ config?.userId,
155
+ config?.companyId,
156
+ config?.organizationId
157
+ ]
158
+ );
159
+ const callWithLifecycle = useCallback(
160
+ async (fn, metadata) => {
161
+ const requestLog = {
162
+ endpoint: metadata.endpoint,
163
+ method: metadata.method,
164
+ payload: metadata.payload,
165
+ headers: client.buildHeaders(metadata.options),
166
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
167
+ };
168
+ setLastRequest(requestLog);
169
+ setIsLoading(true);
170
+ setError(null);
171
+ let response;
172
+ try {
173
+ response = await fn();
174
+ setLastResponse({ ...response, timestamp: (/* @__PURE__ */ new Date()).toISOString() });
175
+ if (!response.ok) {
176
+ const message = response.error || `Athena gateway ${metadata.method} ${metadata.endpoint} failed`;
177
+ setError(message);
178
+ throw new Error(message);
179
+ }
180
+ return response;
181
+ } catch (callError) {
182
+ const message = callError instanceof Error ? callError.message : String(callError);
183
+ setError(message);
184
+ setLastResponse({
185
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
186
+ status: response?.status ?? 0,
187
+ ok: false,
188
+ data: null,
189
+ raw: null,
190
+ error: message
191
+ });
192
+ throw callError;
193
+ } finally {
194
+ setIsLoading(false);
195
+ }
196
+ },
197
+ [client]
198
+ );
199
+ const normalizedConfigStripNulls = useMemo(
200
+ () => config?.stripNulls ?? true,
201
+ [config?.stripNulls]
202
+ );
203
+ const fetchGateway = useCallback(
204
+ (payload, options) => {
205
+ const normalizedPayload = {
206
+ ...payload,
207
+ conditions: payload.conditions ?? [],
208
+ strip_nulls: payload.strip_nulls ?? options?.stripNulls ?? normalizedConfigStripNulls
209
+ };
210
+ return callWithLifecycle(
211
+ () => client.fetchGateway(normalizedPayload, options),
212
+ {
213
+ endpoint: "/gateway/fetch",
214
+ method: "POST",
215
+ payload: normalizedPayload,
216
+ options
217
+ }
218
+ );
219
+ },
220
+ [callWithLifecycle, client, normalizedConfigStripNulls]
221
+ );
222
+ const insertGateway = useCallback(
223
+ (payload, options) => callWithLifecycle(() => client.insertGateway(payload, options), {
224
+ endpoint: "/gateway/insert",
225
+ method: "PUT",
226
+ payload,
227
+ options
228
+ }),
229
+ [callWithLifecycle, client]
230
+ );
231
+ const updateGateway = useCallback(
232
+ (payload, options) => {
233
+ const normalizedPayload = {
234
+ ...payload,
235
+ conditions: payload.conditions ?? [],
236
+ strip_nulls: payload.strip_nulls ?? options?.stripNulls ?? normalizedConfigStripNulls
237
+ };
238
+ return callWithLifecycle(
239
+ () => client.updateGateway(normalizedPayload, options),
240
+ {
241
+ endpoint: "/gateway/update",
242
+ method: "POST",
243
+ payload: normalizedPayload,
244
+ options
245
+ }
246
+ );
247
+ },
248
+ [callWithLifecycle, client, normalizedConfigStripNulls]
249
+ );
250
+ const deleteGateway = useCallback(
251
+ (payload, options) => {
252
+ if (!payload.resource_id) {
253
+ throw new Error(
254
+ "deleteGateway requires resource_id (the unique identifier of the record to delete)"
255
+ );
256
+ }
257
+ return callWithLifecycle(
258
+ () => client.deleteGateway(payload, options),
259
+ { endpoint: "/gateway/delete", method: "DELETE", payload, options }
260
+ );
261
+ },
262
+ [callWithLifecycle, client]
263
+ );
264
+ return {
265
+ fetchGateway,
266
+ insertGateway,
267
+ updateGateway,
268
+ deleteGateway,
269
+ isLoading,
270
+ error,
271
+ lastRequest,
272
+ lastResponse,
273
+ baseUrl: client.baseUrl
274
+ };
275
+ }
276
+
277
+ export { useAthenaGateway };
278
+ //# sourceMappingURL=react.mjs.map
279
+ //# sourceMappingURL=react.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/gateway/client.ts","../src/gateway/use-athena-gateway.ts"],"names":[],"mappings":";;;;;AAcA,IAAM,gBAAA,GAAmB,uBAAA;AACzB,IAAM,cAAA,GAAiB,gBAAA;AAEvB,SAAS,kBAAkB,IAAA,EAAc;AACvC,EAAA,IAAI,CAAC,MAAM,OAAO,IAAA;AAClB,EAAA,IAAI;AACF,IAAA,OAAO,IAAA,CAAK,MAAM,IAAI,CAAA;AAAA,EACxB,CAAA,CAAA,MAAQ;AACN,IAAA,OAAO,IAAA;AAAA,EACT;AACF;AAEA,SAAS,qBAAqB,KAAA,EAAuB;AACnD,EAAA,OAAO,QAAQ,KAAA,GAAQ,MAAA;AACzB;AAEA,SAAS,YAAA,CACP,QACA,OAAA,EACwB;AACxB,EAAA,MAAM,gBAAA,GAAmB,OAAA,EAAS,UAAA,IAAc,MAAA,CAAO,UAAA,IAAc,IAAA;AACrE,EAAA,MAAM,WAAA,GAAc,OAAA,EAAS,MAAA,IAAU,MAAA,CAAO,MAAA,IAAU,cAAA;AACxD,EAAA,MAAM,WAAA,GAAc,OAAA,EAAS,MAAA,IAAU,MAAA,CAAO,MAAA;AAC9C,EAAA,MAAM,gBAAA,GAAmB,OAAA,EAAS,WAAA,IAAe,MAAA,CAAO,WAAA;AACxD,EAAA,MAAM,gBAAA,GAAmB,OAAA,EAAS,WAAA,IAAe,MAAA,CAAO,WAAA;AACxD,EAAA,MAAM,iBAAA,GAAoB,OAAA,EAAS,YAAA,IAAgB,MAAA,CAAO,YAAA;AAC1D,EAAA,MAAM,YAAA,GAAe;AAAA,IACnB,GAAI,MAAA,CAAO,OAAA,IAAW,EAAC;AAAA,IACvB,GAAI,OAAA,EAAS,OAAA,IAAW;AAAC,GAC3B;AAEA,EAAA,MAAM,OAAA,GAAkC;AAAA,IACtC,cAAA,EAAgB;AAAA,GAClB;AAEA,EAAA,IAAI,OAAA,EAAS,MAAA,IAAU,MAAA,CAAO,MAAA,EAAQ;AACpC,IAAA,OAAA,CAAQ,WAAW,CAAA,GAAI,OAAA,EAAS,MAAA,IAAU,OAAO,MAAA,IAAU,EAAA;AAAA,EAC7D;AAEA,EAAA,IAAI,OAAA,EAAS,SAAA,IAAa,MAAA,CAAO,SAAA,EAAW;AAC1C,IAAA,OAAA,CAAQ,cAAc,CAAA,GAAI,OAAA,EAAS,SAAA,IAAa,OAAO,SAAA,IAAa,EAAA;AAAA,EACtE;AAEA,EAAA,IAAI,OAAA,EAAS,cAAA,IAAkB,MAAA,CAAO,cAAA,EAAgB;AACpD,IAAA,OAAA,CAAQ,mBAAmB,CAAA,GAAI,OAAA,EAAS,cAAA,IAAkB,OAAO,cAAA,IAAkB,EAAA;AAAA,EACrF;AAEA,EAAA,IAAI,WAAA,EAAa;AACf,IAAA,OAAA,CAAQ,iBAAiB,CAAA,GAAI,WAAA;AAAA,EAC/B;AAEA,EAAA,IAAI,OAAO,qBAAqB,SAAA,EAAW;AACzC,IAAA,OAAA,CAAQ,eAAe,CAAA,GAAI,gBAAA,GAAmB,MAAA,GAAS,OAAA;AAAA,EACzD;AAEA,EAAA,IAAI,iBAAA,EAAmB;AACrB,IAAA,OAAA,CAAQ,iBAAiB,CAAA,GAAI,iBAAA;AAAA,EAC/B;AAEA,EAAA,IAAI,WAAA,EAAa;AACf,IAAA,OAAA,CAAQ,QAAQ,CAAA,GAAI,WAAA;AACpB,IAAA,OAAA,CAAQ,WAAW,CAAA,GAAI,OAAA,CAAQ,WAAW,CAAA,IAAK,WAAA;AAAA,EACjD;AAEA,EAAA,IAAI,gBAAA,EAAkB;AACpB,IAAA,OAAA,CAAQ,gBAAgB,CAAA,GAAI,gBAAA;AAAA,EAC9B;AAEA,EAAA,IAAI,gBAAA,EAAkB;AACpB,IAAA,OAAA,CAAQ,gBAAgB,CAAA,GAAI,gBAAA;AAAA,EAC9B;AAEA,EAAA,MAAA,CAAO,OAAA,CAAQ,YAAY,CAAA,CAAE,OAAA,CAAQ,CAAC,CAAC,GAAA,EAAK,KAAK,CAAA,KAAM;AACrD,IAAA,MAAM,UAAA,GAAa,qBAAqB,KAAK,CAAA;AAC7C,IAAA,IAAI,UAAA,EAAY;AACd,MAAA,OAAA,CAAQ,GAAG,CAAA,GAAI,UAAA;AAAA,IACjB;AAAA,EACF,CAAC,CAAA;AAED,EAAA,OAAO,OAAA;AACT;AAEA,eAAe,UAAA,CACb,MAAA,EACA,QAAA,EACA,MAAA,EACA,SACA,OAAA,EACmC;AACnC,EAAA,MAAM,OAAA,GAAA,CAAW,SAAS,OAAA,IAAW,MAAA,CAAO,WAAW,gBAAA,EAAkB,OAAA,CAAQ,OAAO,EAAE,CAAA;AAC1F,EAAA,MAAM,GAAA,GAAM,CAAA,EAAG,OAAO,CAAA,EAAG,QAAQ,CAAA,CAAA;AACjC,EAAA,MAAM,OAAA,GAAU,YAAA,CAAa,MAAA,EAAQ,OAAO,CAAA;AAE5C,EAAA,IAAI;AACF,IAAA,MAAM,QAAA,GAAW,MAAM,KAAA,CAAM,GAAA,EAAK;AAAA,MAChC,MAAA;AAAA,MACA,OAAA;AAAA,MACA,IAAA,EAAM,IAAA,CAAK,SAAA,CAAU,OAAO;AAAA,KAC7B,CAAA;AAED,IAAA,MAAM,OAAA,GAAU,MAAM,QAAA,CAAS,IAAA,EAAK;AACpC,IAAA,MAAM,MAAA,GAAS,iBAAA,CAAkB,OAAA,IAAW,EAAE,CAAA;AAC9C,IAAA,MAAM,aAAA,GAAgB,MAAA;AACtB,IAAA,MAAM,WAAA,GACJ,iBAAiB,OAAO,aAAA,KAAkB,WACpC,aAAA,CAAc,KAAA,IAAiC,cAAc,OAAA,GAC/D,KAAA,CAAA;AACN,IAAA,MAAM,WAAW,OAAO,WAAA,KAAgB,YAAY,WAAA,CAAY,MAAA,GAAS,IAAI,WAAA,GAAc,KAAA,CAAA;AAE3F,IAAA,OAAO;AAAA,MACL,IAAI,QAAA,CAAS,EAAA;AAAA,MACb,QAAQ,QAAA,CAAS,MAAA;AAAA,MACjB,MAAO,MAAA,IAAgB,IAAA;AAAA,MACvB,KAAA,EAAO,QAAA;AAAA,MACP,GAAA,EAAK;AAAA,KACP;AAAA,EACF,SAAS,SAAA,EAAW;AAClB,IAAA,MAAM,UAAU,SAAA,YAAqB,KAAA,GAAQ,SAAA,CAAU,OAAA,GAAU,OAAO,SAAS,CAAA;AACjF,IAAA,OAAO;AAAA,MACL,EAAA,EAAI,KAAA;AAAA,MACJ,MAAA,EAAQ,CAAA;AAAA,MACR,IAAA,EAAM,IAAA;AAAA,MACN,KAAA,EAAO,OAAA;AAAA,MACP,GAAA,EAAK;AAAA,KACP;AAAA,EACF;AACF;AAWO,SAAS,yBAAA,CAA0B,MAAA,GAAmC,EAAC,EAAwB;AACpG,EAAA,OAAO;AAAA,IACL,UAAU,MAAA,CAAO,OAAA,IAAW,gBAAA,EAAkB,OAAA,CAAQ,OAAO,EAAE,CAAA;AAAA,IAC/D,aAAa,OAAA,EAAS;AACpB,MAAA,OAAO,YAAA,CAAa,QAAQ,OAAO,CAAA;AAAA,IACrC,CAAA;AAAA,IACA,YAAA,CAAa,SAAS,OAAA,EAAS;AAC7B,MAAA,OAAO,UAAA,CAAW,MAAA,EAAQ,gBAAA,EAAkB,MAAA,EAAQ,SAAS,OAAO,CAAA;AAAA,IACtE,CAAA;AAAA,IACA,aAAA,CAAc,SAAS,OAAA,EAAS;AAC9B,MAAA,OAAO,UAAA,CAAW,MAAA,EAAQ,iBAAA,EAAmB,KAAA,EAAO,SAAS,OAAO,CAAA;AAAA,IACtE,CAAA;AAAA,IACA,aAAA,CAAc,SAAS,OAAA,EAAS;AAC9B,MAAA,OAAO,UAAA,CAAW,MAAA,EAAQ,iBAAA,EAAmB,MAAA,EAAQ,SAAS,OAAO,CAAA;AAAA,IACvE,CAAA;AAAA,IACA,aAAA,CAAc,SAAS,OAAA,EAAS;AAC9B,MAAA,OAAO,UAAA,CAAW,MAAA,EAAQ,iBAAA,EAAmB,QAAA,EAAU,SAAS,OAAO,CAAA;AAAA,IACzE;AAAA,GACF;AACF;;;AC3JO,SAAS,iBACd,MAAA,EACyB;AACzB,EAAA,MAAM,CAAC,SAAA,EAAW,YAAY,CAAA,GAAI,SAAS,KAAK,CAAA;AAChD,EAAA,MAAM,CAAC,KAAA,EAAO,QAAQ,CAAA,GAAI,SAAwB,IAAI,CAAA;AACtD,EAAA,MAAM,CAAC,WAAA,EAAa,cAAc,CAAA,GAAI,QAAA;AAAA,IACpC;AAAA,GACF;AACA,EAAA,MAAM,CAAC,YAAA,EAAc,eAAe,CAAA,GAClC,SAA0C,IAAI,CAAA;AAEhD,EAAA,MAAM,MAAA,GAAS,OAAA;AAAA,IACb,MACE,yBAAA,CAA0B;AAAA,MACxB,QAAQ,MAAA,EAAQ,MAAA;AAAA,MAChB,SAAS,MAAA,EAAQ,OAAA;AAAA,MACjB,QAAQ,MAAA,EAAQ,MAAA;AAAA,MAChB,aAAa,MAAA,EAAQ,WAAA;AAAA,MACrB,aAAa,MAAA,EAAQ,WAAA;AAAA,MACrB,cAAc,MAAA,EAAQ,YAAA;AAAA,MACtB,YAAY,MAAA,EAAQ,UAAA;AAAA,MACpB,SAAS,MAAA,EAAQ,OAAA;AAAA,MACjB,QAAQ,MAAA,EAAQ,MAAA;AAAA,MAChB,WAAW,MAAA,EAAQ,SAAA;AAAA,MACnB,gBAAgB,MAAA,EAAQ;AAAA,KACzB,CAAA;AAAA,IACH;AAAA,MACE,MAAA,EAAQ,OAAA;AAAA,MACR,MAAA,EAAQ,MAAA;AAAA,MACR,MAAA,EAAQ,MAAA;AAAA,MACR,MAAA,EAAQ,WAAA;AAAA,MACR,MAAA,EAAQ,WAAA;AAAA,MACR,MAAA,EAAQ,YAAA;AAAA,MACR,MAAA,EAAQ,UAAA;AAAA,MACR,MAAA,EAAQ,OAAA;AAAA,MACR,MAAA,EAAQ,MAAA;AAAA,MACR,MAAA,EAAQ,SAAA;AAAA,MACR,MAAA,EAAQ;AAAA;AACV,GACF;AAEA,EAAA,MAAM,iBAAA,GAAoB,WAAA;AAAA,IACxB,OACE,IACA,QAAA,KAMsC;AACtC,MAAA,MAAM,UAAA,GAAmC;AAAA,QACvC,UAAU,QAAA,CAAS,QAAA;AAAA,QACnB,QAAQ,QAAA,CAAS,MAAA;AAAA,QACjB,SAAS,QAAA,CAAS,OAAA;AAAA,QAClB,OAAA,EAAS,MAAA,CAAO,YAAA,CAAa,QAAA,CAAS,OAAO,CAAA;AAAA,QAC7C,SAAA,EAAA,iBAAW,IAAI,IAAA,EAAK,EAAE,WAAA;AAAY,OACpC;AAEA,MAAA,cAAA,CAAe,UAAU,CAAA;AACzB,MAAA,YAAA,CAAa,IAAI,CAAA;AACjB,MAAA,QAAA,CAAS,IAAI,CAAA;AAEb,MAAA,IAAI,QAAA;AACJ,MAAA,IAAI;AACF,QAAA,QAAA,GAAW,MAAM,EAAA,EAAG;AACpB,QAAA,eAAA,CAAgB,EAAE,GAAG,QAAA,EAAU,SAAA,EAAA,qBAAe,IAAA,EAAK,EAAE,WAAA,EAAY,EAAG,CAAA;AAEpE,QAAA,IAAI,CAAC,SAAS,EAAA,EAAI;AAChB,UAAA,MAAM,OAAA,GACJ,SAAS,KAAA,IACT,CAAA,eAAA,EAAkB,SAAS,MAAM,CAAA,CAAA,EAAI,SAAS,QAAQ,CAAA,OAAA,CAAA;AACxD,UAAA,QAAA,CAAS,OAAO,CAAA;AAChB,UAAA,MAAM,IAAI,MAAM,OAAO,CAAA;AAAA,QACzB;AAEA,QAAA,OAAO,QAAA;AAAA,MACT,SAAS,SAAA,EAAW;AAClB,QAAA,MAAM,UACJ,SAAA,YAAqB,KAAA,GAAQ,SAAA,CAAU,OAAA,GAAU,OAAO,SAAS,CAAA;AACnE,QAAA,QAAA,CAAS,OAAO,CAAA;AAChB,QAAA,eAAA,CAAgB;AAAA,UACd,SAAA,EAAA,iBAAW,IAAI,IAAA,EAAK,EAAE,WAAA,EAAY;AAAA,UAClC,MAAA,EAAQ,UAAU,MAAA,IAAU,CAAA;AAAA,UAC5B,EAAA,EAAI,KAAA;AAAA,UACJ,IAAA,EAAM,IAAA;AAAA,UACN,GAAA,EAAK,IAAA;AAAA,UACL,KAAA,EAAO;AAAA,SACR,CAAA;AACD,QAAA,MAAM,SAAA;AAAA,MACR,CAAA,SAAE;AACA,QAAA,YAAA,CAAa,KAAK,CAAA;AAAA,MACpB;AAAA,IACF,CAAA;AAAA,IACA,CAAC,MAAM;AAAA,GACT;AAEA,EAAA,MAAM,0BAAA,GAA6B,OAAA;AAAA,IACjC,MAAM,QAAQ,UAAA,IAAc,IAAA;AAAA,IAC5B,CAAC,QAAQ,UAAU;AAAA,GACrB;AAEA,EAAA,MAAM,YAAA,GAAe,WAAA;AAAA,IACnB,CACE,SACA,OAAA,KACG;AACH,MAAA,MAAM,iBAAA,GAAwC;AAAA,QAC5C,GAAG,OAAA;AAAA,QACH,UAAA,EAAY,OAAA,CAAQ,UAAA,IAAc,EAAC;AAAA,QACnC,WAAA,EACE,OAAA,CAAQ,WAAA,IACR,OAAA,EAAS,UAAA,IACT;AAAA,OACJ;AACA,MAAA,OAAO,iBAAA;AAAA,QACL,MAAM,MAAA,CAAO,YAAA,CAAgB,iBAAA,EAAmB,OAAO,CAAA;AAAA,QACvD;AAAA,UACE,QAAA,EAAU,gBAAA;AAAA,UACV,MAAA,EAAQ,MAAA;AAAA,UACR,OAAA,EAAS,iBAAA;AAAA,UACT;AAAA;AACF,OACF;AAAA,IACF,CAAA;AAAA,IACA,CAAC,iBAAA,EAAmB,MAAA,EAAQ,0BAA0B;AAAA,GACxD;AAEA,EAAA,MAAM,aAAA,GAAgB,WAAA;AAAA,IACpB,CACE,SACA,OAAA,KAEA,iBAAA,CAAqB,MAAM,MAAA,CAAO,aAAA,CAAiB,OAAA,EAAS,OAAO,CAAA,EAAG;AAAA,MACpE,QAAA,EAAU,iBAAA;AAAA,MACV,MAAA,EAAQ,KAAA;AAAA,MACR,OAAA;AAAA,MACA;AAAA,KACD,CAAA;AAAA,IACH,CAAC,mBAAmB,MAAM;AAAA,GAC5B;AAEA,EAAA,MAAM,aAAA,GAAgB,WAAA;AAAA,IACpB,CACE,SACA,OAAA,KACG;AACH,MAAA,MAAM,iBAAA,GAAyC;AAAA,QAC7C,GAAG,OAAA;AAAA,QACH,UAAA,EAAY,OAAA,CAAQ,UAAA,IAAc,EAAC;AAAA,QACnC,WAAA,EACE,OAAA,CAAQ,WAAA,IACR,OAAA,EAAS,UAAA,IACT;AAAA,OACJ;AACA,MAAA,OAAO,iBAAA;AAAA,QACL,MAAM,MAAA,CAAO,aAAA,CAAiB,iBAAA,EAAmB,OAAO,CAAA;AAAA,QACxD;AAAA,UACE,QAAA,EAAU,iBAAA;AAAA,UACV,MAAA,EAAQ,MAAA;AAAA,UACR,OAAA,EAAS,iBAAA;AAAA,UACT;AAAA;AACF,OACF;AAAA,IACF,CAAA;AAAA,IACA,CAAC,iBAAA,EAAmB,MAAA,EAAQ,0BAA0B;AAAA,GACxD;AAEA,EAAA,MAAM,aAAA,GAAgB,WAAA;AAAA,IACpB,CACE,SACA,OAAA,KACG;AACH,MAAA,IAAI,CAAC,QAAQ,WAAA,EAAa;AACxB,QAAA,MAAM,IAAI,KAAA;AAAA,UACR;AAAA,SACF;AAAA,MACF;AACA,MAAA,OAAO,iBAAA;AAAA,QACL,MAAM,MAAA,CAAO,aAAA,CAAiB,OAAA,EAAS,OAAO,CAAA;AAAA,QAC9C,EAAE,QAAA,EAAU,iBAAA,EAAmB,MAAA,EAAQ,QAAA,EAAU,SAAS,OAAA;AAAQ,OACpE;AAAA,IACF,CAAA;AAAA,IACA,CAAC,mBAAmB,MAAM;AAAA,GAC5B;AAEA,EAAA,OAAO;AAAA,IACL,YAAA;AAAA,IACA,aAAA;AAAA,IACA,aAAA;AAAA,IACA,aAAA;AAAA,IACA,SAAA;AAAA,IACA,KAAA;AAAA,IACA,WAAA;AAAA,IACA,YAAA;AAAA,IACA,SAAS,MAAA,CAAO;AAAA,GAClB;AACF","file":"react.mjs","sourcesContent":["import type {\r\n AthenaGatewayBaseOptions,\r\n AthenaGatewayCallOptions,\r\n AthenaGatewayEndpointPath,\r\n AthenaGatewayMethod,\r\n AthenaGatewayResponse,\r\n} from './types.js'\r\nimport type {\r\n AthenaDeletePayload,\r\n AthenaFetchPayload,\r\n AthenaInsertPayload,\r\n AthenaUpdatePayload,\r\n} from './types.js'\r\n\r\nconst DEFAULT_BASE_URL = 'https://athena-db.com'\r\nconst DEFAULT_CLIENT = 'railway_direct'\r\n\r\nfunction parseResponseText(text: string) {\r\n if (!text) return null\r\n try {\r\n return JSON.parse(text)\r\n } catch {\r\n return text\r\n }\r\n}\r\n\r\nfunction normalizeHeaderValue(value?: string | null) {\r\n return value ? value : undefined\r\n}\r\n\r\nfunction buildHeaders(\r\n config: AthenaGatewayBaseOptions,\r\n options?: AthenaGatewayCallOptions,\r\n): Record<string, string> {\r\n const mergedStripNulls = options?.stripNulls ?? config.stripNulls ?? true\r\n const finalClient = options?.client ?? config.client ?? DEFAULT_CLIENT\r\n const finalApiKey = options?.apiKey ?? config.apiKey\r\n const finalSupabaseUrl = options?.supabaseUrl ?? config.supabaseUrl\r\n const finalSupabaseKey = options?.supabaseKey ?? config.supabaseKey\r\n const finalPublishEvent = options?.publishEvent ?? config.publishEvent\r\n const extraHeaders = {\r\n ...(config.headers ?? {}),\r\n ...(options?.headers ?? {}),\r\n }\r\n\r\n const headers: Record<string, string> = {\r\n 'Content-Type': 'application/json',\r\n }\r\n\r\n if (options?.userId ?? config.userId) {\r\n headers['X-User-Id'] = options?.userId ?? config.userId ?? ''\r\n }\r\n\r\n if (options?.companyId ?? config.companyId) {\r\n headers['X-Company-Id'] = options?.companyId ?? config.companyId ?? ''\r\n }\r\n\r\n if (options?.organizationId ?? config.organizationId) {\r\n headers['X-Organization-Id'] = options?.organizationId ?? config.organizationId ?? ''\r\n }\r\n\r\n if (finalClient) {\r\n headers['X-Athena-Client'] = finalClient\r\n }\r\n\r\n if (typeof mergedStripNulls === 'boolean') {\r\n headers['X-Strip-Nulls'] = mergedStripNulls ? 'true' : 'false'\r\n }\r\n\r\n if (finalPublishEvent) {\r\n headers['X-Publish-Event'] = finalPublishEvent\r\n }\r\n\r\n if (finalApiKey) {\r\n headers['apikey'] = finalApiKey\r\n headers['x-api-key'] = headers['x-api-key'] ?? finalApiKey\r\n }\r\n\r\n if (finalSupabaseUrl) {\r\n headers['x-supabase-url'] = finalSupabaseUrl\r\n }\r\n\r\n if (finalSupabaseKey) {\r\n headers['x-supabase-key'] = finalSupabaseKey\r\n }\r\n\r\n Object.entries(extraHeaders).forEach(([key, value]) => {\r\n const normalized = normalizeHeaderValue(value)\r\n if (normalized) {\r\n headers[key] = normalized\r\n }\r\n })\r\n\r\n return headers\r\n}\r\n\r\nasync function callAthena<T>(\r\n config: AthenaGatewayBaseOptions,\r\n endpoint: AthenaGatewayEndpointPath,\r\n method: AthenaGatewayMethod,\r\n payload: unknown,\r\n options?: AthenaGatewayCallOptions,\r\n): Promise<AthenaGatewayResponse<T>> {\r\n const baseUrl = (options?.baseUrl ?? config.baseUrl ?? DEFAULT_BASE_URL).replace(/\\/$/, '')\r\n const url = `${baseUrl}${endpoint}`\r\n const headers = buildHeaders(config, options)\r\n\r\n try {\r\n const response = await fetch(url, {\r\n method,\r\n headers,\r\n body: JSON.stringify(payload),\r\n })\r\n\r\n const rawText = await response.text()\r\n const parsed = parseResponseText(rawText ?? '')\r\n const parsedPayload = parsed as Record<string, unknown> | null\r\n const parsedError =\r\n parsedPayload && typeof parsedPayload === 'object'\r\n ? ((parsedPayload.error as string | undefined) ?? (parsedPayload.message as string | undefined))\r\n : undefined\r\n const hasError = typeof parsedError === 'string' && parsedError.length > 0 ? parsedError : undefined\r\n\r\n return {\r\n ok: response.ok,\r\n status: response.status,\r\n data: (parsed as T) ?? null,\r\n error: hasError,\r\n raw: parsed,\r\n }\r\n } catch (callError) {\r\n const message = callError instanceof Error ? callError.message : String(callError)\r\n return {\r\n ok: false,\r\n status: 0,\r\n data: null,\r\n error: message,\r\n raw: null,\r\n }\r\n }\r\n}\r\n\r\nexport interface AthenaGatewayClient {\r\n baseUrl: string\r\n buildHeaders(options?: AthenaGatewayCallOptions): Record<string, string>\r\n fetchGateway<T>(payload: AthenaFetchPayload, options?: AthenaGatewayCallOptions): Promise<AthenaGatewayResponse<T>>\r\n insertGateway<T>(payload: AthenaInsertPayload, options?: AthenaGatewayCallOptions): Promise<AthenaGatewayResponse<T>>\r\n updateGateway<T>(payload: AthenaUpdatePayload, options?: AthenaGatewayCallOptions): Promise<AthenaGatewayResponse<T>>\r\n deleteGateway<T>(payload: AthenaDeletePayload, options?: AthenaGatewayCallOptions): Promise<AthenaGatewayResponse<T>>\r\n}\r\n\r\nexport function createAthenaGatewayClient(config: AthenaGatewayBaseOptions = {}): AthenaGatewayClient {\r\n return {\r\n baseUrl: (config.baseUrl ?? DEFAULT_BASE_URL).replace(/\\/$/, ''),\r\n buildHeaders(options) {\r\n return buildHeaders(config, options)\r\n },\r\n fetchGateway(payload, options) {\r\n return callAthena(config, '/gateway/fetch', 'POST', payload, options)\r\n },\r\n insertGateway(payload, options) {\r\n return callAthena(config, '/gateway/insert', 'PUT', payload, options)\r\n },\r\n updateGateway(payload, options) {\r\n return callAthena(config, '/gateway/update', 'POST', payload, options)\r\n },\r\n deleteGateway(payload, options) {\r\n return callAthena(config, '/gateway/delete', 'DELETE', payload, options)\r\n },\r\n }\r\n}\r\n","import { useCallback, useMemo, useState } from \"react\";\r\nimport type {\r\n AthenaDeletePayload,\r\n AthenaFetchPayload,\r\n AthenaGatewayCallLog,\r\n AthenaGatewayCallOptions,\r\n AthenaGatewayHookConfig,\r\n AthenaGatewayHookResult,\r\n AthenaGatewayResponse,\r\n AthenaGatewayResponseLog,\r\n AthenaInsertPayload,\r\n AthenaUpdatePayload,\r\n} from \"./types.js\";\r\nimport { createAthenaGatewayClient } from \"./client.js\";\r\n\r\nexport function useAthenaGateway(\r\n config?: AthenaGatewayHookConfig,\r\n): AthenaGatewayHookResult {\r\n const [isLoading, setIsLoading] = useState(false);\r\n const [error, setError] = useState<string | null>(null);\r\n const [lastRequest, setLastRequest] = useState<AthenaGatewayCallLog | null>(\r\n null,\r\n );\r\n const [lastResponse, setLastResponse] =\r\n useState<AthenaGatewayResponseLog | null>(null);\r\n\r\n const client = useMemo(\r\n () =>\r\n createAthenaGatewayClient({\r\n client: config?.client,\r\n baseUrl: config?.baseUrl,\r\n apiKey: config?.apiKey,\r\n supabaseUrl: config?.supabaseUrl,\r\n supabaseKey: config?.supabaseKey,\r\n publishEvent: config?.publishEvent,\r\n stripNulls: config?.stripNulls,\r\n headers: config?.headers,\r\n userId: config?.userId,\r\n companyId: config?.companyId,\r\n organizationId: config?.organizationId,\r\n }),\r\n [\r\n config?.baseUrl,\r\n config?.client,\r\n config?.apiKey,\r\n config?.supabaseUrl,\r\n config?.supabaseKey,\r\n config?.publishEvent,\r\n config?.stripNulls,\r\n config?.headers,\r\n config?.userId,\r\n config?.companyId,\r\n config?.organizationId,\r\n ],\r\n );\r\n\r\n const callWithLifecycle = useCallback(\r\n async <T>(\r\n fn: () => Promise<AthenaGatewayResponse<T>>,\r\n metadata: {\r\n endpoint: string;\r\n method: string;\r\n payload: unknown;\r\n options?: AthenaGatewayCallOptions;\r\n },\r\n ): Promise<AthenaGatewayResponse<T>> => {\r\n const requestLog: AthenaGatewayCallLog = {\r\n endpoint: metadata.endpoint as any,\r\n method: metadata.method as any,\r\n payload: metadata.payload,\r\n headers: client.buildHeaders(metadata.options),\r\n timestamp: new Date().toISOString(),\r\n };\r\n\r\n setLastRequest(requestLog);\r\n setIsLoading(true);\r\n setError(null);\r\n\r\n let response: AthenaGatewayResponse<T> | undefined;\r\n try {\r\n response = await fn();\r\n setLastResponse({ ...response, timestamp: new Date().toISOString() });\r\n\r\n if (!response.ok) {\r\n const message =\r\n response.error ||\r\n `Athena gateway ${metadata.method} ${metadata.endpoint} failed`;\r\n setError(message);\r\n throw new Error(message);\r\n }\r\n\r\n return response;\r\n } catch (callError) {\r\n const message =\r\n callError instanceof Error ? callError.message : String(callError);\r\n setError(message);\r\n setLastResponse({\r\n timestamp: new Date().toISOString(),\r\n status: response?.status ?? 0,\r\n ok: false,\r\n data: null,\r\n raw: null,\r\n error: message,\r\n });\r\n throw callError;\r\n } finally {\r\n setIsLoading(false);\r\n }\r\n },\r\n [client],\r\n );\r\n\r\n const normalizedConfigStripNulls = useMemo(\r\n () => config?.stripNulls ?? true,\r\n [config?.stripNulls],\r\n );\r\n\r\n const fetchGateway = useCallback(\r\n <T = unknown>(\r\n payload: AthenaFetchPayload,\r\n options?: AthenaGatewayCallOptions,\r\n ) => {\r\n const normalizedPayload: AthenaFetchPayload = {\r\n ...payload,\r\n conditions: payload.conditions ?? [],\r\n strip_nulls:\r\n payload.strip_nulls ??\r\n options?.stripNulls ??\r\n normalizedConfigStripNulls,\r\n };\r\n return callWithLifecycle<T>(\r\n () => client.fetchGateway<T>(normalizedPayload, options),\r\n {\r\n endpoint: \"/gateway/fetch\",\r\n method: \"POST\",\r\n payload: normalizedPayload,\r\n options,\r\n },\r\n );\r\n },\r\n [callWithLifecycle, client, normalizedConfigStripNulls],\r\n );\r\n\r\n const insertGateway = useCallback(\r\n <T = unknown>(\r\n payload: AthenaInsertPayload,\r\n options?: AthenaGatewayCallOptions,\r\n ) =>\r\n callWithLifecycle<T>(() => client.insertGateway<T>(payload, options), {\r\n endpoint: \"/gateway/insert\",\r\n method: \"PUT\",\r\n payload,\r\n options,\r\n }),\r\n [callWithLifecycle, client],\r\n );\r\n\r\n const updateGateway = useCallback(\r\n <T = unknown>(\r\n payload: AthenaUpdatePayload,\r\n options?: AthenaGatewayCallOptions,\r\n ) => {\r\n const normalizedPayload: AthenaUpdatePayload = {\r\n ...payload,\r\n conditions: payload.conditions ?? [],\r\n strip_nulls:\r\n payload.strip_nulls ??\r\n options?.stripNulls ??\r\n normalizedConfigStripNulls,\r\n };\r\n return callWithLifecycle<T>(\r\n () => client.updateGateway<T>(normalizedPayload, options),\r\n {\r\n endpoint: \"/gateway/update\",\r\n method: \"POST\",\r\n payload: normalizedPayload,\r\n options,\r\n },\r\n );\r\n },\r\n [callWithLifecycle, client, normalizedConfigStripNulls],\r\n );\r\n\r\n const deleteGateway = useCallback(\r\n <T = unknown>(\r\n payload: AthenaDeletePayload,\r\n options?: AthenaGatewayCallOptions,\r\n ) => {\r\n if (!payload.resource_id) {\r\n throw new Error(\r\n \"deleteGateway requires resource_id (the unique identifier of the record to delete)\",\r\n );\r\n }\r\n return callWithLifecycle<T>(\r\n () => client.deleteGateway<T>(payload, options),\r\n { endpoint: \"/gateway/delete\", method: \"DELETE\", payload, options },\r\n );\r\n },\r\n [callWithLifecycle, client],\r\n );\r\n\r\n return {\r\n fetchGateway,\r\n insertGateway,\r\n updateGateway,\r\n deleteGateway,\r\n isLoading,\r\n error,\r\n lastRequest,\r\n lastResponse,\r\n baseUrl: client.baseUrl,\r\n };\r\n}\r\n"]}
@@ -0,0 +1,88 @@
1
+ /**
2
+ * athena gateway types
3
+ *
4
+ * type definitions for the athena gateway api client and react hook
5
+ */
6
+ type AthenaGatewayMethod = 'POST' | 'PUT' | 'DELETE';
7
+ type AthenaGatewayEndpointPath = '/gateway/fetch' | '/gateway/insert' | '/gateway/update' | '/gateway/delete';
8
+ interface AthenaGatewayCondition {
9
+ eq_column: string;
10
+ eq_value: string | number | boolean | null;
11
+ }
12
+ interface AthenaFetchPayload {
13
+ view_name?: string;
14
+ table_name?: string;
15
+ columns?: string[] | string;
16
+ conditions?: AthenaGatewayCondition[];
17
+ limit?: number;
18
+ offset?: number;
19
+ current_page?: number;
20
+ page_size?: number;
21
+ total_pages?: number;
22
+ strip_nulls?: boolean;
23
+ group_by?: string;
24
+ time_granularity?: 'day' | 'hour' | 'minute';
25
+ aggregation_column?: string;
26
+ aggregation_strategy?: 'cumulative_sum';
27
+ aggregation_dedup?: boolean;
28
+ }
29
+ interface AthenaInsertPayload {
30
+ table_name: string;
31
+ insert_body: Record<string, unknown>;
32
+ update_body?: Record<string, unknown>;
33
+ }
34
+ interface AthenaDeletePayload {
35
+ table_name: string;
36
+ resource_id: string;
37
+ }
38
+ interface AthenaUpdatePayload extends AthenaFetchPayload {
39
+ update_body?: Record<string, unknown>;
40
+ }
41
+ interface AthenaGatewayBaseOptions {
42
+ baseUrl?: string;
43
+ client?: string;
44
+ apiKey?: string;
45
+ stripNulls?: boolean;
46
+ supabaseUrl?: string;
47
+ supabaseKey?: string;
48
+ publishEvent?: string;
49
+ headers?: Record<string, string>;
50
+ /** optional user context injected as gateway request headers */
51
+ userId?: string | null;
52
+ companyId?: string | null;
53
+ organizationId?: string | null;
54
+ }
55
+ interface AthenaGatewayHookConfig extends AthenaGatewayBaseOptions {
56
+ }
57
+ interface AthenaGatewayCallOptions extends AthenaGatewayBaseOptions {
58
+ }
59
+ interface AthenaGatewayResponse<T = unknown> {
60
+ ok: boolean;
61
+ status: number;
62
+ data: T | null;
63
+ error?: string;
64
+ raw: unknown;
65
+ }
66
+ interface AthenaGatewayResponseLog extends AthenaGatewayResponse {
67
+ timestamp: string;
68
+ }
69
+ interface AthenaGatewayCallLog {
70
+ endpoint: AthenaGatewayEndpointPath;
71
+ method: AthenaGatewayMethod;
72
+ payload: unknown;
73
+ headers: Record<string, string>;
74
+ timestamp: string;
75
+ }
76
+ interface AthenaGatewayHookResult {
77
+ fetchGateway: <T = unknown>(payload: AthenaFetchPayload, options?: AthenaGatewayCallOptions) => Promise<AthenaGatewayResponse<T>>;
78
+ insertGateway: <T = unknown>(payload: AthenaInsertPayload, options?: AthenaGatewayCallOptions) => Promise<AthenaGatewayResponse<T>>;
79
+ updateGateway: <T = unknown>(payload: AthenaUpdatePayload, options?: AthenaGatewayCallOptions) => Promise<AthenaGatewayResponse<T>>;
80
+ deleteGateway: <T = unknown>(payload: AthenaDeletePayload, options?: AthenaGatewayCallOptions) => Promise<AthenaGatewayResponse<T>>;
81
+ isLoading: boolean;
82
+ error: string | null;
83
+ lastRequest: AthenaGatewayCallLog | null;
84
+ lastResponse: AthenaGatewayResponseLog | null;
85
+ baseUrl: string;
86
+ }
87
+
88
+ export type { AthenaGatewayCallOptions as A, AthenaDeletePayload as a, AthenaFetchPayload as b, AthenaGatewayBaseOptions as c, AthenaGatewayCallLog as d, AthenaGatewayCondition as e, AthenaGatewayEndpointPath as f, AthenaGatewayHookConfig as g, AthenaGatewayHookResult as h, AthenaGatewayMethod as i, AthenaGatewayResponse as j, AthenaGatewayResponseLog as k, AthenaInsertPayload as l, AthenaUpdatePayload as m };
@@ -0,0 +1,88 @@
1
+ /**
2
+ * athena gateway types
3
+ *
4
+ * type definitions for the athena gateway api client and react hook
5
+ */
6
+ type AthenaGatewayMethod = 'POST' | 'PUT' | 'DELETE';
7
+ type AthenaGatewayEndpointPath = '/gateway/fetch' | '/gateway/insert' | '/gateway/update' | '/gateway/delete';
8
+ interface AthenaGatewayCondition {
9
+ eq_column: string;
10
+ eq_value: string | number | boolean | null;
11
+ }
12
+ interface AthenaFetchPayload {
13
+ view_name?: string;
14
+ table_name?: string;
15
+ columns?: string[] | string;
16
+ conditions?: AthenaGatewayCondition[];
17
+ limit?: number;
18
+ offset?: number;
19
+ current_page?: number;
20
+ page_size?: number;
21
+ total_pages?: number;
22
+ strip_nulls?: boolean;
23
+ group_by?: string;
24
+ time_granularity?: 'day' | 'hour' | 'minute';
25
+ aggregation_column?: string;
26
+ aggregation_strategy?: 'cumulative_sum';
27
+ aggregation_dedup?: boolean;
28
+ }
29
+ interface AthenaInsertPayload {
30
+ table_name: string;
31
+ insert_body: Record<string, unknown>;
32
+ update_body?: Record<string, unknown>;
33
+ }
34
+ interface AthenaDeletePayload {
35
+ table_name: string;
36
+ resource_id: string;
37
+ }
38
+ interface AthenaUpdatePayload extends AthenaFetchPayload {
39
+ update_body?: Record<string, unknown>;
40
+ }
41
+ interface AthenaGatewayBaseOptions {
42
+ baseUrl?: string;
43
+ client?: string;
44
+ apiKey?: string;
45
+ stripNulls?: boolean;
46
+ supabaseUrl?: string;
47
+ supabaseKey?: string;
48
+ publishEvent?: string;
49
+ headers?: Record<string, string>;
50
+ /** optional user context injected as gateway request headers */
51
+ userId?: string | null;
52
+ companyId?: string | null;
53
+ organizationId?: string | null;
54
+ }
55
+ interface AthenaGatewayHookConfig extends AthenaGatewayBaseOptions {
56
+ }
57
+ interface AthenaGatewayCallOptions extends AthenaGatewayBaseOptions {
58
+ }
59
+ interface AthenaGatewayResponse<T = unknown> {
60
+ ok: boolean;
61
+ status: number;
62
+ data: T | null;
63
+ error?: string;
64
+ raw: unknown;
65
+ }
66
+ interface AthenaGatewayResponseLog extends AthenaGatewayResponse {
67
+ timestamp: string;
68
+ }
69
+ interface AthenaGatewayCallLog {
70
+ endpoint: AthenaGatewayEndpointPath;
71
+ method: AthenaGatewayMethod;
72
+ payload: unknown;
73
+ headers: Record<string, string>;
74
+ timestamp: string;
75
+ }
76
+ interface AthenaGatewayHookResult {
77
+ fetchGateway: <T = unknown>(payload: AthenaFetchPayload, options?: AthenaGatewayCallOptions) => Promise<AthenaGatewayResponse<T>>;
78
+ insertGateway: <T = unknown>(payload: AthenaInsertPayload, options?: AthenaGatewayCallOptions) => Promise<AthenaGatewayResponse<T>>;
79
+ updateGateway: <T = unknown>(payload: AthenaUpdatePayload, options?: AthenaGatewayCallOptions) => Promise<AthenaGatewayResponse<T>>;
80
+ deleteGateway: <T = unknown>(payload: AthenaDeletePayload, options?: AthenaGatewayCallOptions) => Promise<AthenaGatewayResponse<T>>;
81
+ isLoading: boolean;
82
+ error: string | null;
83
+ lastRequest: AthenaGatewayCallLog | null;
84
+ lastResponse: AthenaGatewayResponseLog | null;
85
+ baseUrl: string;
86
+ }
87
+
88
+ export type { AthenaGatewayCallOptions as A, AthenaDeletePayload as a, AthenaFetchPayload as b, AthenaGatewayBaseOptions as c, AthenaGatewayCallLog as d, AthenaGatewayCondition as e, AthenaGatewayEndpointPath as f, AthenaGatewayHookConfig as g, AthenaGatewayHookResult as h, AthenaGatewayMethod as i, AthenaGatewayResponse as j, AthenaGatewayResponseLog as k, AthenaInsertPayload as l, AthenaUpdatePayload as m };
package/package.json ADDED
@@ -0,0 +1,95 @@
1
+ {
2
+ "name": "@xylex-group/athena",
3
+ "version": "0.1.0",
4
+ "description": "Athena SDK",
5
+ "main": "./dist/index.js",
6
+ "module": "./dist/index.mjs",
7
+ "types": "./dist/index.d.ts",
8
+ "bin": {
9
+ "athena-js": "./bin/athena-js.js"
10
+ },
11
+ "exports": {
12
+ ".": {
13
+ "types": "./dist/index.d.ts",
14
+ "import": "./dist/index.mjs",
15
+ "require": "./dist/index.js"
16
+ },
17
+ "./react": {
18
+ "types": "./dist/react.d.ts",
19
+ "import": "./dist/react.mjs",
20
+ "require": "./dist/react.js"
21
+ }
22
+ },
23
+ "files": [
24
+ "dist",
25
+ "bin",
26
+ "README.md",
27
+ "LICENSE"
28
+ ],
29
+ "scripts": {
30
+ "build": "tsup",
31
+ "dev": "tsup --watch",
32
+ "test": "node --test test/**/*.test.ts",
33
+ "test:watch": "node --test --watch test/**/*.test.ts",
34
+ "lint": "eslint \"src/**/*.ts\" \"examples/**/*.ts\" \"test/**/*.ts\"",
35
+ "lint:fix": "npm run lint -- --fix",
36
+ "prepublishOnly": "npm run build",
37
+ "publish:token": "node scripts/publish.js",
38
+ "example:express-api": "cd examples/express-api && bun run start",
39
+ "example:order-saga": "cd examples/order-saga && bun run start",
40
+ "example:recurring-invoice": "cd examples/recurring-invoice && bun run start",
41
+ "example:retry-patterns": "cd examples/retry-patterns && bun run start",
42
+ "example:email-resend": "cd examples/email-resend && bun run start",
43
+ "example:api-call": "cd examples/api-call && bun run start",
44
+ "example:supabase-fetch": "cd examples/supabase-fetch && bun run start",
45
+ "example:postgres-connection": "cd examples/postgres-connection && bun run start"
46
+ },
47
+ "keywords": [
48
+ "database",
49
+ "driver",
50
+ "api-gateway",
51
+ "sdk",
52
+ "react",
53
+ "hooks",
54
+ "http",
55
+ "postgres",
56
+ "supabase",
57
+ "query-builder"
58
+ ],
59
+ "author": "floris@xylex.group",
60
+ "publisher": "XYLEX Group",
61
+ "license": "MIT",
62
+ "repository": {
63
+ "type": "git",
64
+ "url": "https://github.com/xylex-group/athena-js"
65
+ },
66
+ "dependencies": {
67
+ "blessed": "^0.1.81",
68
+ "chalk": "^4.1.2",
69
+ "cron-parser": "^4.9.0",
70
+ "uuid": "^9.0.1"
71
+ },
72
+ "peerDependencies": {
73
+ "react": ">=17.0.0"
74
+ },
75
+ "peerDependenciesMeta": {
76
+ "react": {
77
+ "optional": true
78
+ }
79
+ },
80
+ "devDependencies": {
81
+ "@types/blessed": "^0.1.25",
82
+ "@types/node": "^20.10.5",
83
+ "@types/react": "^18.3.12",
84
+ "@types/uuid": "^9.0.7",
85
+ "@typescript-eslint/eslint-plugin": "^7.18.0",
86
+ "@typescript-eslint/parser": "^7.18.0",
87
+ "eslint": "^8.57.1",
88
+ "tsup": "^8.5.1",
89
+ "tsx": "^4.7.0",
90
+ "typescript": "^5.3.3"
91
+ },
92
+ "engines": {
93
+ "node": ">=18.0.0"
94
+ }
95
+ }