@thisisagile/easy 12.19.12 → 12.19.14
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/http/RequestOptions.d.ts +3 -1
- package/dist/http/RequestOptions.js +4 -0
- package/dist/http/RequestOptions.js.map +1 -1
- package/dist/services/AxiosProvider.js +1 -0
- package/dist/services/AxiosProvider.js.map +1 -1
- package/package.json +2 -2
- package/src/http/RequestOptions.ts +7 -2
- package/src/services/AxiosProvider.ts +22 -5
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Enum, Id, PageOptions, Text } from '../types';
|
|
1
|
+
import { CacheAge, Enum, Id, PageOptions, Text } from '../types';
|
|
2
2
|
import { ContentType } from './ContentType';
|
|
3
3
|
export declare const toPageOptions: (options?: RequestOptions | PageOptions) => PageOptions | undefined;
|
|
4
4
|
export declare class RequestOptions extends Enum {
|
|
@@ -10,6 +10,7 @@ export declare class RequestOptions extends Enum {
|
|
|
10
10
|
requestOptions: {
|
|
11
11
|
maxRedirects?: number;
|
|
12
12
|
validateStatus?: (status: number) => boolean;
|
|
13
|
+
timeout?: CacheAge;
|
|
13
14
|
};
|
|
14
15
|
constructor(type?: ContentType, headers?: {
|
|
15
16
|
[key: string]: any;
|
|
@@ -29,5 +30,6 @@ export declare class RequestOptions extends Enum {
|
|
|
29
30
|
basic: (username: Text, password: Text) => this;
|
|
30
31
|
maxRedirects: (max?: number) => this;
|
|
31
32
|
validateStatus: (validate?: ((status: number) => boolean) | undefined) => this;
|
|
33
|
+
timeout: (t?: CacheAge) => this;
|
|
32
34
|
}
|
|
33
35
|
export declare const isRequestOptions: (o?: unknown) => o is RequestOptions;
|
|
@@ -37,6 +37,10 @@ class RequestOptions extends types_1.Enum {
|
|
|
37
37
|
this.requestOptions.validateStatus = validate;
|
|
38
38
|
return this;
|
|
39
39
|
};
|
|
40
|
+
this.timeout = (t) => {
|
|
41
|
+
this.requestOptions.timeout = t;
|
|
42
|
+
return this;
|
|
43
|
+
};
|
|
40
44
|
this.headers['Content-Type'] = type.id;
|
|
41
45
|
this.headers[HttpHeader_1.HttpHeader.Correlation] = types_1.ctx.request.correlationId ?? (0, types_1.toUuid)();
|
|
42
46
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RequestOptions.js","sourceRoot":"","sources":["../../src/http/RequestOptions.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"RequestOptions.js","sourceRoot":"","sources":["../../src/http/RequestOptions.ts"],"names":[],"mappings":"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"}
|
|
@@ -23,6 +23,7 @@ class AxiosProvider {
|
|
|
23
23
|
headers: uri.isInternal && (0, types_1.isEmpty)(options.headers.Authorization) ? options.bearer(types_1.ctx.request.jwt).headers : options.headers,
|
|
24
24
|
data: options.type.encode(body),
|
|
25
25
|
maxRedirects: options.requestOptions.maxRedirects,
|
|
26
|
+
...(options.requestOptions.timeout && { timeout: types_1.cacheAge.toMilliseconds(options?.requestOptions.timeout) }),
|
|
26
27
|
...(options.requestOptions.validateStatus && { validateStatus: options.requestOptions.validateStatus }),
|
|
27
28
|
})
|
|
28
29
|
.then(r => (0, http_1.toResponse)(r.status, transform(r.data), r.headers))
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AxiosProvider.js","sourceRoot":"","sources":["../../src/services/AxiosProvider.ts"],"names":[],"mappings":";;;;;;AAAA,kDAAgF;AAChF,
|
|
1
|
+
{"version":3,"file":"AxiosProvider.js","sourceRoot":"","sources":["../../src/services/AxiosProvider.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@thisisagile/easy",
|
|
3
|
-
"version": "12.19.
|
|
3
|
+
"version": "12.19.14",
|
|
4
4
|
"description": "Straightforward library for building domain-driven microservice architectures",
|
|
5
5
|
"author": "Sander Hoogendoorn",
|
|
6
6
|
"license": "MIT",
|
|
@@ -31,7 +31,7 @@
|
|
|
31
31
|
"access": "public"
|
|
32
32
|
},
|
|
33
33
|
"devDependencies": {
|
|
34
|
-
"@thisisagile/easy-test": "12.19.
|
|
34
|
+
"@thisisagile/easy-test": "12.19.14",
|
|
35
35
|
"@types/form-urlencoded": "^4.4.0",
|
|
36
36
|
"@types/jsonwebtoken": "^8.5.9",
|
|
37
37
|
"@types/luxon": "3.1.0",
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ctx, Enum, Id, isDefined, isNotEmpty, on, PageOptions, Text, toUuid } from '../types';
|
|
1
|
+
import { CacheAge, ctx, Enum, Id, isDefined, isNotEmpty, on, PageOptions, Text, toUuid } from '../types';
|
|
2
2
|
import { HttpHeader } from './HttpHeader';
|
|
3
3
|
import { ContentType } from './ContentType';
|
|
4
4
|
|
|
@@ -6,7 +6,7 @@ export const toPageOptions = (options?: RequestOptions | PageOptions): PageOptio
|
|
|
6
6
|
options instanceof RequestOptions ? options.pageOptions : options;
|
|
7
7
|
|
|
8
8
|
export class RequestOptions extends Enum {
|
|
9
|
-
public requestOptions: { maxRedirects?: number; validateStatus?: (status: number) => boolean } = {};
|
|
9
|
+
public requestOptions: { maxRedirects?: number; validateStatus?: (status: number) => boolean; timeout?: CacheAge } = {};
|
|
10
10
|
|
|
11
11
|
constructor(readonly type: ContentType = ContentType.Json, readonly headers: { [key: string]: any } = {}, public pageOptions?: PageOptions) {
|
|
12
12
|
super(type.name);
|
|
@@ -67,6 +67,11 @@ export class RequestOptions extends Enum {
|
|
|
67
67
|
this.requestOptions.validateStatus = validate;
|
|
68
68
|
return this;
|
|
69
69
|
};
|
|
70
|
+
|
|
71
|
+
timeout = (t?: CacheAge): this => {
|
|
72
|
+
this.requestOptions.timeout = t;
|
|
73
|
+
return this;
|
|
74
|
+
};
|
|
70
75
|
}
|
|
71
76
|
|
|
72
77
|
export const isRequestOptions = (o?: unknown): o is RequestOptions => isDefined(o) && o instanceof RequestOptions;
|
|
@@ -1,6 +1,15 @@
|
|
|
1
1
|
import axios, { AxiosError, AxiosInstance, AxiosResponse, Method } from 'axios';
|
|
2
|
-
import {
|
|
3
|
-
|
|
2
|
+
import {
|
|
3
|
+
HttpStatus,
|
|
4
|
+
HttpVerb,
|
|
5
|
+
isRestResult,
|
|
6
|
+
Request,
|
|
7
|
+
RequestOptions,
|
|
8
|
+
RequestProvider,
|
|
9
|
+
Response,
|
|
10
|
+
toResponse
|
|
11
|
+
} from '../http';
|
|
12
|
+
import { cacheAge, choose, ctx, isDefined, isEmpty, toResult, Uri } from '../types';
|
|
4
13
|
|
|
5
14
|
const isResponse = (a: unknown): a is { response: AxiosResponse } => isDefined((a as any)?.response);
|
|
6
15
|
const isRequest = (a: unknown): a is { request: any } => isDefined((a as any)?.request);
|
|
@@ -14,17 +23,25 @@ const asResponse = (uri: Uri, verb: HttpVerb, error: AxiosError): Response =>
|
|
|
14
23
|
.else(e => toResponse(HttpStatus.InternalServerError, toResult(e.message, uri.path, uri)));
|
|
15
24
|
|
|
16
25
|
export class AxiosProvider implements RequestProvider {
|
|
17
|
-
constructor(readonly ai: AxiosInstance = axios) {
|
|
26
|
+
constructor(readonly ai: AxiosInstance = axios) {
|
|
27
|
+
}
|
|
18
28
|
|
|
19
|
-
execute = ({
|
|
29
|
+
execute = ({
|
|
30
|
+
uri,
|
|
31
|
+
verb,
|
|
32
|
+
body,
|
|
33
|
+
transform = (r: any) => r,
|
|
34
|
+
transformError = (r: any) => r,
|
|
35
|
+
options = RequestOptions.Json
|
|
36
|
+
}: Request): Promise<Response> =>
|
|
20
37
|
this.ai
|
|
21
38
|
.request({
|
|
22
39
|
url: uri.toString(),
|
|
23
40
|
method: verb.toString() as Method,
|
|
24
41
|
headers: uri.isInternal && isEmpty(options.headers.Authorization) ? options.bearer(ctx.request.jwt).headers : options.headers,
|
|
25
42
|
data: options.type.encode(body),
|
|
26
|
-
|
|
27
43
|
maxRedirects: options.requestOptions.maxRedirects,
|
|
44
|
+
...(options.requestOptions.timeout && { timeout: cacheAge.toMilliseconds(options?.requestOptions.timeout) }),
|
|
28
45
|
...(options.requestOptions.validateStatus && { validateStatus: options.requestOptions.validateStatus }),
|
|
29
46
|
})
|
|
30
47
|
.then(r => toResponse(r.status, transform(r.data), r.headers))
|