@forklaunch/universal-sdk 0.1.1 → 0.2.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.
@@ -0,0 +1,3 @@
1
+ declare const universalSdk: <TypedController>(host: string) => TypedController;
2
+
3
+ export { universalSdk };
package/lib/index.d.ts CHANGED
@@ -1,2 +1,3 @@
1
- export declare const universalSdk: <TypedController>(host: string) => TypedController;
2
- //# sourceMappingURL=index.d.ts.map
1
+ declare const universalSdk: <TypedController>(host: string) => TypedController;
2
+
3
+ export { universalSdk };
package/lib/index.js CHANGED
@@ -1,20 +1,217 @@
1
- /**
2
- * Initializes the Forklaunch SDK with HTTP methods proxied.
3
- *
4
- * @template TypedController
5
- * @param {string} host - The host URL for the SDK.
6
- * @returns {TypedController} - The SDK proxy with methods for HTTP requests.
7
- */
8
- import { UniversalSdk } from './src/universalSdk';
9
- export const universalSdk = (host) => {
10
- const sdkInternal = new UniversalSdk(host);
11
- const proxyInternal = new Proxy(sdkInternal, {
12
- get(target, prop) {
13
- if (typeof prop === 'string' && prop in target) {
14
- return target[prop].bind(target);
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // index.ts
21
+ var index_exports = {};
22
+ __export(index_exports, {
23
+ universalSdk: () => universalSdk
24
+ });
25
+ module.exports = __toCommonJS(index_exports);
26
+
27
+ // src/utils/regex.ts
28
+ function generateStringFromRegex(regex) {
29
+ let regexStr = typeof regex === "object" ? regex.source : regex;
30
+ if (regexStr.startsWith("/")) regexStr = regexStr.slice(1);
31
+ if (regexStr.endsWith("/g")) regexStr = regexStr.slice(0, -2);
32
+ if (regexStr.endsWith("/")) regexStr = regexStr.slice(0, -1);
33
+ let result = "";
34
+ let i = 0;
35
+ while (i < regexStr.length) {
36
+ const char = regexStr[i];
37
+ switch (char) {
38
+ case "\\": {
39
+ const nextChar = regexStr[i + 1];
40
+ switch (nextChar) {
41
+ case "b":
42
+ if (result.length > 0 && /\w/.test(result[result.length - 1])) {
43
+ result += " ";
15
44
  }
16
- throw new Error(`Method ${String(prop)} not found`);
45
+ break;
46
+ case "d":
47
+ result += "0";
48
+ break;
49
+ case "w":
50
+ result += "a";
51
+ break;
52
+ case "s":
53
+ result += " ";
54
+ break;
55
+ default:
56
+ result += nextChar;
57
+ }
58
+ i += 2;
59
+ break;
60
+ }
61
+ case ".":
62
+ result += "a";
63
+ i++;
64
+ break;
65
+ case "[": {
66
+ const endIdx = regexStr.indexOf("]", i);
67
+ if (endIdx === -1) {
68
+ throw new Error("Unmatched [");
69
+ }
70
+ const charClass = regexStr.slice(i + 1, endIdx);
71
+ result += charClass[0];
72
+ i = endIdx + 1;
73
+ break;
74
+ }
75
+ case "(": {
76
+ const endGroupIdx = regexStr.indexOf(")", i);
77
+ if (endGroupIdx === -1) {
78
+ throw new Error("Unmatched (");
17
79
  }
80
+ const groupContent = regexStr.slice(i + 1, endGroupIdx);
81
+ result += generateStringFromRegex(groupContent);
82
+ i = endGroupIdx + 1;
83
+ break;
84
+ }
85
+ case "{": {
86
+ const endQuantIdx = regexStr.indexOf("}", i);
87
+ if (endQuantIdx === -1) {
88
+ throw new Error("Unmatched {");
89
+ }
90
+ const quantifier = regexStr.slice(i + 1, endQuantIdx);
91
+ const min = parseInt(quantifier.split(",")[0], 10) || 1;
92
+ const lastChar = result[result.length - 1];
93
+ result += lastChar.repeat(min - 1);
94
+ i = endQuantIdx + 1;
95
+ break;
96
+ }
97
+ case "*":
98
+ case "+":
99
+ case "?": {
100
+ const prevChar = result[result.length - 1];
101
+ if (char === "*") {
102
+ result += prevChar;
103
+ } else if (char === "+") {
104
+ result += prevChar;
105
+ }
106
+ i++;
107
+ break;
108
+ }
109
+ default:
110
+ result += char;
111
+ i++;
112
+ break;
113
+ }
114
+ }
115
+ return result;
116
+ }
117
+
118
+ // src/utils/resolvePath.ts
119
+ function getSdkPath(path) {
120
+ let sdkPath = path;
121
+ if (Array.isArray(path)) {
122
+ sdkPath = path.pop() || path[0];
123
+ }
124
+ if (!sdkPath) {
125
+ throw new Error("Path is not defined");
126
+ }
127
+ if (sdkPath instanceof RegExp) {
128
+ sdkPath = generateStringFromRegex(sdkPath);
129
+ }
130
+ return sdkPath;
131
+ }
132
+
133
+ // src/universalSdk.ts
134
+ var UniversalSdk = class {
135
+ /**
136
+ * Creates an instance of UniversalSdk.
137
+ *
138
+ * @param {string} host - The host URL for the SDK.
139
+ */
140
+ constructor(host) {
141
+ this.host = host;
142
+ }
143
+ /**
144
+ * Executes an HTTP request.
145
+ *
146
+ * @param {string} route - The route path for the request.
147
+ * @param {'GET' | 'POST' | 'PUT' | 'PATCH' | 'DELETE'} method - The HTTP method.
148
+ * @param {RequestType} [request] - The request object.
149
+ * @returns {Promise<ResponseType>} - The response object.
150
+ */
151
+ async execute(route, method, request) {
152
+ const { params, body, query, headers } = request || {};
153
+ let url = getSdkPath(this.host + route);
154
+ if (params) {
155
+ for (const key in params) {
156
+ url = url.replace(`:${key}`, encodeURIComponent(params[key]));
157
+ }
158
+ }
159
+ if (query) {
160
+ const queryString = new URLSearchParams(
161
+ query
162
+ ).toString();
163
+ url += queryString ? `?${queryString}` : "";
164
+ }
165
+ const response = await fetch(encodeURI(url), {
166
+ method,
167
+ headers: headers ? { ...headers, "Content-Type": "application/json" } : void 0,
168
+ body: body ? JSON.stringify(body) : void 0
18
169
  });
19
- return proxyInternal;
170
+ const contentType = response.headers.get("content-type");
171
+ const responseBody = contentType && contentType.includes("application/json") ? await response.json() : await response.text();
172
+ return {
173
+ code: response.status,
174
+ content: responseBody,
175
+ headers: response.headers
176
+ };
177
+ }
178
+ async pathParamRequest(route, method, request) {
179
+ return this.execute(route, method, request);
180
+ }
181
+ async bodyRequest(route, method, request) {
182
+ return this.execute(route, method, request);
183
+ }
184
+ async get(route, request) {
185
+ return this.pathParamRequest(route, "GET", request);
186
+ }
187
+ async post(route, request) {
188
+ return this.bodyRequest(route, "POST", request);
189
+ }
190
+ async put(route, request) {
191
+ return this.bodyRequest(route, "PUT", request);
192
+ }
193
+ async patch(route, request) {
194
+ return this.bodyRequest(route, "PATCH", request);
195
+ }
196
+ async delete(route, request) {
197
+ return this.pathParamRequest(route, "DELETE", request);
198
+ }
199
+ };
200
+
201
+ // index.ts
202
+ var universalSdk = (host) => {
203
+ const sdkInternal = new UniversalSdk(host);
204
+ const proxyInternal = new Proxy(sdkInternal, {
205
+ get(target, prop) {
206
+ if (typeof prop === "string" && prop in target) {
207
+ return target[prop].bind(target);
208
+ }
209
+ throw new Error(`Method ${String(prop)} not found`);
210
+ }
211
+ });
212
+ return proxyInternal;
20
213
  };
214
+ // Annotate the CommonJS export names for ESM import in node:
215
+ 0 && (module.exports = {
216
+ universalSdk
217
+ });
package/lib/index.mjs ADDED
@@ -0,0 +1,190 @@
1
+ // src/utils/regex.ts
2
+ function generateStringFromRegex(regex) {
3
+ let regexStr = typeof regex === "object" ? regex.source : regex;
4
+ if (regexStr.startsWith("/")) regexStr = regexStr.slice(1);
5
+ if (regexStr.endsWith("/g")) regexStr = regexStr.slice(0, -2);
6
+ if (regexStr.endsWith("/")) regexStr = regexStr.slice(0, -1);
7
+ let result = "";
8
+ let i = 0;
9
+ while (i < regexStr.length) {
10
+ const char = regexStr[i];
11
+ switch (char) {
12
+ case "\\": {
13
+ const nextChar = regexStr[i + 1];
14
+ switch (nextChar) {
15
+ case "b":
16
+ if (result.length > 0 && /\w/.test(result[result.length - 1])) {
17
+ result += " ";
18
+ }
19
+ break;
20
+ case "d":
21
+ result += "0";
22
+ break;
23
+ case "w":
24
+ result += "a";
25
+ break;
26
+ case "s":
27
+ result += " ";
28
+ break;
29
+ default:
30
+ result += nextChar;
31
+ }
32
+ i += 2;
33
+ break;
34
+ }
35
+ case ".":
36
+ result += "a";
37
+ i++;
38
+ break;
39
+ case "[": {
40
+ const endIdx = regexStr.indexOf("]", i);
41
+ if (endIdx === -1) {
42
+ throw new Error("Unmatched [");
43
+ }
44
+ const charClass = regexStr.slice(i + 1, endIdx);
45
+ result += charClass[0];
46
+ i = endIdx + 1;
47
+ break;
48
+ }
49
+ case "(": {
50
+ const endGroupIdx = regexStr.indexOf(")", i);
51
+ if (endGroupIdx === -1) {
52
+ throw new Error("Unmatched (");
53
+ }
54
+ const groupContent = regexStr.slice(i + 1, endGroupIdx);
55
+ result += generateStringFromRegex(groupContent);
56
+ i = endGroupIdx + 1;
57
+ break;
58
+ }
59
+ case "{": {
60
+ const endQuantIdx = regexStr.indexOf("}", i);
61
+ if (endQuantIdx === -1) {
62
+ throw new Error("Unmatched {");
63
+ }
64
+ const quantifier = regexStr.slice(i + 1, endQuantIdx);
65
+ const min = parseInt(quantifier.split(",")[0], 10) || 1;
66
+ const lastChar = result[result.length - 1];
67
+ result += lastChar.repeat(min - 1);
68
+ i = endQuantIdx + 1;
69
+ break;
70
+ }
71
+ case "*":
72
+ case "+":
73
+ case "?": {
74
+ const prevChar = result[result.length - 1];
75
+ if (char === "*") {
76
+ result += prevChar;
77
+ } else if (char === "+") {
78
+ result += prevChar;
79
+ }
80
+ i++;
81
+ break;
82
+ }
83
+ default:
84
+ result += char;
85
+ i++;
86
+ break;
87
+ }
88
+ }
89
+ return result;
90
+ }
91
+
92
+ // src/utils/resolvePath.ts
93
+ function getSdkPath(path) {
94
+ let sdkPath = path;
95
+ if (Array.isArray(path)) {
96
+ sdkPath = path.pop() || path[0];
97
+ }
98
+ if (!sdkPath) {
99
+ throw new Error("Path is not defined");
100
+ }
101
+ if (sdkPath instanceof RegExp) {
102
+ sdkPath = generateStringFromRegex(sdkPath);
103
+ }
104
+ return sdkPath;
105
+ }
106
+
107
+ // src/universalSdk.ts
108
+ var UniversalSdk = class {
109
+ /**
110
+ * Creates an instance of UniversalSdk.
111
+ *
112
+ * @param {string} host - The host URL for the SDK.
113
+ */
114
+ constructor(host) {
115
+ this.host = host;
116
+ }
117
+ /**
118
+ * Executes an HTTP request.
119
+ *
120
+ * @param {string} route - The route path for the request.
121
+ * @param {'GET' | 'POST' | 'PUT' | 'PATCH' | 'DELETE'} method - The HTTP method.
122
+ * @param {RequestType} [request] - The request object.
123
+ * @returns {Promise<ResponseType>} - The response object.
124
+ */
125
+ async execute(route, method, request) {
126
+ const { params, body, query, headers } = request || {};
127
+ let url = getSdkPath(this.host + route);
128
+ if (params) {
129
+ for (const key in params) {
130
+ url = url.replace(`:${key}`, encodeURIComponent(params[key]));
131
+ }
132
+ }
133
+ if (query) {
134
+ const queryString = new URLSearchParams(
135
+ query
136
+ ).toString();
137
+ url += queryString ? `?${queryString}` : "";
138
+ }
139
+ const response = await fetch(encodeURI(url), {
140
+ method,
141
+ headers: headers ? { ...headers, "Content-Type": "application/json" } : void 0,
142
+ body: body ? JSON.stringify(body) : void 0
143
+ });
144
+ const contentType = response.headers.get("content-type");
145
+ const responseBody = contentType && contentType.includes("application/json") ? await response.json() : await response.text();
146
+ return {
147
+ code: response.status,
148
+ content: responseBody,
149
+ headers: response.headers
150
+ };
151
+ }
152
+ async pathParamRequest(route, method, request) {
153
+ return this.execute(route, method, request);
154
+ }
155
+ async bodyRequest(route, method, request) {
156
+ return this.execute(route, method, request);
157
+ }
158
+ async get(route, request) {
159
+ return this.pathParamRequest(route, "GET", request);
160
+ }
161
+ async post(route, request) {
162
+ return this.bodyRequest(route, "POST", request);
163
+ }
164
+ async put(route, request) {
165
+ return this.bodyRequest(route, "PUT", request);
166
+ }
167
+ async patch(route, request) {
168
+ return this.bodyRequest(route, "PATCH", request);
169
+ }
170
+ async delete(route, request) {
171
+ return this.pathParamRequest(route, "DELETE", request);
172
+ }
173
+ };
174
+
175
+ // index.ts
176
+ var universalSdk = (host) => {
177
+ const sdkInternal = new UniversalSdk(host);
178
+ const proxyInternal = new Proxy(sdkInternal, {
179
+ get(target, prop) {
180
+ if (typeof prop === "string" && prop in target) {
181
+ return target[prop].bind(target);
182
+ }
183
+ throw new Error(`Method ${String(prop)} not found`);
184
+ }
185
+ });
186
+ return proxyInternal;
187
+ };
188
+ export {
189
+ universalSdk
190
+ };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@forklaunch/universal-sdk",
3
- "version": "0.1.1",
3
+ "version": "0.2.0",
4
4
  "description": "Cross runtime fetch library for forklaunch router sdks",
5
5
  "files": [
6
6
  "lib/**"
@@ -25,11 +25,20 @@
25
25
  "devDependencies": {
26
26
  "fetch-mock": "^12.2.0",
27
27
  "jest": "^29.7.0",
28
- "ts-jest": "^29.2.5"
28
+ "ts-jest": "^29.2.5",
29
+ "tsup": "^8.3.5"
30
+ },
31
+ "exports": {
32
+ ".": {
33
+ "types": "./lib/index.d.ts",
34
+ "import": "./lib/index.mjs",
35
+ "require": "./lib/index.js",
36
+ "default": "./lib/index.js"
37
+ }
29
38
  },
30
39
  "scripts": {
31
40
  "test": "vitest --passWithNoTests",
32
- "build": "tsc",
41
+ "build": "tsc --noEmit && tsup index.ts --format cjs,esm --no-splitting --dts --tsconfig tsconfig.json --out-dir lib --clean",
33
42
  "clean": "rm -rf lib pnpm.lock.yaml node_modules",
34
43
  "docs": "typedoc --out docs *",
35
44
  "lint": "eslint . -c eslint.config.mjs",