@autometa/http 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/index.js ADDED
@@ -0,0 +1,524 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var __decorateClass = (decorators, target, key, kind) => {
30
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
31
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
32
+ if (decorator = decorators[i])
33
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
34
+ if (kind && result)
35
+ __defProp(target, key, result);
36
+ return result;
37
+ };
38
+ var __accessCheck = (obj, member, msg) => {
39
+ if (!member.has(obj))
40
+ throw TypeError("Cannot " + msg);
41
+ };
42
+ var __privateGet = (obj, member, getter) => {
43
+ __accessCheck(obj, member, "read from private field");
44
+ return getter ? getter.call(obj) : member.get(obj);
45
+ };
46
+ var __privateAdd = (obj, member, value) => {
47
+ if (member.has(obj))
48
+ throw TypeError("Cannot add the same private member more than once");
49
+ member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
50
+ };
51
+ var __privateSet = (obj, member, value, setter) => {
52
+ __accessCheck(obj, member, "write to private field");
53
+ setter ? setter.call(obj, value) : member.set(obj, value);
54
+ return value;
55
+ };
56
+
57
+ // src/index.ts
58
+ var src_exports = {};
59
+ __export(src_exports, {
60
+ DerivedHTTPResponse: () => DerivedHTTPResponse,
61
+ HTTP: () => HTTP,
62
+ HTTPRequestBuilder: () => HTTPRequestBuilder,
63
+ HTTPResponse: () => HTTPResponse,
64
+ IsStatusCode: () => IsStatusCode,
65
+ SchemaMap: () => SchemaMap,
66
+ assertIsStatusCode: () => assertIsStatusCode
67
+ });
68
+ module.exports = __toCommonJS(src_exports);
69
+
70
+ // src/http.builder.ts
71
+ var import_app = require("@autometa/app");
72
+ var import_errors2 = require("@autometa/errors");
73
+ var import_axios = __toESM(require("axios"), 1);
74
+ var import_class_transformer = require("class-transformer");
75
+ var import_url_join_ts = require("url-join-ts");
76
+
77
+ // src/http.response.ts
78
+ var HTTPResponse = class _HTTPResponse {
79
+ static fromRaw(data, status, statusText, headers, url) {
80
+ const response = new _HTTPResponse();
81
+ response.data = data;
82
+ response.status = status;
83
+ response.statusText = statusText;
84
+ response.headers = headers;
85
+ response.request = {
86
+ url
87
+ };
88
+ return response;
89
+ }
90
+ static derive(original, data) {
91
+ const response = new DerivedHTTPResponse();
92
+ if (typeof data === "function") {
93
+ const fn = data;
94
+ response.data = fn(original.data);
95
+ } else {
96
+ response.data = data;
97
+ }
98
+ response.status = original.status;
99
+ response.statusText = original.statusText;
100
+ response.headers = original.headers;
101
+ response.request = original.request;
102
+ response.actual = original;
103
+ return response;
104
+ }
105
+ };
106
+ var DerivedHTTPResponse = class extends HTTPResponse {
107
+ };
108
+
109
+ // src/schema.map.ts
110
+ var import_errors = require("@autometa/errors");
111
+ var import_status_codes = require("@autometa/status-codes");
112
+ var _children, _map;
113
+ var SchemaMap = class {
114
+ constructor() {
115
+ __privateAdd(this, _children, []);
116
+ __privateAdd(this, _map, /* @__PURE__ */ new Map());
117
+ }
118
+ register(parser, ...args) {
119
+ args.forEach((arg) => {
120
+ if (typeof arg === "number") {
121
+ this.registerSingle(parser, arg);
122
+ } else {
123
+ this.registerRange(parser, arg);
124
+ }
125
+ });
126
+ return parser.parse;
127
+ }
128
+ registerSingle(parser, ...codes) {
129
+ codes.forEach((code) => {
130
+ if (__privateGet(this, _map).has(code)) {
131
+ throw new import_errors.AutomationError(
132
+ `Status code ${code} is already registered with a parser`
133
+ );
134
+ }
135
+ assertIsStatusCode(code);
136
+ __privateGet(this, _map).set(code, parser);
137
+ });
138
+ }
139
+ including(map) {
140
+ __privateGet(this, _children).includes(map);
141
+ return this;
142
+ }
143
+ registerRange(parser, ...range) {
144
+ range.forEach(({ from, to }) => {
145
+ assertIsStatusCode(from);
146
+ assertIsStatusCode(to);
147
+ for (let i = from; i <= to; i++) {
148
+ if (!IsStatusCode(i)) {
149
+ continue;
150
+ }
151
+ if (__privateGet(this, _map).has(i)) {
152
+ throw new import_errors.AutomationError(
153
+ `Status code ${i} is already registered with a parser`
154
+ );
155
+ }
156
+ __privateGet(this, _map).set(i, parser);
157
+ }
158
+ });
159
+ }
160
+ get(status) {
161
+ assertIsStatusCode(status);
162
+ const local = __privateGet(this, _map).get(status);
163
+ if (local) {
164
+ return local;
165
+ }
166
+ const nested = __privateGet(this, _children).find((it) => __privateGet(it, _map).has(status));
167
+ return nested?.get(status);
168
+ }
169
+ validate(status, response, strict) {
170
+ const parser = this.get(status);
171
+ if (!parser) {
172
+ if (!strict) {
173
+ return response;
174
+ }
175
+ throw new import_errors.AutomationError(
176
+ `No schema parser registered for status code ${status} and 'requireSchema' is set to true`
177
+ );
178
+ }
179
+ return parser.parse(response);
180
+ }
181
+ };
182
+ _children = new WeakMap();
183
+ _map = new WeakMap();
184
+ function assertIsStatusCode(value) {
185
+ const result = Object.values(import_status_codes.StatusCodes).map((it) => it.status).includes(value);
186
+ if (!result) {
187
+ throw new import_errors.AutomationError(
188
+ `Expected status code ${value} to be a valid status code, but it is not a known HTTP codeF`
189
+ );
190
+ }
191
+ }
192
+ function IsStatusCode(value) {
193
+ return Object.values(import_status_codes.StatusCodes).map((it) => it.status).includes(value);
194
+ }
195
+
196
+ // src/http.builder.ts
197
+ var import_assert_is_json = __toESM(require("@stdlib/assert-is-json"), 1);
198
+ var import_cli_highlight = __toESM(require("cli-highlight"), 1);
199
+ var _headers, _params, _url, _route, _method, _schemaMap, _responseType, _data, _requireSchema, _allowPlainText, _onBeforeSend, _onAfterSend;
200
+ var HTTPRequestBuilder = class {
201
+ constructor(map) {
202
+ __privateAdd(this, _headers, /* @__PURE__ */ new Map());
203
+ __privateAdd(this, _params, /* @__PURE__ */ new Map());
204
+ __privateAdd(this, _url, void 0);
205
+ __privateAdd(this, _route, []);
206
+ __privateAdd(this, _method, void 0);
207
+ __privateAdd(this, _schemaMap, new SchemaMap());
208
+ __privateAdd(this, _responseType, "json");
209
+ __privateAdd(this, _data, void 0);
210
+ __privateAdd(this, _requireSchema, false);
211
+ __privateAdd(this, _allowPlainText, false);
212
+ __privateAdd(this, _onBeforeSend, []);
213
+ __privateAdd(this, _onAfterSend, []);
214
+ __privateSet(this, _schemaMap, new SchemaMap().including(map));
215
+ }
216
+ requireSchema(value) {
217
+ __privateSet(this, _requireSchema, value);
218
+ return this;
219
+ }
220
+ get currentState() {
221
+ const fullUrl = this.currentUrl;
222
+ return {
223
+ headers: __privateGet(this, _headers),
224
+ params: __privateGet(this, _params),
225
+ url: __privateGet(this, _url),
226
+ route: __privateGet(this, _route),
227
+ responseType: __privateGet(this, _responseType),
228
+ data: __privateGet(this, _data),
229
+ method: __privateGet(this, _method),
230
+ fullUrl
231
+ };
232
+ }
233
+ get currentUrl() {
234
+ const params = Object.fromEntries(__privateGet(this, _params));
235
+ return (0, import_url_join_ts.urlJoinP)(__privateGet(this, _url), __privateGet(this, _route), params);
236
+ }
237
+ url(url) {
238
+ __privateSet(this, _url, url);
239
+ return this;
240
+ }
241
+ allowPlainText(value) {
242
+ __privateSet(this, _allowPlainText, value);
243
+ return this;
244
+ }
245
+ schema(parser, ...args) {
246
+ __privateGet(this, _schemaMap).register(parser, ...args);
247
+ return this;
248
+ }
249
+ onBeforeSend(hook) {
250
+ __privateGet(this, _onBeforeSend).push(hook);
251
+ return this;
252
+ }
253
+ onReceivedResponse(hook) {
254
+ __privateGet(this, _onAfterSend).push(hook);
255
+ return this;
256
+ }
257
+ route(...route) {
258
+ __privateGet(this, _route).push(...route.map((it) => `${it}`));
259
+ return this;
260
+ }
261
+ header(name, value) {
262
+ __privateGet(this, _headers).set(name, value);
263
+ return this;
264
+ }
265
+ headers(dict) {
266
+ Object.entries(dict).forEach(
267
+ ([name, value]) => __privateGet(this, _headers).set(name, value)
268
+ );
269
+ return this;
270
+ }
271
+ param(name, value) {
272
+ __privateGet(this, _params).set(name, value);
273
+ return this;
274
+ }
275
+ params(dict) {
276
+ Object.entries(dict).forEach(
277
+ ([name, value]) => __privateGet(this, _params).set(name, value)
278
+ );
279
+ return this;
280
+ }
281
+ data(data) {
282
+ __privateSet(this, _data, data);
283
+ return this;
284
+ }
285
+ async post() {
286
+ return this._request("POST");
287
+ }
288
+ async get() {
289
+ return this._request("GET");
290
+ }
291
+ async delete() {
292
+ return this._request("DELETE");
293
+ }
294
+ async put() {
295
+ return this._request("PUT");
296
+ }
297
+ async _request(method) {
298
+ __privateSet(this, _method, method);
299
+ const url = this.currentUrl;
300
+ const headers = __privateGet(this, _headers) && Object.fromEntries(__privateGet(this, _headers));
301
+ const responseType = __privateGet(this, _responseType);
302
+ const data = __privateGet(this, _data);
303
+ try {
304
+ this.tryRunBeforeHooks();
305
+ const response = await (0, import_axios.default)({
306
+ method,
307
+ url,
308
+ headers,
309
+ data,
310
+ responseType,
311
+ validateStatus: function(status) {
312
+ return status >= 100 && status < 500;
313
+ },
314
+ transformResponse: transformResponse.bind(null, __privateGet(this, _allowPlainText))
315
+ });
316
+ const instance = this.makeResponse(response);
317
+ this.tryRunAfterHooks(instance);
318
+ return instance;
319
+ } catch (e) {
320
+ const error = e;
321
+ const message = `HTTP Client failed while while making request to ${url} with:
322
+ * headers: ${JSON.stringify(headers, null, 2)}
323
+
324
+ * data: ${data && JSON.stringify(data, null, 2)}`;
325
+ throw new import_errors2.AutomationError(message, { cause: error });
326
+ } finally {
327
+ __privateGet(this, _headers).clear();
328
+ __privateGet(this, _params).clear();
329
+ __privateSet(this, _route, []);
330
+ __privateSet(this, _url, "");
331
+ __privateSet(this, _responseType, void 0);
332
+ __privateSet(this, _data, void 0);
333
+ }
334
+ }
335
+ tryRunBeforeHooks() {
336
+ let index = 0;
337
+ try {
338
+ for (const hook of __privateGet(this, _onBeforeSend)) {
339
+ hook(this.currentState);
340
+ index++;
341
+ }
342
+ } catch (e) {
343
+ const error = e;
344
+ const message = `HTTP Client encountered an error while running 'onBeforeRequest' hooks at index ${index}`;
345
+ throw new import_errors2.AutomationError(message, { cause: error });
346
+ }
347
+ }
348
+ tryRunAfterHooks(response) {
349
+ let index = 0;
350
+ try {
351
+ for (const hook of __privateGet(this, _onAfterSend)) {
352
+ hook(response);
353
+ index++;
354
+ }
355
+ } catch (e) {
356
+ const error = e;
357
+ const message = `HTTP Client encountered an error while running 'onAfterRequest' hooks at index ${index}`;
358
+ throw new import_errors2.AutomationError(message, { cause: error });
359
+ }
360
+ }
361
+ makeResponse(res) {
362
+ const { status, data, statusText, headers } = res;
363
+ const parsed = __privateGet(this, _schemaMap).validate(
364
+ status,
365
+ data,
366
+ __privateGet(this, _requireSchema)
367
+ );
368
+ const params = Object.fromEntries(__privateGet(this, _params));
369
+ const url = (0, import_url_join_ts.urlJoinP)(__privateGet(this, _url), __privateGet(this, _route), params);
370
+ return (0, import_class_transformer.plainToClass)(HTTPResponse, {
371
+ status,
372
+ statusText,
373
+ headers,
374
+ data: parsed,
375
+ request: {
376
+ url
377
+ }
378
+ });
379
+ }
380
+ };
381
+ _headers = new WeakMap();
382
+ _params = new WeakMap();
383
+ _url = new WeakMap();
384
+ _route = new WeakMap();
385
+ _method = new WeakMap();
386
+ _schemaMap = new WeakMap();
387
+ _responseType = new WeakMap();
388
+ _data = new WeakMap();
389
+ _requireSchema = new WeakMap();
390
+ _allowPlainText = new WeakMap();
391
+ _onBeforeSend = new WeakMap();
392
+ _onAfterSend = new WeakMap();
393
+ HTTPRequestBuilder = __decorateClass([
394
+ (0, import_app.Fixture)(import_app.LIFE_CYCLE.Transient)
395
+ ], HTTPRequestBuilder);
396
+ function transformResponse(allowPlainText, data) {
397
+ if ((0, import_assert_is_json.default)(data)) {
398
+ return JSON.parse(data);
399
+ }
400
+ if (["true", "false"].includes(data)) {
401
+ return JSON.parse(data);
402
+ }
403
+ const asNumber = Number(data);
404
+ if (!isNaN(asNumber)) {
405
+ return asNumber;
406
+ }
407
+ if (allowPlainText) {
408
+ return data;
409
+ }
410
+ const response = (0, import_cli_highlight.default)(data, { language: "html" });
411
+ const message = [
412
+ `HTTP Client received a response which could not be parsed as JSON, and plain text responses were not configured for this request, Instead the body was:`,
413
+ " ",
414
+ response
415
+ ];
416
+ throw new import_errors2.AutomationError(message.join("\n"));
417
+ }
418
+
419
+ // src/http.ts
420
+ var import_app2 = require("@autometa/app");
421
+ var _url2, _route2, _headers2, _requireSchema2, _schemaMap2, _onBeforeSend2, _onAfterSend2, _allowPlainText2;
422
+ var HTTP = class {
423
+ constructor() {
424
+ __privateAdd(this, _url2, void 0);
425
+ __privateAdd(this, _route2, []);
426
+ __privateAdd(this, _headers2, /* @__PURE__ */ new Map());
427
+ __privateAdd(this, _requireSchema2, false);
428
+ __privateAdd(this, _schemaMap2, new SchemaMap());
429
+ __privateAdd(this, _onBeforeSend2, []);
430
+ __privateAdd(this, _onAfterSend2, []);
431
+ __privateAdd(this, _allowPlainText2, false);
432
+ }
433
+ allowPlainText(value) {
434
+ __privateSet(this, _allowPlainText2, value);
435
+ return this;
436
+ }
437
+ requireSchema(value) {
438
+ __privateSet(this, _requireSchema2, value);
439
+ return this;
440
+ }
441
+ url(url) {
442
+ __privateSet(this, _url2, url);
443
+ return this;
444
+ }
445
+ sharedOnBeforeSend(hook) {
446
+ __privateGet(this, _onBeforeSend2).push(hook);
447
+ return this;
448
+ }
449
+ sharedOnReceiveResponse(hook) {
450
+ __privateGet(this, _onAfterSend2).push(hook);
451
+ return this;
452
+ }
453
+ onBeforeSend(hook) {
454
+ return this.builder().onBeforeSend(hook);
455
+ }
456
+ onReceiveResponse(hook) {
457
+ return this.builder().onReceivedResponse(hook);
458
+ }
459
+ shareSchema(parser, ...args) {
460
+ __privateGet(this, _schemaMap2).register(parser, ...args);
461
+ return this;
462
+ }
463
+ schema(parser, ...args) {
464
+ return this.builder().schema(parser, ...args);
465
+ }
466
+ sharedRoute(...route) {
467
+ __privateGet(this, _route2).push(...route);
468
+ return this;
469
+ }
470
+ param(name, value) {
471
+ return this.builder().param(name, value);
472
+ }
473
+ params(dict) {
474
+ return this.builder().params(dict);
475
+ }
476
+ data(data) {
477
+ return this.builder().data(data);
478
+ }
479
+ sharedHeader(name, value) {
480
+ __privateGet(this, _headers2).set(name, value);
481
+ return this;
482
+ }
483
+ route(...route) {
484
+ return this.builder().route(...route);
485
+ }
486
+ header(name, value) {
487
+ return this.builder().header(name, value);
488
+ }
489
+ headers(dict) {
490
+ return this.builder().headers(dict);
491
+ }
492
+ get() {
493
+ return this.builder().get();
494
+ }
495
+ builder() {
496
+ return new HTTPRequestBuilder(__privateGet(this, _schemaMap2)).url(__privateGet(this, _url2)).route(...__privateGet(this, _route2)).allowPlainText(__privateGet(this, _allowPlainText2)).headers(Object.fromEntries(__privateGet(this, _headers2))).requireSchema(__privateGet(this, _requireSchema2)).onBeforeSend((state) => {
497
+ __privateGet(this, _onBeforeSend2).forEach((it) => it(state));
498
+ }).onReceivedResponse((state) => {
499
+ __privateGet(this, _onAfterSend2).forEach((it) => it(state));
500
+ });
501
+ }
502
+ };
503
+ _url2 = new WeakMap();
504
+ _route2 = new WeakMap();
505
+ _headers2 = new WeakMap();
506
+ _requireSchema2 = new WeakMap();
507
+ _schemaMap2 = new WeakMap();
508
+ _onBeforeSend2 = new WeakMap();
509
+ _onAfterSend2 = new WeakMap();
510
+ _allowPlainText2 = new WeakMap();
511
+ HTTP = __decorateClass([
512
+ (0, import_app2.Fixture)(import_app2.LIFE_CYCLE.Transient)
513
+ ], HTTP);
514
+ // Annotate the CommonJS export names for ESM import in node:
515
+ 0 && (module.exports = {
516
+ DerivedHTTPResponse,
517
+ HTTP,
518
+ HTTPRequestBuilder,
519
+ HTTPResponse,
520
+ IsStatusCode,
521
+ SchemaMap,
522
+ assertIsStatusCode
523
+ });
524
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts","../src/http.builder.ts","../src/http.response.ts","../src/schema.map.ts","../src/http.ts"],"sourcesContent":["export * from \"./http.builder\";\nexport * from \"./http.response\";\nexport * from \"./types\";\nexport * from \"./schema.map\";\nexport * from \"./http\";\n","import { Fixture, LIFE_CYCLE } from \"@autometa/app\";\nimport { AutomationError } from \"@autometa/errors\";\nimport axios, { AxiosResponse, Method, ResponseType } from \"axios\";\nimport { plainToClass } from \"class-transformer\";\nimport { urlJoinP } from \"url-join-ts\";\nimport { HTTPResponse } from \"./http.response\";\nimport { SchemaMap } from \"./schema.map\";\nimport { SchemaParser, StatusCode } from \"./types\";\nimport isJson from \"@stdlib/assert-is-json\";\nimport highlight from \"cli-highlight\";\nexport type RequestState = {\n headers: Map<string, string>;\n params: Map<string, string>;\n url: string;\n route: string[];\n responseType: ResponseType | undefined;\n data: unknown;\n method: Method;\n get fullUrl(): string;\n};\n\nexport type RequestHook = (state: RequestState) => unknown;\nexport type ResponseHook<T> = (state: HTTPResponse<T>) => unknown;\n\n@Fixture(LIFE_CYCLE.Transient)\nexport class HTTPRequestBuilder {\n #headers = new Map<string, string>();\n #params = new Map<string, string>();\n #url: string;\n #route: string[] = [];\n #method: Method;\n #schemaMap = new SchemaMap();\n #responseType: ResponseType | undefined = \"json\";\n #data: unknown;\n #requireSchema = false;\n #allowPlainText = false;\n #onBeforeSend: RequestHook[] = [];\n #onAfterSend: ResponseHook<unknown>[] = [];\n constructor(map: SchemaMap) {\n this.#schemaMap = new SchemaMap().including(map);\n }\n requireSchema(value: boolean) {\n this.#requireSchema = value;\n return this;\n }\n get currentState(): RequestState {\n const fullUrl = this.currentUrl;\n return {\n headers: this.#headers,\n params: this.#params,\n url: this.#url,\n route: this.#route,\n responseType: this.#responseType,\n data: this.#data,\n method: this.#method,\n fullUrl\n };\n }\n\n get currentUrl() {\n const params = Object.fromEntries(this.#params);\n return urlJoinP(this.#url, this.#route, params);\n }\n\n url(url: string) {\n this.#url = url;\n return this;\n }\n allowPlainText(value: boolean) {\n this.#allowPlainText = value;\n return this;\n }\n schema(parser: SchemaParser, ...codes: number[]): HTTPRequestBuilder;\n schema(\n parser: SchemaParser,\n ...range: { from: number; to: number }[]\n ): HTTPRequestBuilder;\n\n schema(\n parser: SchemaParser,\n ...args: (number | { from: number; to: number })[]\n ) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n this.#schemaMap.register(parser, ...(args as any));\n return this;\n }\n\n onBeforeSend(hook: RequestHook) {\n this.#onBeforeSend.push(hook);\n return this;\n }\n\n onReceivedResponse(hook: ResponseHook<unknown>) {\n this.#onAfterSend.push(hook);\n return this;\n }\n\n route(...route: (string | number | boolean)[]) {\n this.#route.push(...route.map((it) => `${it}`));\n return this;\n }\n\n header(name: string, value: string) {\n this.#headers.set(name, value);\n return this;\n }\n\n headers(dict: Record<string, string>) {\n Object.entries(dict).forEach(([name, value]) =>\n this.#headers.set(name, value)\n );\n return this;\n }\n\n param(name: string, value: string) {\n this.#params.set(name, value);\n return this;\n }\n\n params(dict: Record<string, string>) {\n Object.entries(dict).forEach(([name, value]) =>\n this.#params.set(name, value)\n );\n return this;\n }\n\n data<T>(data: T) {\n this.#data = data;\n return this;\n }\n\n async post<TReturn>(): Promise<HTTPResponse<TReturn>> {\n return this._request(\"POST\");\n }\n\n async get<TReturn>(): Promise<HTTPResponse<TReturn>> {\n return this._request(\"GET\");\n }\n\n async delete<TReturn>(): Promise<HTTPResponse<TReturn>> {\n return this._request(\"DELETE\");\n }\n\n async put<TReturn>(): Promise<HTTPResponse<TReturn>> {\n return this._request(\"PUT\");\n }\n\n private async _request<T>(method: Method) {\n this.#method = method;\n const url = this.currentUrl;\n const headers = this.#headers && Object.fromEntries(this.#headers);\n const responseType = this.#responseType;\n const data = this.#data;\n try {\n this.tryRunBeforeHooks();\n const response = await axios({\n method,\n url,\n headers,\n data,\n responseType,\n validateStatus: function (status) {\n return status >= 100 && status < 500;\n },\n transformResponse: transformResponse.bind(null, this.#allowPlainText)\n });\n const instance = this.makeResponse<T>(response);\n\n this.tryRunAfterHooks<T>(instance);\n return instance;\n } catch (e) {\n const error = e as Error;\n const message = `HTTP Client failed while while making request to ${url} with:\n* headers: ${JSON.stringify(headers, null, 2)}\n\n* data: ${data && JSON.stringify(data, null, 2)}`;\n throw new AutomationError(message, { cause: error });\n } finally {\n this.#headers.clear();\n this.#params.clear();\n this.#route = [];\n this.#url = \"\";\n this.#responseType = undefined;\n this.#data = undefined;\n }\n }\n\n private tryRunBeforeHooks() {\n let index = 0;\n try {\n for (const hook of this.#onBeforeSend) {\n hook(this.currentState);\n index++;\n }\n } catch (e) {\n const error = e as Error;\n const message = `HTTP Client encountered an error while running 'onBeforeRequest' hooks at index ${index}`;\n throw new AutomationError(message, { cause: error });\n }\n }\n private tryRunAfterHooks<T>(response: HTTPResponse<T>) {\n let index = 0;\n try {\n for (const hook of this.#onAfterSend) {\n hook(response);\n index++;\n }\n } catch (e) {\n const error = e as Error;\n const message = `HTTP Client encountered an error while running 'onAfterRequest' hooks at index ${index}`;\n throw new AutomationError(message, { cause: error });\n }\n }\n makeResponse<T>(res: AxiosResponse) {\n const { status, data, statusText, headers } = res;\n const parsed = this.#schemaMap.validate<T>(\n status as StatusCode,\n data,\n this.#requireSchema\n );\n const params = Object.fromEntries(this.#params);\n const url = urlJoinP(this.#url, this.#route, params);\n return plainToClass(HTTPResponse<T>, {\n status,\n statusText,\n headers,\n data: parsed,\n request: {\n url\n }\n });\n }\n}\n\nfunction transformResponse(allowPlainText: boolean, data: string) {\n if (isJson(data)) {\n return JSON.parse(data);\n }\n if ([\"true\", \"false\"].includes(data)) {\n return JSON.parse(data);\n }\n const asNumber = Number(data);\n if (!isNaN(asNumber)) {\n return asNumber;\n }\n if (allowPlainText) {\n return data;\n }\n const response = highlight(data, { language: \"html\" });\n const message = [\n `HTTP Client received a response which could not be parsed as JSON, and plain text responses were not configured for this request, Instead the body was:`,\n \" \",\n response\n ];\n throw new AutomationError(message.join(\"\\n\"));\n}\n","export class HTTPResponse<T> {\n status: number;\n statusText: string;\n data: T;\n headers: Record<string, string>;\n request: {\n url: string;\n };\n\n static fromRaw<T>(\n data: T,\n status: number,\n statusText: string,\n headers: Record<string, string>,\n url: string\n ) {\n const response = new HTTPResponse<T>();\n response.data = data;\n response.status = status;\n response.statusText = statusText;\n response.headers = headers;\n response.request = {\n url\n };\n return response;\n }\n static derive<TOriginal, TDerived>(\n original: HTTPResponse<TOriginal>,\n data: TDerived\n ): HTTPResponse<TDerived>;\n static derive<TOriginal, TDerived>(\n original: HTTPResponse<TOriginal>,\n data: (original: TOriginal) => TDerived\n ): HTTPResponse<TDerived>;\n static derive<TOriginal, TDerived>(\n original: HTTPResponse<TOriginal>,\n data: TDerived | ((original: TOriginal) => TDerived)\n ) {\n const response = new DerivedHTTPResponse<TDerived, TOriginal>();\n if (typeof data === \"function\") {\n const fn = data as (original: TOriginal) => TDerived;\n response.data = fn(original.data);\n } else {\n response.data = data;\n }\n response.status = original.status;\n response.statusText = original.statusText;\n response.headers = original.headers;\n response.request = original.request;\n response.actual = original as HTTPResponse<TOriginal>;\n return response;\n }\n}\n\nexport class DerivedHTTPResponse<T, K> extends HTTPResponse<T> {\n actual: HTTPResponse<K>;\n}\n","import { StatusCode, SchemaParser } from \"./types\";\nimport { AutomationError } from \"@autometa/errors\";\nimport { StatusCodes } from \"@autometa/status-codes\";\n\nexport class SchemaMap {\n #children: SchemaMap[] = [];\n #map: Map<StatusCode, SchemaParser> = new Map();\n register(\n parser: SchemaParser,\n ...codes: StatusCode[]\n ): (typeof parser)[\"parse\"];\n register(\n parser: SchemaParser,\n ...range: { from: StatusCode; to: StatusCode }[]\n ): (typeof parser)[\"parse\"];\n register(\n parser: SchemaParser,\n ...args: (StatusCode | { from: StatusCode; to: StatusCode })[]\n ) {\n args.forEach((arg) => {\n if (typeof arg === \"number\") {\n this.registerSingle(parser, arg);\n } else {\n this.registerRange(parser, arg);\n }\n });\n return parser.parse;\n }\n\n registerSingle(parser: SchemaParser, ...codes: StatusCode[]) {\n codes.forEach((code) => {\n if (this.#map.has(code)) {\n throw new AutomationError(\n `Status code ${code} is already registered with a parser`\n );\n }\n assertIsStatusCode(code);\n this.#map.set(code, parser);\n });\n }\n\n including(map: SchemaMap) {\n this.#children.includes(map);\n return this;\n }\n registerRange(\n parser: SchemaParser,\n ...range: { from: StatusCode; to: StatusCode }[]\n ) {\n range.forEach(({ from, to }) => {\n assertIsStatusCode(from);\n assertIsStatusCode(to);\n for (let i = from; i <= to; i++) {\n if (!IsStatusCode(i)) {\n continue;\n }\n if (this.#map.has(i)) {\n throw new AutomationError(\n `Status code ${i} is already registered with a parser`\n );\n }\n this.#map.set(i, parser);\n }\n });\n }\n\n get(status: StatusCode): SchemaParser | undefined {\n assertIsStatusCode(status);\n const local = this.#map.get(status);\n if (local) {\n return local;\n }\n const nested = this.#children.find((it) => it.#map.has(status));\n return nested?.get(status);\n }\n\n validate<T>(status: StatusCode, response: T, strict: boolean) {\n const parser = this.get(status);\n if (!parser) {\n if (!strict) {\n return response;\n }\n throw new AutomationError(\n `No schema parser registered for status code ${status} and 'requireSchema' is set to true`\n );\n }\n return parser.parse(response);\n }\n}\n\nexport function assertIsStatusCode(value: number): asserts value is StatusCode {\n const result = Object.values(StatusCodes)\n .map((it) => it.status as number)\n .includes(value);\n if (!result) {\n throw new AutomationError(\n `Expected status code ${value} to be a valid status code, but it is not a known HTTP codeF`\n );\n }\n}\n\nexport function IsStatusCode(value: number): value is StatusCode {\n return Object.values(StatusCodes)\n .map((it) => it.status as number)\n .includes(value);\n}\n","import { Fixture, LIFE_CYCLE } from \"@autometa/app\";\nimport { HTTPRequestBuilder, RequestHook, ResponseHook } from \"./http.builder\";\nimport { SchemaMap } from \"./schema.map\";\nimport { SchemaParser, StatusCode } from \"./types\";\n@Fixture(LIFE_CYCLE.Transient)\nexport class HTTP {\n #url: string;\n #route: string[] = [];\n #headers = new Map<string, string>();\n #requireSchema = false;\n #schemaMap: SchemaMap = new SchemaMap();\n #onBeforeSend: RequestHook[] = [];\n #onAfterSend: ResponseHook<unknown>[] = [];\n #allowPlainText = false;\n\n allowPlainText(value: boolean) {\n this.#allowPlainText = value;\n return this;\n }\n requireSchema(value: boolean) {\n this.#requireSchema = value;\n return this;\n }\n\n url(url: string) {\n this.#url = url;\n return this;\n }\n\n sharedOnBeforeSend(hook: RequestHook) {\n this.#onBeforeSend.push(hook);\n return this;\n }\n\n sharedOnReceiveResponse(hook: ResponseHook<unknown>) {\n this.#onAfterSend.push(hook);\n return this;\n }\n\n onBeforeSend(hook: RequestHook) {\n return this.builder().onBeforeSend(hook);\n }\n\n onReceiveResponse(hook: ResponseHook<unknown>) {\n return this.builder().onReceivedResponse(hook);\n }\n\n shareSchema(parser: SchemaParser, ...codes: StatusCode[]): HTTP;\n shareSchema(\n parser: SchemaParser,\n ...range: { from: StatusCode; to: StatusCode }[]\n ): HTTP;\n shareSchema(\n parser: SchemaParser,\n ...args: (StatusCode | { from: StatusCode; to: StatusCode })[]\n ) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n this.#schemaMap.register(parser, ...(args as any));\n return this;\n }\n\n schema(parser: SchemaParser, ...codes: StatusCode[]): HTTPRequestBuilder;\n schema(\n parser: SchemaParser,\n ...range: { from: StatusCode; to: StatusCode }[]\n ): HTTPRequestBuilder;\n schema(\n parser: SchemaParser,\n ...args: (StatusCode | { from: StatusCode; to: StatusCode })[]\n ) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return this.builder().schema(parser, ...(args as any));\n }\n\n sharedRoute(...route: string[]) {\n this.#route.push(...route);\n return this;\n }\n\n param(name: string, value: string) {\n return this.builder().param(name, value);\n }\n\n params(dict: Record<string, string>) {\n return this.builder().params(dict);\n }\n\n data<T>(data: T) {\n return this.builder().data(data);\n }\n\n sharedHeader(name: string, value: string) {\n this.#headers.set(name, value);\n return this;\n }\n\n route(...route: (string | number | boolean)[]) {\n return this.builder().route(...route);\n }\n\n header(name: string, value: string) {\n return this.builder().header(name, value);\n }\n\n headers(dict: Record<string, string>) {\n return this.builder().headers(dict);\n }\n\n get() {\n return this.builder().get();\n }\n\n private builder() {\n return new HTTPRequestBuilder(this.#schemaMap)\n .url(this.#url)\n .route(...this.#route)\n .allowPlainText(this.#allowPlainText)\n .headers(Object.fromEntries(this.#headers))\n .requireSchema(this.#requireSchema)\n .onBeforeSend((state) => {\n this.#onBeforeSend.forEach((it) => it(state));\n })\n .onReceivedResponse((state) => {\n this.#onAfterSend.forEach((it) => it(state));\n });\n }\n}\n"],"mappings":"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","names":["import_errors","axios","isJson","highlight","import_app","_url","_route","_headers","_requireSchema","_schemaMap","_onBeforeSend","_onAfterSend","_allowPlainText"]}
package/package.json ADDED
@@ -0,0 +1,51 @@
1
+ {
2
+ "name": "@autometa/http",
3
+ "version": "0.1.0",
4
+ "description": "An Axios Based HTTP Client for Autometa",
5
+ "type": "module",
6
+ "main": "dist/index.js",
7
+ "module": "dist/esm/index.js",
8
+ "types": "dist/index.d.ts",
9
+ "exports": {
10
+ "import": "./dist/esm/index.js",
11
+ "require": "./dist/index.js",
12
+ "default": "./dist/esm/index.js",
13
+ "types": "./dist/index.d.ts"
14
+ },
15
+ "license": "MIT",
16
+ "devDependencies": {
17
+ "@types/node": "^18.11.18",
18
+ "@types/uuid": "^9.0.1",
19
+ "@typescript-eslint/eslint-plugin": "^5.54.1",
20
+ "@typescript-eslint/parser": "^5.54.1",
21
+ "eslint": "^8.37.0",
22
+ "eslint-config-custom": "0.6.0",
23
+ "eslint-config-prettier": "^8.3.0",
24
+ "rimraf": "^4.1.2",
25
+ "tsconfig": " *",
26
+ "tsup": "^7.2.0",
27
+ "typescript": "^4.9.5",
28
+ "vitest": "0.34.6"
29
+ },
30
+ "dependencies": {
31
+ "@autometa/app": "^0.1.13",
32
+ "@autometa/errors": "^0.1.4",
33
+ "@autometa/status-codes": "^0.4.1",
34
+ "@stdlib/assert-is-json": "^0.1.1",
35
+ "axios": "^1.5.1",
36
+ "class-transformer": "^0.5.1",
37
+ "cli-highlight": "^2.1.11",
38
+ "reflect-metadata": "^0.1.13",
39
+ "url-join-ts": "^1.0.5"
40
+ },
41
+ "scripts": {
42
+ "test": "vitest run --passWithNoTests",
43
+ "prettify": "prettier --config .prettierrc 'src/**/*.ts' --write",
44
+ "lint": "eslint . --max-warnings 0",
45
+ "lint:fix": "eslint . --fix",
46
+ "clean": "rimraf dist",
47
+ "build": "tsup",
48
+ "build:watch": "tsup --watch"
49
+ },
50
+ "readme": "# Introduction\n\nThere's nothing here yet"
51
+ }
package/tsup.config.ts ADDED
@@ -0,0 +1,14 @@
1
+ import { defineConfig } from "tsup";
2
+
3
+ export default defineConfig({
4
+ clean: true, // clean up the dist folder
5
+ format: ["cjs", "esm"], // generate cjs and esm files
6
+ dts: true,
7
+ sourcemap:true, // generate sourcemaps
8
+ skipNodeModulesBundle: true,
9
+ entryPoints: ["src/index.ts"],
10
+ target: "es2020",
11
+ outDir: "dist",
12
+ legacyOutput: true,
13
+ external: ["dist"],
14
+ });