@decaf-ts/for-http 0.2.0 → 0.2.2
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/LICENSE.md +21 -157
- package/dist/for-http.cjs +313 -81
- package/dist/for-http.esm.cjs +314 -81
- package/lib/RestRepository.cjs +30 -1
- package/lib/RestRepository.d.ts +32 -2
- package/lib/RestService.cjs +154 -11
- package/lib/RestService.d.ts +156 -12
- package/lib/adapter.cjs +122 -13
- package/lib/adapter.d.ts +170 -9
- package/lib/axios/axios.cjs +99 -3
- package/lib/axios/axios.d.ts +96 -1
- package/lib/axios/constants.cjs +11 -0
- package/lib/axios/constants.d.ts +7 -0
- package/lib/axios/index.cjs +14 -1
- package/lib/axios/index.d.ts +2 -0
- package/lib/axios/types.cjs +1 -1
- package/lib/axios/types.d.ts +6 -0
- package/lib/esm/RestRepository.d.ts +32 -2
- package/lib/esm/RestRepository.js +30 -1
- package/lib/esm/RestService.d.ts +156 -12
- package/lib/esm/RestService.js +154 -11
- package/lib/esm/adapter.d.ts +170 -9
- package/lib/esm/adapter.js +123 -14
- package/lib/esm/axios/axios.d.ts +96 -1
- package/lib/esm/axios/axios.js +100 -4
- package/lib/esm/axios/constants.d.ts +7 -0
- package/lib/esm/axios/constants.js +8 -0
- package/lib/esm/axios/index.d.ts +2 -0
- package/lib/esm/axios/index.js +15 -2
- package/lib/esm/axios/types.d.ts +6 -0
- package/lib/esm/axios/types.js +1 -1
- package/lib/esm/index.d.ts +11 -16
- package/lib/esm/index.js +14 -19
- package/lib/esm/types.d.ts +15 -0
- package/lib/esm/types.js +1 -1
- package/lib/index.cjs +12 -17
- package/lib/index.d.ts +11 -16
- package/lib/types.cjs +1 -1
- package/lib/types.d.ts +15 -0
- package/package.json +2 -2
package/lib/adapter.cjs
CHANGED
|
@@ -2,27 +2,92 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.HttpAdapter = void 0;
|
|
4
4
|
const core_1 = require("@decaf-ts/core");
|
|
5
|
-
const db_decorators_1 = require("@decaf-ts/db-decorators");
|
|
6
5
|
const RestService_1 = require("./RestService.cjs");
|
|
6
|
+
/**
|
|
7
|
+
* @description Abstract HTTP adapter for REST API interactions
|
|
8
|
+
* @summary Provides a base implementation for HTTP adapters with methods for CRUD operations,
|
|
9
|
+
* URL construction, and error handling. This class extends the core Adapter class and
|
|
10
|
+
* implements the necessary methods for HTTP communication. Concrete implementations
|
|
11
|
+
* must provide specific HTTP client functionality.
|
|
12
|
+
* @template Y - The native HTTP client type
|
|
13
|
+
* @template Q - The query type used by the adapter
|
|
14
|
+
* @template F - The HTTP flags type, extending HttpFlags
|
|
15
|
+
* @template C - The context type, extending Context<F>
|
|
16
|
+
* @param {Y} native - The native HTTP client instance
|
|
17
|
+
* @param {HttpConfig} config - Configuration for the HTTP adapter
|
|
18
|
+
* @param {string} flavour - The adapter flavor identifier
|
|
19
|
+
* @param {string} [alias] - Optional alias for the adapter
|
|
20
|
+
* @example
|
|
21
|
+
* ```typescript
|
|
22
|
+
* // Example implementation with Axios
|
|
23
|
+
* class AxiosAdapter extends HttpAdapter<AxiosInstance, AxiosRequestConfig> {
|
|
24
|
+
* constructor(config: HttpConfig) {
|
|
25
|
+
* super(axios.create(), config, 'axios');
|
|
26
|
+
* }
|
|
27
|
+
*
|
|
28
|
+
* async request<V>(details: AxiosRequestConfig): Promise<V> {
|
|
29
|
+
* const response = await this.native.request(details);
|
|
30
|
+
* return response.data;
|
|
31
|
+
* }
|
|
32
|
+
*
|
|
33
|
+
* // Implement other abstract methods...
|
|
34
|
+
* }
|
|
35
|
+
* ```
|
|
36
|
+
* @class
|
|
37
|
+
*/
|
|
7
38
|
class HttpAdapter extends core_1.Adapter {
|
|
8
|
-
constructor(native, config, flavour
|
|
9
|
-
super(native, flavour);
|
|
39
|
+
constructor(native, config, flavour, alias) {
|
|
40
|
+
super(native, flavour, alias);
|
|
10
41
|
this.config = config;
|
|
11
42
|
}
|
|
12
|
-
|
|
13
|
-
|
|
43
|
+
/**
|
|
44
|
+
* @description Generates operation flags with HTTP headers
|
|
45
|
+
* @summary Extends the base flags method to include HTTP-specific headers for operations.
|
|
46
|
+
* This method adds an empty headers object to the flags returned by the parent class.
|
|
47
|
+
* @template F - The Repository Flags type
|
|
48
|
+
* @template M - The model type
|
|
49
|
+
* @param {OperationKeys.CREATE|OperationKeys.READ|OperationKeys.UPDATE|OperationKeys.DELETE} operation - The operation type
|
|
50
|
+
* @param {Constructor<M>} model - The model constructor
|
|
51
|
+
* @param {Partial<F>} overrides - Optional flag overrides
|
|
52
|
+
* @return {F} The flags object with headers
|
|
53
|
+
*/
|
|
54
|
+
flags(operation, model, overrides) {
|
|
55
|
+
return Object.assign(super.flags(operation, model, overrides), {
|
|
14
56
|
headers: {},
|
|
15
|
-
}
|
|
57
|
+
});
|
|
16
58
|
}
|
|
59
|
+
/**
|
|
60
|
+
* @description Returns the repository constructor for this adapter
|
|
61
|
+
* @summary Provides the RestService class as the repository implementation for this HTTP adapter.
|
|
62
|
+
* This method is used to create repository instances that work with this adapter type.
|
|
63
|
+
* @template M - The model type
|
|
64
|
+
* @return {Constructor<Repository<M, Q, HttpAdapter<Y, Q, F, C>>>} The repository constructor
|
|
65
|
+
*/
|
|
17
66
|
repository() {
|
|
18
67
|
return RestService_1.RestService;
|
|
19
68
|
}
|
|
69
|
+
/**
|
|
70
|
+
* @description Constructs a URL for API requests
|
|
71
|
+
* @summary Builds a complete URL for API requests using the configured protocol and host,
|
|
72
|
+
* the specified table name, and optional query parameters. The method handles URL encoding.
|
|
73
|
+
* @param {string} tableName - The name of the table or endpoint
|
|
74
|
+
* @param {Record<string, string | number>} [queryParams] - Optional query parameters
|
|
75
|
+
* @return {string} The encoded URL string
|
|
76
|
+
*/
|
|
20
77
|
url(tableName, queryParams) {
|
|
21
78
|
const url = new URL(`${this.config.protocol}://${this.config.host}/${tableName}`);
|
|
22
79
|
if (queryParams)
|
|
23
80
|
Object.entries(queryParams).forEach(([key, value]) => url.searchParams.append(key, value.toString()));
|
|
24
81
|
return encodeURI(url.toString());
|
|
25
82
|
}
|
|
83
|
+
/**
|
|
84
|
+
* @description Parses and converts errors to BaseError type
|
|
85
|
+
* @summary Processes errors that occur during HTTP operations and converts them to
|
|
86
|
+
* the appropriate BaseError type. Currently returns the error as-is, but can be
|
|
87
|
+
* extended to handle specific error messages differently.
|
|
88
|
+
* @param {Error} err - The error to parse
|
|
89
|
+
* @return {BaseError} The parsed error as a BaseError
|
|
90
|
+
*/
|
|
26
91
|
parseError(err) {
|
|
27
92
|
const { message } = err;
|
|
28
93
|
switch (message) {
|
|
@@ -30,28 +95,72 @@ class HttpAdapter extends core_1.Adapter {
|
|
|
30
95
|
return err;
|
|
31
96
|
}
|
|
32
97
|
}
|
|
98
|
+
/**
|
|
99
|
+
* @description Initializes the HTTP adapter
|
|
100
|
+
* @summary Placeholder method for adapter initialization. This method is currently
|
|
101
|
+
* a no-op but can be overridden by subclasses to perform initialization tasks.
|
|
102
|
+
* @param {...any[]} args - Initialization arguments
|
|
103
|
+
* @return {Promise<void>} A promise that resolves when initialization is complete
|
|
104
|
+
*/
|
|
33
105
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
34
106
|
async initialize(...args) {
|
|
35
107
|
// do nothing
|
|
36
108
|
}
|
|
109
|
+
/**
|
|
110
|
+
* @description Executes a raw query
|
|
111
|
+
* @summary Method for executing raw queries directly with the HTTP client.
|
|
112
|
+
* This method is not supported by default in HTTP adapters and throws an UnsupportedError.
|
|
113
|
+
* Subclasses can override this method to provide implementation.
|
|
114
|
+
* @template R - The result type
|
|
115
|
+
* @param {Q} rawInput - The raw query input
|
|
116
|
+
* @param {boolean} process - Whether to process the result
|
|
117
|
+
* @param {...any[]} args - Additional arguments
|
|
118
|
+
* @return {Promise<R>} A promise that resolves with the query result
|
|
119
|
+
* @throws {UnsupportedError} Always throws as this method is not supported by default
|
|
120
|
+
*/
|
|
37
121
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
38
122
|
raw(rawInput, process, ...args) {
|
|
39
123
|
throw new core_1.UnsupportedError("Api is not natively available for HttpAdapters. If required, please extends this class");
|
|
40
124
|
}
|
|
125
|
+
/**
|
|
126
|
+
* @description Creates a sequence
|
|
127
|
+
* @summary Method for creating a sequence for generating unique identifiers.
|
|
128
|
+
* This method is not supported by default in HTTP adapters and throws an UnsupportedError.
|
|
129
|
+
* Subclasses can override this method to provide implementation.
|
|
130
|
+
* @param {SequenceOptions} options - Options for creating the sequence
|
|
131
|
+
* @return {Promise<Sequence>} A promise that resolves with the created sequence
|
|
132
|
+
* @throws {UnsupportedError} Always throws as this method is not supported by default
|
|
133
|
+
*/
|
|
41
134
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
42
135
|
Sequence(options) {
|
|
43
136
|
throw new core_1.UnsupportedError("Api is not natively available for HttpAdapters. If required, please extends this class");
|
|
44
137
|
}
|
|
45
|
-
|
|
46
|
-
|
|
138
|
+
/**
|
|
139
|
+
* @description Creates a statement for querying
|
|
140
|
+
* @summary Method for creating a statement for building and executing queries.
|
|
141
|
+
* This method is not supported by default in HTTP adapters and throws an UnsupportedError.
|
|
142
|
+
* Subclasses can override this method to provide implementation.
|
|
143
|
+
* @template M - The model type
|
|
144
|
+
* @template ! - The raw query type
|
|
145
|
+
* @return {Statement<Q, M, any>} A statement object for building queries
|
|
146
|
+
* @throws {UnsupportedError} Always throws as this method is not supported by default
|
|
147
|
+
*/
|
|
148
|
+
Statement() {
|
|
47
149
|
throw new core_1.UnsupportedError("Api is not natively available for HttpAdapters. If required, please extends this class");
|
|
48
150
|
}
|
|
49
|
-
|
|
151
|
+
/**
|
|
152
|
+
* @description Parses a condition into a query
|
|
153
|
+
* @summary Method for parsing a condition object into a query format understood by the HTTP client.
|
|
154
|
+
* This method is not supported by default in HTTP adapters and throws an UnsupportedError.
|
|
155
|
+
* Subclasses can override this method to provide implementation.
|
|
156
|
+
* @param {Condition<any>} condition - The condition to parse
|
|
157
|
+
* @return {Q} The parsed query
|
|
158
|
+
* @throws {UnsupportedError} Always throws as this method is not supported by default
|
|
159
|
+
*/
|
|
160
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
161
|
+
parseCondition(condition) {
|
|
50
162
|
throw new core_1.UnsupportedError("Api is not natively available for HttpAdapters. If required, please extends this class");
|
|
51
163
|
}
|
|
52
|
-
get Clauses() {
|
|
53
|
-
throw new db_decorators_1.InternalError("Api is not natively available for HttpAdapters. If required, please extends this class");
|
|
54
|
-
}
|
|
55
164
|
}
|
|
56
165
|
exports.HttpAdapter = HttpAdapter;
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRhcHRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9hZGFwdGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHlDQVN3QjtBQUN4QiwyREFNaUM7QUFHakMsbURBQTRDO0FBRTVDLE1BQXNCLFdBS3BCLFNBQVEsY0FBbUI7SUFDM0IsWUFDRSxNQUFTLEVBQ0MsTUFBa0IsRUFDNUIsVUFBa0IsTUFBTTtRQUV4QixLQUFLLENBQUMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBSGIsV0FBTSxHQUFOLE1BQU0sQ0FBWTtJQUk5QixDQUFDO0lBRUQsS0FBSyxDQUFDLE9BQU8sQ0FLWCxTQUl3QixFQUN4QixTQUFxQixFQUNyQixLQUFxQjtRQUVyQixPQUFPLENBQUMsTUFBTSxLQUFLLENBQUMsT0FBTyxDQUN6QixTQUFTLEVBQ1QsTUFBTSxDQUFDLE1BQU0sQ0FDWDtZQUNFLE9BQU8sRUFBRSxFQUFFO1NBQ1osRUFDRCxTQUFTLENBQ1YsRUFDRCxLQUFLLENBQ04sQ0FBaUIsQ0FBQztJQUNyQixDQUFDO0lBRUQsVUFBVTtRQUdSLE9BQU8seUJBRU4sQ0FBQztJQUNKLENBQUM7SUFFUyxHQUFHLENBQ1gsU0FBaUIsRUFDakIsV0FBNkM7UUFFN0MsTUFBTSxHQUFHLEdBQUcsSUFBSSxHQUFHLENBQ2pCLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLElBQUksU0FBUyxFQUFFLENBQzdELENBQUM7UUFDRixJQUFJLFdBQVc7WUFDYixNQUFNLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLEVBQUUsQ0FDbkQsR0FBRyxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUMvQyxDQUFDO1FBRUosT0FBTyxTQUFTLENBQUMsR0FBRyxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7SUFDbkMsQ0FBQztJQUVELFVBQVUsQ0FBQyxHQUFVO1FBQ25CLE1BQU0sRUFBRSxPQUFPLEVBQUUsR0FBRyxHQUFHLENBQUM7UUFDeEIsUUFBUSxPQUFPLEVBQUUsQ0FBQztZQUNoQjtnQkFDRSxPQUFPLEdBQWdCLENBQUM7UUFDNUIsQ0FBQztJQUNILENBQUM7SUFFRCw2REFBNkQ7SUFDN0QsS0FBSyxDQUFDLFVBQVUsQ0FBQyxHQUFHLElBQVc7UUFDN0IsYUFBYTtJQUNmLENBQUM7SUE4QkQsNkRBQTZEO0lBQzdELEdBQUcsQ0FBSSxRQUFXLEVBQUUsT0FBZ0IsRUFBRSxHQUFHLElBQVc7UUFDbEQsTUFBTSxJQUFJLHVCQUFnQixDQUN4Qix3RkFBd0YsQ0FDekYsQ0FBQztJQUNKLENBQUM7SUFFRCw2REFBNkQ7SUFDN0QsUUFBUSxDQUFDLE9BQXdCO1FBQy9CLE1BQU0sSUFBSSx1QkFBZ0IsQ0FDeEIsd0ZBQXdGLENBQ3pGLENBQUM7SUFDSixDQUFDO0lBRUQsNkRBQTZEO0lBQzdELGNBQWMsQ0FBQyxTQUFvQjtRQUNqQyxNQUFNLElBQUksdUJBQWdCLENBQ3hCLHdGQUF3RixDQUN6RixDQUFDO0lBQ0osQ0FBQztJQUNELElBQUksU0FBUztRQUNYLE1BQU0sSUFBSSx1QkFBZ0IsQ0FDeEIsd0ZBQXdGLENBQ3pGLENBQUM7SUFDSixDQUFDO0lBQ0QsSUFBSSxPQUFPO1FBQ1QsTUFBTSxJQUFJLDZCQUFhLENBQ3JCLHdGQUF3RixDQUN6RixDQUFDO0lBQ0osQ0FBQztDQUNGO0FBcklELGtDQXFJQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFkYXB0ZXIsXG4gIENsYXVzZUZhY3RvcnksXG4gIENvbmRpdGlvbixcbiAgUmVwb3NpdG9yeSxcbiAgU2VxdWVuY2UsXG4gIFNlcXVlbmNlT3B0aW9ucyxcbiAgU3RhdGVtZW50LFxuICBVbnN1cHBvcnRlZEVycm9yLFxufSBmcm9tIFwiQGRlY2FmLXRzL2NvcmVcIjtcbmltcG9ydCB7XG4gIEJhc2VFcnJvcixcbiAgQ29udGV4dCxcbiAgSW50ZXJuYWxFcnJvcixcbiAgT3BlcmF0aW9uS2V5cyxcbiAgUmVwb3NpdG9yeUZsYWdzLFxufSBmcm9tIFwiQGRlY2FmLXRzL2RiLWRlY29yYXRvcnNcIjtcbmltcG9ydCB7IEh0dHBDb25maWcgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHsgQ29uc3RydWN0b3IsIE1vZGVsIH0gZnJvbSBcIkBkZWNhZi10cy9kZWNvcmF0b3ItdmFsaWRhdGlvblwiO1xuaW1wb3J0IHsgUmVzdFNlcnZpY2UgfSBmcm9tIFwiLi9SZXN0U2VydmljZVwiO1xuXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgSHR0cEFkYXB0ZXI8XG4gIFksXG4gIFEsXG4gIEYgZXh0ZW5kcyBSZXBvc2l0b3J5RmxhZ3MsXG4gIEMgZXh0ZW5kcyBDb250ZXh0PEY+LFxuPiBleHRlbmRzIEFkYXB0ZXI8WSwgUSwgRiwgQz4ge1xuICBwcm90ZWN0ZWQgY29uc3RydWN0b3IoXG4gICAgbmF0aXZlOiBZLFxuICAgIHByb3RlY3RlZCBjb25maWc6IEh0dHBDb25maWcsXG4gICAgZmxhdm91cjogc3RyaW5nID0gXCJodHRwXCJcbiAgKSB7XG4gICAgc3VwZXIobmF0aXZlLCBmbGF2b3VyKTtcbiAgfVxuXG4gIGFzeW5jIGNvbnRleHQ8XG4gICAgTSBleHRlbmRzIE1vZGVsLFxuICAgIEMgZXh0ZW5kcyBDb250ZXh0PEY+LFxuICAgIEYgZXh0ZW5kcyBSZXBvc2l0b3J5RmxhZ3MsXG4gID4oXG4gICAgb3BlcmF0aW9uOlxuICAgICAgfCBPcGVyYXRpb25LZXlzLkNSRUFURVxuICAgICAgfCBPcGVyYXRpb25LZXlzLlJFQURcbiAgICAgIHwgT3BlcmF0aW9uS2V5cy5VUERBVEVcbiAgICAgIHwgT3BlcmF0aW9uS2V5cy5ERUxFVEUsXG4gICAgb3ZlcnJpZGVzOiBQYXJ0aWFsPEY+LFxuICAgIG1vZGVsOiBDb25zdHJ1Y3RvcjxNPlxuICApOiBQcm9taXNlPEM+IHtcbiAgICByZXR1cm4gKGF3YWl0IHN1cGVyLmNvbnRleHQoXG4gICAgICBvcGVyYXRpb24sXG4gICAgICBPYmplY3QuYXNzaWduKFxuICAgICAgICB7XG4gICAgICAgICAgaGVhZGVyczoge30sXG4gICAgICAgIH0sXG4gICAgICAgIG92ZXJyaWRlc1xuICAgICAgKSxcbiAgICAgIG1vZGVsXG4gICAgKSkgYXMgdW5rbm93biBhcyBDO1xuICB9XG5cbiAgcmVwb3NpdG9yeTxNIGV4dGVuZHMgTW9kZWw+KCk6IENvbnN0cnVjdG9yPFxuICAgIFJlcG9zaXRvcnk8TSwgUSwgSHR0cEFkYXB0ZXI8WSwgUSwgRiwgQz4+XG4gID4ge1xuICAgIHJldHVybiBSZXN0U2VydmljZSBhcyB1bmtub3duIGFzIENvbnN0cnVjdG9yPFxuICAgICAgUmVwb3NpdG9yeTxNLCBRLCBIdHRwQWRhcHRlcjxZLCBRLCBGLCBDPj5cbiAgICA+O1xuICB9XG5cbiAgcHJvdGVjdGVkIHVybChcbiAgICB0YWJsZU5hbWU6IHN0cmluZyxcbiAgICBxdWVyeVBhcmFtcz86IFJlY29yZDxzdHJpbmcsIHN0cmluZyB8IG51bWJlcj5cbiAgKSB7XG4gICAgY29uc3QgdXJsID0gbmV3IFVSTChcbiAgICAgIGAke3RoaXMuY29uZmlnLnByb3RvY29sfTovLyR7dGhpcy5jb25maWcuaG9zdH0vJHt0YWJsZU5hbWV9YFxuICAgICk7XG4gICAgaWYgKHF1ZXJ5UGFyYW1zKVxuICAgICAgT2JqZWN0LmVudHJpZXMocXVlcnlQYXJhbXMpLmZvckVhY2goKFtrZXksIHZhbHVlXSkgPT5cbiAgICAgICAgdXJsLnNlYXJjaFBhcmFtcy5hcHBlbmQoa2V5LCB2YWx1ZS50b1N0cmluZygpKVxuICAgICAgKTtcblxuICAgIHJldHVybiBlbmNvZGVVUkkodXJsLnRvU3RyaW5nKCkpO1xuICB9XG5cbiAgcGFyc2VFcnJvcihlcnI6IEVycm9yKTogQmFzZUVycm9yIHtcbiAgICBjb25zdCB7IG1lc3NhZ2UgfSA9IGVycjtcbiAgICBzd2l0Y2ggKG1lc3NhZ2UpIHtcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiBlcnIgYXMgQmFzZUVycm9yO1xuICAgIH1cbiAgfVxuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbiAgYXN5bmMgaW5pdGlhbGl6ZSguLi5hcmdzOiBhbnlbXSk6IFByb21pc2U8dm9pZD4ge1xuICAgIC8vIGRvIG5vdGhpbmdcbiAgfVxuXG4gIGFic3RyYWN0IHJlcXVlc3Q8Vj4oZGV0YWlsczogUSk6IFByb21pc2U8Vj47XG5cbiAgYWJzdHJhY3QgY3JlYXRlKFxuICAgIHRhYmxlTmFtZTogc3RyaW5nLFxuICAgIGlkOiBzdHJpbmcgfCBudW1iZXIsXG4gICAgbW9kZWw6IFJlY29yZDxzdHJpbmcsIGFueT4sXG4gICAgLi4uYXJnczogYW55W11cbiAgKTogUHJvbWlzZTxSZWNvcmQ8c3RyaW5nLCBhbnk+PjtcblxuICBhYnN0cmFjdCByZWFkKFxuICAgIHRhYmxlTmFtZTogc3RyaW5nLFxuICAgIGlkOiBzdHJpbmcgfCBudW1iZXIgfCBiaWdpbnQsXG4gICAgLi4uYXJnczogYW55W11cbiAgKTogUHJvbWlzZTxSZWNvcmQ8c3RyaW5nLCBhbnk+PjtcblxuICBhYnN0cmFjdCB1cGRhdGUoXG4gICAgdGFibGVOYW1lOiBzdHJpbmcsXG4gICAgaWQ6IHN0cmluZyB8IG51bWJlcixcbiAgICBtb2RlbDogUmVjb3JkPHN0cmluZywgYW55PixcbiAgICAuLi5hcmdzOiBhbnlbXVxuICApOiBQcm9taXNlPFJlY29yZDxzdHJpbmcsIGFueT4+O1xuXG4gIGFic3RyYWN0IGRlbGV0ZShcbiAgICB0YWJsZU5hbWU6IHN0cmluZyxcbiAgICBpZDogc3RyaW5nIHwgbnVtYmVyIHwgYmlnaW50LFxuICAgIC4uLmFyZ3M6IGFueVtdXG4gICk6IFByb21pc2U8UmVjb3JkPHN0cmluZywgYW55Pj47XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnVzZWQtdmFyc1xuICByYXc8Uj4ocmF3SW5wdXQ6IFEsIHByb2Nlc3M6IGJvb2xlYW4sIC4uLmFyZ3M6IGFueVtdKTogUHJvbWlzZTxSPiB7XG4gICAgdGhyb3cgbmV3IFVuc3VwcG9ydGVkRXJyb3IoXG4gICAgICBcIkFwaSBpcyBub3QgbmF0aXZlbHkgYXZhaWxhYmxlIGZvciBIdHRwQWRhcHRlcnMuIElmIHJlcXVpcmVkLCBwbGVhc2UgZXh0ZW5kcyB0aGlzIGNsYXNzXCJcbiAgICApO1xuICB9XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnVzZWQtdmFyc1xuICBTZXF1ZW5jZShvcHRpb25zOiBTZXF1ZW5jZU9wdGlvbnMpOiBQcm9taXNlPFNlcXVlbmNlPiB7XG4gICAgdGhyb3cgbmV3IFVuc3VwcG9ydGVkRXJyb3IoXG4gICAgICBcIkFwaSBpcyBub3QgbmF0aXZlbHkgYXZhaWxhYmxlIGZvciBIdHRwQWRhcHRlcnMuIElmIHJlcXVpcmVkLCBwbGVhc2UgZXh0ZW5kcyB0aGlzIGNsYXNzXCJcbiAgICApO1xuICB9XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnVzZWQtdmFyc1xuICBwYXJzZUNvbmRpdGlvbihjb25kaXRpb246IENvbmRpdGlvbik6IFEge1xuICAgIHRocm93IG5ldyBVbnN1cHBvcnRlZEVycm9yKFxuICAgICAgXCJBcGkgaXMgbm90IG5hdGl2ZWx5IGF2YWlsYWJsZSBmb3IgSHR0cEFkYXB0ZXJzLiBJZiByZXF1aXJlZCwgcGxlYXNlIGV4dGVuZHMgdGhpcyBjbGFzc1wiXG4gICAgKTtcbiAgfVxuICBnZXQgU3RhdGVtZW50KCk6IFN0YXRlbWVudDxRPiB7XG4gICAgdGhyb3cgbmV3IFVuc3VwcG9ydGVkRXJyb3IoXG4gICAgICBcIkFwaSBpcyBub3QgbmF0aXZlbHkgYXZhaWxhYmxlIGZvciBIdHRwQWRhcHRlcnMuIElmIHJlcXVpcmVkLCBwbGVhc2UgZXh0ZW5kcyB0aGlzIGNsYXNzXCJcbiAgICApO1xuICB9XG4gIGdldCBDbGF1c2VzKCk6IENsYXVzZUZhY3Rvcnk8WSwgUSwgdHlwZW9mIHRoaXM+IHtcbiAgICB0aHJvdyBuZXcgSW50ZXJuYWxFcnJvcihcbiAgICAgIFwiQXBpIGlzIG5vdCBuYXRpdmVseSBhdmFpbGFibGUgZm9yIEh0dHBBZGFwdGVycy4gSWYgcmVxdWlyZWQsIHBsZWFzZSBleHRlbmRzIHRoaXMgY2xhc3NcIlxuICAgICk7XG4gIH1cbn1cbiJdfQ==
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../src/adapter.ts"],"names":[],"mappings":";;;AAAA,yCAOwB;AAIxB,mDAA4C;AAG5C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+BG;AACH,MAAsB,WAKpB,SAAQ,cAAmB;IAC3B,YACE,MAAS,EACC,MAAkB,EAC5B,OAAe,EACf,KAAc;QAEd,KAAK,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;QAJpB,WAAM,GAAN,MAAM,CAAY;IAK9B,CAAC;IAED;;;;;;;;;;OAUG;IACM,KAAK,CACZ,SAIwB,EACxB,KAAqB,EACrB,SAAqB;QAErB,OAAO,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAI,SAAS,EAAE,KAAK,EAAE,SAAS,CAAC,EAAE;YAChE,OAAO,EAAE,EAAE;SACZ,CAAC,CAAC;IACL,CAAC;IAED;;;;;;OAMG;IACM,UAAU;QAGjB,OAAO,yBAEN,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACO,GAAG,CACX,SAAiB,EACjB,WAA6C;QAE7C,MAAM,GAAG,GAAG,IAAI,GAAG,CACjB,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,SAAS,EAAE,CAC7D,CAAC;QACF,IAAI,WAAW;YACb,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CACnD,GAAG,CAAC,YAAY,CAAC,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAC/C,CAAC;QAEJ,OAAO,SAAS,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC;IACnC,CAAC;IAED;;;;;;;OAOG;IACH,UAAU,CAAC,GAAU;QACnB,MAAM,EAAE,OAAO,EAAE,GAAG,GAAG,CAAC;QACxB,QAAQ,OAAO,EAAE,CAAC;YAChB;gBACE,OAAO,GAAgB,CAAC;QAC5B,CAAC;IACH,CAAC;IAED;;;;;;OAMG;IACH,6DAA6D;IAC7D,KAAK,CAAC,UAAU,CAAC,GAAG,IAAW;QAC7B,aAAa;IACf,CAAC;IA4ED;;;;;;;;;;;OAWG;IACH,6DAA6D;IAC7D,GAAG,CAAI,QAAW,EAAE,OAAgB,EAAE,GAAG,IAAW;QAClD,MAAM,IAAI,uBAAgB,CACxB,wFAAwF,CACzF,CAAC;IACJ,CAAC;IAED;;;;;;;;OAQG;IACH,6DAA6D;IAC7D,QAAQ,CAAC,OAAwB;QAC/B,MAAM,IAAI,uBAAgB,CACxB,wFAAwF,CACzF,CAAC;IACJ,CAAC;IAED;;;;;;;;;OASG;IACM,SAAS;QAChB,MAAM,IAAI,uBAAgB,CACxB,wFAAwF,CACzF,CAAC;IACJ,CAAC;IAED;;;;;;;;OAQG;IACH,6DAA6D;IAC7D,cAAc,CAAC,SAAyB;QACtC,MAAM,IAAI,uBAAgB,CACxB,wFAAwF,CACzF,CAAC;IACJ,CAAC;CACF;AAtPD,kCAsPC","sourcesContent":["import {\n  Adapter,\n  Condition,\n  Repository,\n  Sequence,\n  SequenceOptions,\n  UnsupportedError,\n} from \"@decaf-ts/core\";\nimport { BaseError, Context, OperationKeys } from \"@decaf-ts/db-decorators\";\nimport { HttpConfig, HttpFlags } from \"./types\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { RestService } from \"./RestService\";\nimport { Statement } from \"@decaf-ts/core\";\n\n/**\n * @description Abstract HTTP adapter for REST API interactions\n * @summary Provides a base implementation for HTTP adapters with methods for CRUD operations,\n * URL construction, and error handling. This class extends the core Adapter class and\n * implements the necessary methods for HTTP communication. Concrete implementations\n * must provide specific HTTP client functionality.\n * @template Y - The native HTTP client type\n * @template Q - The query type used by the adapter\n * @template F - The HTTP flags type, extending HttpFlags\n * @template C - The context type, extending Context<F>\n * @param {Y} native - The native HTTP client instance\n * @param {HttpConfig} config - Configuration for the HTTP adapter\n * @param {string} flavour - The adapter flavor identifier\n * @param {string} [alias] - Optional alias for the adapter\n * @example\n * ```typescript\n * // Example implementation with Axios\n * class AxiosAdapter extends HttpAdapter<AxiosInstance, AxiosRequestConfig> {\n *   constructor(config: HttpConfig) {\n *     super(axios.create(), config, 'axios');\n *   }\n *\n *   async request<V>(details: AxiosRequestConfig): Promise<V> {\n *     const response = await this.native.request(details);\n *     return response.data;\n *   }\n *\n *   // Implement other abstract methods...\n * }\n * ```\n * @class\n */\nexport abstract class HttpAdapter<\n  Y,\n  Q,\n  F extends HttpFlags = HttpFlags,\n  C extends Context<F> = Context<F>,\n> extends Adapter<Y, Q, F, C> {\n  protected constructor(\n    native: Y,\n    protected config: HttpConfig,\n    flavour: string,\n    alias?: string\n  ) {\n    super(native, flavour, alias);\n  }\n\n  /**\n   * @description Generates operation flags with HTTP headers\n   * @summary Extends the base flags method to include HTTP-specific headers for operations.\n   * This method adds an empty headers object to the flags returned by the parent class.\n   * @template F - The Repository Flags type\n   * @template M - The model type\n   * @param {OperationKeys.CREATE|OperationKeys.READ|OperationKeys.UPDATE|OperationKeys.DELETE} operation - The operation type\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<F>} overrides - Optional flag overrides\n   * @return {F} The flags object with headers\n   */\n  override flags<M extends Model>(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    model: Constructor<M>,\n    overrides: Partial<F>\n  ) {\n    return Object.assign(super.flags<M>(operation, model, overrides), {\n      headers: {},\n    });\n  }\n\n  /**\n   * @description Returns the repository constructor for this adapter\n   * @summary Provides the RestService class as the repository implementation for this HTTP adapter.\n   * This method is used to create repository instances that work with this adapter type.\n   * @template M - The model type\n   * @return {Constructor<Repository<M, Q, HttpAdapter<Y, Q, F, C>>>} The repository constructor\n   */\n  override repository<M extends Model>(): Constructor<\n    Repository<M, Q, HttpAdapter<Y, Q, F, C>>\n  > {\n    return RestService as unknown as Constructor<\n      Repository<M, Q, HttpAdapter<Y, Q, F, C>>\n    >;\n  }\n\n  /**\n   * @description Constructs a URL for API requests\n   * @summary Builds a complete URL for API requests using the configured protocol and host,\n   * the specified table name, and optional query parameters. The method handles URL encoding.\n   * @param {string} tableName - The name of the table or endpoint\n   * @param {Record<string, string | number>} [queryParams] - Optional query parameters\n   * @return {string} The encoded URL string\n   */\n  protected url(\n    tableName: string,\n    queryParams?: Record<string, string | number>\n  ) {\n    const url = new URL(\n      `${this.config.protocol}://${this.config.host}/${tableName}`\n    );\n    if (queryParams)\n      Object.entries(queryParams).forEach(([key, value]) =>\n        url.searchParams.append(key, value.toString())\n      );\n\n    return encodeURI(url.toString());\n  }\n\n  /**\n   * @description Parses and converts errors to BaseError type\n   * @summary Processes errors that occur during HTTP operations and converts them to\n   * the appropriate BaseError type. Currently returns the error as-is, but can be\n   * extended to handle specific error messages differently.\n   * @param {Error} err - The error to parse\n   * @return {BaseError} The parsed error as a BaseError\n   */\n  parseError(err: Error): BaseError {\n    const { message } = err;\n    switch (message) {\n      default:\n        return err as BaseError;\n    }\n  }\n\n  /**\n   * @description Initializes the HTTP adapter\n   * @summary Placeholder method for adapter initialization. This method is currently\n   * a no-op but can be overridden by subclasses to perform initialization tasks.\n   * @param {...any[]} args - Initialization arguments\n   * @return {Promise<void>} A promise that resolves when initialization is complete\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async initialize(...args: any[]): Promise<void> {\n    // do nothing\n  }\n\n  /**\n   * @description Sends an HTTP request\n   * @summary Abstract method that must be implemented by subclasses to send HTTP requests\n   * using the native HTTP client. This is the core method for making API calls.\n   * @template V - The response value type\n   * @param {Q} details - The request details specific to the HTTP client\n   * @return {Promise<V>} A promise that resolves with the response data\n   */\n  abstract request<V>(details: Q): Promise<V>;\n\n  /**\n   * @description Creates a new resource\n   * @summary Abstract method that must be implemented by subclasses to create a new resource\n   * via HTTP. This typically corresponds to a POST request.\n   * @param {string} tableName - The name of the table or endpoint\n   * @param {string|number} id - The identifier for the resource\n   * @param {Record<string, any>} model - The data model to create\n   * @param {...any[]} args - Additional arguments\n   * @return {Promise<Record<string, any>>} A promise that resolves with the created resource\n   */\n  abstract override create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Retrieves a resource by ID\n   * @summary Abstract method that must be implemented by subclasses to retrieve a resource\n   * via HTTP. This typically corresponds to a GET request.\n   * @param {string} tableName - The name of the table or endpoint\n   * @param {string|number|bigint} id - The identifier for the resource\n   * @param {...any[]} args - Additional arguments\n   * @return {Promise<Record<string, any>>} A promise that resolves with the retrieved resource\n   */\n  abstract override read(\n    tableName: string,\n    id: string | number | bigint,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Updates an existing resource\n   * @summary Abstract method that must be implemented by subclasses to update a resource\n   * via HTTP. This typically corresponds to a PUT or PATCH request.\n   * @param {string} tableName - The name of the table or endpoint\n   * @param {string|number} id - The identifier for the resource\n   * @param {Record<string, any>} model - The updated data model\n   * @param {...any[]} args - Additional arguments\n   * @return {Promise<Record<string, any>>} A promise that resolves with the updated resource\n   */\n  abstract override update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Deletes a resource by ID\n   * @summary Abstract method that must be implemented by subclasses to delete a resource\n   * via HTTP. This typically corresponds to a DELETE request.\n   * @param {string} tableName - The name of the table or endpoint\n   * @param {string|number|bigint} id - The identifier for the resource to delete\n   * @param {...any[]} args - Additional arguments\n   * @return {Promise<Record<string, any>>} A promise that resolves with the deletion result\n   */\n  abstract override delete(\n    tableName: string,\n    id: string | number | bigint,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Executes a raw query\n   * @summary Method for executing raw queries directly with the HTTP client.\n   * This method is not supported by default in HTTP adapters and throws an UnsupportedError.\n   * Subclasses can override this method to provide implementation.\n   * @template R - The result type\n   * @param {Q} rawInput - The raw query input\n   * @param {boolean} process - Whether to process the result\n   * @param {...any[]} args - Additional arguments\n   * @return {Promise<R>} A promise that resolves with the query result\n   * @throws {UnsupportedError} Always throws as this method is not supported by default\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  raw<R>(rawInput: Q, process: boolean, ...args: any[]): Promise<R> {\n    throw new UnsupportedError(\n      \"Api is not natively available for HttpAdapters. If required, please extends this class\"\n    );\n  }\n\n  /**\n   * @description Creates a sequence\n   * @summary Method for creating a sequence for generating unique identifiers.\n   * This method is not supported by default in HTTP adapters and throws an UnsupportedError.\n   * Subclasses can override this method to provide implementation.\n   * @param {SequenceOptions} options - Options for creating the sequence\n   * @return {Promise<Sequence>} A promise that resolves with the created sequence\n   * @throws {UnsupportedError} Always throws as this method is not supported by default\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  Sequence(options: SequenceOptions): Promise<Sequence> {\n    throw new UnsupportedError(\n      \"Api is not natively available for HttpAdapters. If required, please extends this class\"\n    );\n  }\n\n  /**\n   * @description Creates a statement for querying\n   * @summary Method for creating a statement for building and executing queries.\n   * This method is not supported by default in HTTP adapters and throws an UnsupportedError.\n   * Subclasses can override this method to provide implementation.\n   * @template M - The model type\n   * @template ! - The raw query type\n   * @return {Statement<Q, M, any>} A statement object for building queries\n   * @throws {UnsupportedError} Always throws as this method is not supported by default\n   */\n  override Statement<M extends Model>(): Statement<Q, M, any> {\n    throw new UnsupportedError(\n      \"Api is not natively available for HttpAdapters. If required, please extends this class\"\n    );\n  }\n\n  /**\n   * @description Parses a condition into a query\n   * @summary Method for parsing a condition object into a query format understood by the HTTP client.\n   * This method is not supported by default in HTTP adapters and throws an UnsupportedError.\n   * Subclasses can override this method to provide implementation.\n   * @param {Condition<any>} condition - The condition to parse\n   * @return {Q} The parsed query\n   * @throws {UnsupportedError} Always throws as this method is not supported by default\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  parseCondition(condition: Condition<any>): Q {\n    throw new UnsupportedError(\n      \"Api is not natively available for HttpAdapters. If required, please extends this class\"\n    );\n  }\n}\n"]}
|
package/lib/adapter.d.ts
CHANGED
|
@@ -1,23 +1,184 @@
|
|
|
1
|
-
import { Adapter,
|
|
2
|
-
import { BaseError, Context, OperationKeys
|
|
3
|
-
import { HttpConfig } from "./types";
|
|
1
|
+
import { Adapter, Condition, Repository, Sequence, SequenceOptions } from "@decaf-ts/core";
|
|
2
|
+
import { BaseError, Context, OperationKeys } from "@decaf-ts/db-decorators";
|
|
3
|
+
import { HttpConfig, HttpFlags } from "./types";
|
|
4
4
|
import { Constructor, Model } from "@decaf-ts/decorator-validation";
|
|
5
|
-
|
|
5
|
+
import { Statement } from "@decaf-ts/core";
|
|
6
|
+
/**
|
|
7
|
+
* @description Abstract HTTP adapter for REST API interactions
|
|
8
|
+
* @summary Provides a base implementation for HTTP adapters with methods for CRUD operations,
|
|
9
|
+
* URL construction, and error handling. This class extends the core Adapter class and
|
|
10
|
+
* implements the necessary methods for HTTP communication. Concrete implementations
|
|
11
|
+
* must provide specific HTTP client functionality.
|
|
12
|
+
* @template Y - The native HTTP client type
|
|
13
|
+
* @template Q - The query type used by the adapter
|
|
14
|
+
* @template F - The HTTP flags type, extending HttpFlags
|
|
15
|
+
* @template C - The context type, extending Context<F>
|
|
16
|
+
* @param {Y} native - The native HTTP client instance
|
|
17
|
+
* @param {HttpConfig} config - Configuration for the HTTP adapter
|
|
18
|
+
* @param {string} flavour - The adapter flavor identifier
|
|
19
|
+
* @param {string} [alias] - Optional alias for the adapter
|
|
20
|
+
* @example
|
|
21
|
+
* ```typescript
|
|
22
|
+
* // Example implementation with Axios
|
|
23
|
+
* class AxiosAdapter extends HttpAdapter<AxiosInstance, AxiosRequestConfig> {
|
|
24
|
+
* constructor(config: HttpConfig) {
|
|
25
|
+
* super(axios.create(), config, 'axios');
|
|
26
|
+
* }
|
|
27
|
+
*
|
|
28
|
+
* async request<V>(details: AxiosRequestConfig): Promise<V> {
|
|
29
|
+
* const response = await this.native.request(details);
|
|
30
|
+
* return response.data;
|
|
31
|
+
* }
|
|
32
|
+
*
|
|
33
|
+
* // Implement other abstract methods...
|
|
34
|
+
* }
|
|
35
|
+
* ```
|
|
36
|
+
* @class
|
|
37
|
+
*/
|
|
38
|
+
export declare abstract class HttpAdapter<Y, Q, F extends HttpFlags = HttpFlags, C extends Context<F> = Context<F>> extends Adapter<Y, Q, F, C> {
|
|
6
39
|
protected config: HttpConfig;
|
|
7
|
-
protected constructor(native: Y, config: HttpConfig, flavour?: string);
|
|
8
|
-
|
|
40
|
+
protected constructor(native: Y, config: HttpConfig, flavour: string, alias?: string);
|
|
41
|
+
/**
|
|
42
|
+
* @description Generates operation flags with HTTP headers
|
|
43
|
+
* @summary Extends the base flags method to include HTTP-specific headers for operations.
|
|
44
|
+
* This method adds an empty headers object to the flags returned by the parent class.
|
|
45
|
+
* @template F - The Repository Flags type
|
|
46
|
+
* @template M - The model type
|
|
47
|
+
* @param {OperationKeys.CREATE|OperationKeys.READ|OperationKeys.UPDATE|OperationKeys.DELETE} operation - The operation type
|
|
48
|
+
* @param {Constructor<M>} model - The model constructor
|
|
49
|
+
* @param {Partial<F>} overrides - Optional flag overrides
|
|
50
|
+
* @return {F} The flags object with headers
|
|
51
|
+
*/
|
|
52
|
+
flags<M extends Model>(operation: OperationKeys.CREATE | OperationKeys.READ | OperationKeys.UPDATE | OperationKeys.DELETE, model: Constructor<M>, overrides: Partial<F>): F & {
|
|
53
|
+
headers: {};
|
|
54
|
+
};
|
|
55
|
+
/**
|
|
56
|
+
* @description Returns the repository constructor for this adapter
|
|
57
|
+
* @summary Provides the RestService class as the repository implementation for this HTTP adapter.
|
|
58
|
+
* This method is used to create repository instances that work with this adapter type.
|
|
59
|
+
* @template M - The model type
|
|
60
|
+
* @return {Constructor<Repository<M, Q, HttpAdapter<Y, Q, F, C>>>} The repository constructor
|
|
61
|
+
*/
|
|
9
62
|
repository<M extends Model>(): Constructor<Repository<M, Q, HttpAdapter<Y, Q, F, C>>>;
|
|
63
|
+
/**
|
|
64
|
+
* @description Constructs a URL for API requests
|
|
65
|
+
* @summary Builds a complete URL for API requests using the configured protocol and host,
|
|
66
|
+
* the specified table name, and optional query parameters. The method handles URL encoding.
|
|
67
|
+
* @param {string} tableName - The name of the table or endpoint
|
|
68
|
+
* @param {Record<string, string | number>} [queryParams] - Optional query parameters
|
|
69
|
+
* @return {string} The encoded URL string
|
|
70
|
+
*/
|
|
10
71
|
protected url(tableName: string, queryParams?: Record<string, string | number>): string;
|
|
72
|
+
/**
|
|
73
|
+
* @description Parses and converts errors to BaseError type
|
|
74
|
+
* @summary Processes errors that occur during HTTP operations and converts them to
|
|
75
|
+
* the appropriate BaseError type. Currently returns the error as-is, but can be
|
|
76
|
+
* extended to handle specific error messages differently.
|
|
77
|
+
* @param {Error} err - The error to parse
|
|
78
|
+
* @return {BaseError} The parsed error as a BaseError
|
|
79
|
+
*/
|
|
11
80
|
parseError(err: Error): BaseError;
|
|
81
|
+
/**
|
|
82
|
+
* @description Initializes the HTTP adapter
|
|
83
|
+
* @summary Placeholder method for adapter initialization. This method is currently
|
|
84
|
+
* a no-op but can be overridden by subclasses to perform initialization tasks.
|
|
85
|
+
* @param {...any[]} args - Initialization arguments
|
|
86
|
+
* @return {Promise<void>} A promise that resolves when initialization is complete
|
|
87
|
+
*/
|
|
12
88
|
initialize(...args: any[]): Promise<void>;
|
|
89
|
+
/**
|
|
90
|
+
* @description Sends an HTTP request
|
|
91
|
+
* @summary Abstract method that must be implemented by subclasses to send HTTP requests
|
|
92
|
+
* using the native HTTP client. This is the core method for making API calls.
|
|
93
|
+
* @template V - The response value type
|
|
94
|
+
* @param {Q} details - The request details specific to the HTTP client
|
|
95
|
+
* @return {Promise<V>} A promise that resolves with the response data
|
|
96
|
+
*/
|
|
13
97
|
abstract request<V>(details: Q): Promise<V>;
|
|
98
|
+
/**
|
|
99
|
+
* @description Creates a new resource
|
|
100
|
+
* @summary Abstract method that must be implemented by subclasses to create a new resource
|
|
101
|
+
* via HTTP. This typically corresponds to a POST request.
|
|
102
|
+
* @param {string} tableName - The name of the table or endpoint
|
|
103
|
+
* @param {string|number} id - The identifier for the resource
|
|
104
|
+
* @param {Record<string, any>} model - The data model to create
|
|
105
|
+
* @param {...any[]} args - Additional arguments
|
|
106
|
+
* @return {Promise<Record<string, any>>} A promise that resolves with the created resource
|
|
107
|
+
*/
|
|
14
108
|
abstract create(tableName: string, id: string | number, model: Record<string, any>, ...args: any[]): Promise<Record<string, any>>;
|
|
109
|
+
/**
|
|
110
|
+
* @description Retrieves a resource by ID
|
|
111
|
+
* @summary Abstract method that must be implemented by subclasses to retrieve a resource
|
|
112
|
+
* via HTTP. This typically corresponds to a GET request.
|
|
113
|
+
* @param {string} tableName - The name of the table or endpoint
|
|
114
|
+
* @param {string|number|bigint} id - The identifier for the resource
|
|
115
|
+
* @param {...any[]} args - Additional arguments
|
|
116
|
+
* @return {Promise<Record<string, any>>} A promise that resolves with the retrieved resource
|
|
117
|
+
*/
|
|
15
118
|
abstract read(tableName: string, id: string | number | bigint, ...args: any[]): Promise<Record<string, any>>;
|
|
119
|
+
/**
|
|
120
|
+
* @description Updates an existing resource
|
|
121
|
+
* @summary Abstract method that must be implemented by subclasses to update a resource
|
|
122
|
+
* via HTTP. This typically corresponds to a PUT or PATCH request.
|
|
123
|
+
* @param {string} tableName - The name of the table or endpoint
|
|
124
|
+
* @param {string|number} id - The identifier for the resource
|
|
125
|
+
* @param {Record<string, any>} model - The updated data model
|
|
126
|
+
* @param {...any[]} args - Additional arguments
|
|
127
|
+
* @return {Promise<Record<string, any>>} A promise that resolves with the updated resource
|
|
128
|
+
*/
|
|
16
129
|
abstract update(tableName: string, id: string | number, model: Record<string, any>, ...args: any[]): Promise<Record<string, any>>;
|
|
130
|
+
/**
|
|
131
|
+
* @description Deletes a resource by ID
|
|
132
|
+
* @summary Abstract method that must be implemented by subclasses to delete a resource
|
|
133
|
+
* via HTTP. This typically corresponds to a DELETE request.
|
|
134
|
+
* @param {string} tableName - The name of the table or endpoint
|
|
135
|
+
* @param {string|number|bigint} id - The identifier for the resource to delete
|
|
136
|
+
* @param {...any[]} args - Additional arguments
|
|
137
|
+
* @return {Promise<Record<string, any>>} A promise that resolves with the deletion result
|
|
138
|
+
*/
|
|
17
139
|
abstract delete(tableName: string, id: string | number | bigint, ...args: any[]): Promise<Record<string, any>>;
|
|
140
|
+
/**
|
|
141
|
+
* @description Executes a raw query
|
|
142
|
+
* @summary Method for executing raw queries directly with the HTTP client.
|
|
143
|
+
* This method is not supported by default in HTTP adapters and throws an UnsupportedError.
|
|
144
|
+
* Subclasses can override this method to provide implementation.
|
|
145
|
+
* @template R - The result type
|
|
146
|
+
* @param {Q} rawInput - The raw query input
|
|
147
|
+
* @param {boolean} process - Whether to process the result
|
|
148
|
+
* @param {...any[]} args - Additional arguments
|
|
149
|
+
* @return {Promise<R>} A promise that resolves with the query result
|
|
150
|
+
* @throws {UnsupportedError} Always throws as this method is not supported by default
|
|
151
|
+
*/
|
|
18
152
|
raw<R>(rawInput: Q, process: boolean, ...args: any[]): Promise<R>;
|
|
153
|
+
/**
|
|
154
|
+
* @description Creates a sequence
|
|
155
|
+
* @summary Method for creating a sequence for generating unique identifiers.
|
|
156
|
+
* This method is not supported by default in HTTP adapters and throws an UnsupportedError.
|
|
157
|
+
* Subclasses can override this method to provide implementation.
|
|
158
|
+
* @param {SequenceOptions} options - Options for creating the sequence
|
|
159
|
+
* @return {Promise<Sequence>} A promise that resolves with the created sequence
|
|
160
|
+
* @throws {UnsupportedError} Always throws as this method is not supported by default
|
|
161
|
+
*/
|
|
19
162
|
Sequence(options: SequenceOptions): Promise<Sequence>;
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
163
|
+
/**
|
|
164
|
+
* @description Creates a statement for querying
|
|
165
|
+
* @summary Method for creating a statement for building and executing queries.
|
|
166
|
+
* This method is not supported by default in HTTP adapters and throws an UnsupportedError.
|
|
167
|
+
* Subclasses can override this method to provide implementation.
|
|
168
|
+
* @template M - The model type
|
|
169
|
+
* @template ! - The raw query type
|
|
170
|
+
* @return {Statement<Q, M, any>} A statement object for building queries
|
|
171
|
+
* @throws {UnsupportedError} Always throws as this method is not supported by default
|
|
172
|
+
*/
|
|
173
|
+
Statement<M extends Model>(): Statement<Q, M, any>;
|
|
174
|
+
/**
|
|
175
|
+
* @description Parses a condition into a query
|
|
176
|
+
* @summary Method for parsing a condition object into a query format understood by the HTTP client.
|
|
177
|
+
* This method is not supported by default in HTTP adapters and throws an UnsupportedError.
|
|
178
|
+
* Subclasses can override this method to provide implementation.
|
|
179
|
+
* @param {Condition<any>} condition - The condition to parse
|
|
180
|
+
* @return {Q} The parsed query
|
|
181
|
+
* @throws {UnsupportedError} Always throws as this method is not supported by default
|
|
182
|
+
*/
|
|
183
|
+
parseCondition(condition: Condition<any>): Q;
|
|
23
184
|
}
|
package/lib/axios/axios.cjs
CHANGED
|
@@ -2,13 +2,78 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.AxiosHttpAdapter = void 0;
|
|
4
4
|
const adapter_1 = require("./../adapter.cjs");
|
|
5
|
+
const constants_1 = require("./constants.cjs");
|
|
6
|
+
/**
|
|
7
|
+
* @description Axios implementation of the HTTP adapter
|
|
8
|
+
* @summary Concrete implementation of HttpAdapter using Axios as the HTTP client.
|
|
9
|
+
* This adapter provides CRUD operations for RESTful APIs using Axios for HTTP requests.
|
|
10
|
+
* @template Axios - The Axios client type
|
|
11
|
+
* @template AxiosRequestConfig - The Axios request configuration type
|
|
12
|
+
* @template AxiosFlags - The flags type extending HttpFlags
|
|
13
|
+
* @template Context<AxiosFlags> - The context type for this adapter
|
|
14
|
+
* @param {Axios} native - The Axios instance
|
|
15
|
+
* @param {HttpConfig} config - Configuration for the HTTP adapter
|
|
16
|
+
* @param {string} [alias] - Optional alias for the adapter
|
|
17
|
+
* @class
|
|
18
|
+
* @example
|
|
19
|
+
* ```typescript
|
|
20
|
+
* import axios from 'axios';
|
|
21
|
+
* import { AxiosHttpAdapter } from '@decaf-ts/for-http';
|
|
22
|
+
*
|
|
23
|
+
* const config = { protocol: 'https', host: 'api.example.com' };
|
|
24
|
+
* const adapter = new AxiosHttpAdapter(axios.create(), config);
|
|
25
|
+
*
|
|
26
|
+
* // Use the adapter with a repository
|
|
27
|
+
* const userRepo = adapter.getRepository(User);
|
|
28
|
+
* const user = await userRepo.findById('123');
|
|
29
|
+
* ```
|
|
30
|
+
* @mermaid
|
|
31
|
+
* sequenceDiagram
|
|
32
|
+
* participant Client
|
|
33
|
+
* participant AxiosHttpAdapter
|
|
34
|
+
* participant Axios
|
|
35
|
+
* participant API
|
|
36
|
+
*
|
|
37
|
+
* Client->>AxiosHttpAdapter: create(table, id, data)
|
|
38
|
+
* AxiosHttpAdapter->>AxiosHttpAdapter: url(table)
|
|
39
|
+
* AxiosHttpAdapter->>Axios: post(url, data)
|
|
40
|
+
* Axios->>API: HTTP POST Request
|
|
41
|
+
* API-->>Axios: Response
|
|
42
|
+
* Axios-->>AxiosHttpAdapter: Response Data
|
|
43
|
+
* AxiosHttpAdapter-->>Client: Created Resource
|
|
44
|
+
*
|
|
45
|
+
* Client->>AxiosHttpAdapter: read(table, id)
|
|
46
|
+
* AxiosHttpAdapter->>AxiosHttpAdapter: url(table, {id})
|
|
47
|
+
* AxiosHttpAdapter->>Axios: get(url)
|
|
48
|
+
* Axios->>API: HTTP GET Request
|
|
49
|
+
* API-->>Axios: Response
|
|
50
|
+
* Axios-->>AxiosHttpAdapter: Response Data
|
|
51
|
+
* AxiosHttpAdapter-->>Client: Resource Data
|
|
52
|
+
*/
|
|
5
53
|
class AxiosHttpAdapter extends adapter_1.HttpAdapter {
|
|
6
|
-
constructor(native, config,
|
|
7
|
-
super(native, config,
|
|
54
|
+
constructor(native, config, alias) {
|
|
55
|
+
super(native, config, constants_1.AxiosFlavour, alias);
|
|
8
56
|
}
|
|
57
|
+
/**
|
|
58
|
+
* @description Sends an HTTP request using Axios
|
|
59
|
+
* @summary Implementation of the abstract request method from HttpAdapter.
|
|
60
|
+
* This method uses the Axios instance to send HTTP requests with the provided configuration.
|
|
61
|
+
* @template V - The response value type
|
|
62
|
+
* @param {AxiosRequestConfig} details - The Axios request configuration
|
|
63
|
+
* @return {Promise<V>} A promise that resolves with the response data
|
|
64
|
+
*/
|
|
9
65
|
async request(details) {
|
|
10
66
|
return this.native.request(details);
|
|
11
67
|
}
|
|
68
|
+
/**
|
|
69
|
+
* @description Creates a new resource via HTTP POST
|
|
70
|
+
* @summary Implementation of the abstract create method from HttpAdapter.
|
|
71
|
+
* This method sends a POST request to the specified endpoint with the model data.
|
|
72
|
+
* @param {string} tableName - The name of the table or endpoint
|
|
73
|
+
* @param {string|number} id - The identifier for the resource (not used in URL for POST)
|
|
74
|
+
* @param {Record<string, any>} model - The data model to create
|
|
75
|
+
* @return {Promise<Record<string, any>>} A promise that resolves with the created resource
|
|
76
|
+
*/
|
|
12
77
|
async create(tableName, id, model) {
|
|
13
78
|
try {
|
|
14
79
|
const url = this.url(tableName);
|
|
@@ -18,6 +83,14 @@ class AxiosHttpAdapter extends adapter_1.HttpAdapter {
|
|
|
18
83
|
throw this.parseError(e);
|
|
19
84
|
}
|
|
20
85
|
}
|
|
86
|
+
/**
|
|
87
|
+
* @description Retrieves a resource by ID via HTTP GET
|
|
88
|
+
* @summary Implementation of the abstract read method from HttpAdapter.
|
|
89
|
+
* This method sends a GET request to the specified endpoint with the ID as a query parameter.
|
|
90
|
+
* @param {string} tableName - The name of the table or endpoint
|
|
91
|
+
* @param {string|number|bigint} id - The identifier for the resource to retrieve
|
|
92
|
+
* @return {Promise<Record<string, any>>} A promise that resolves with the retrieved resource
|
|
93
|
+
*/
|
|
21
94
|
async read(tableName, id) {
|
|
22
95
|
try {
|
|
23
96
|
const url = this.url(tableName, { id: id });
|
|
@@ -27,6 +100,15 @@ class AxiosHttpAdapter extends adapter_1.HttpAdapter {
|
|
|
27
100
|
throw this.parseError(e);
|
|
28
101
|
}
|
|
29
102
|
}
|
|
103
|
+
/**
|
|
104
|
+
* @description Updates an existing resource via HTTP PUT
|
|
105
|
+
* @summary Implementation of the abstract update method from HttpAdapter.
|
|
106
|
+
* This method sends a PUT request to the specified endpoint with the updated model data.
|
|
107
|
+
* @param {string} tableName - The name of the table or endpoint
|
|
108
|
+
* @param {string|number} id - The identifier for the resource (not used in URL for PUT)
|
|
109
|
+
* @param {Record<string, any>} model - The updated data model
|
|
110
|
+
* @return {Promise<Record<string, any>>} A promise that resolves with the updated resource
|
|
111
|
+
*/
|
|
30
112
|
async update(tableName, id, model) {
|
|
31
113
|
try {
|
|
32
114
|
const url = this.url(tableName);
|
|
@@ -36,6 +118,14 @@ class AxiosHttpAdapter extends adapter_1.HttpAdapter {
|
|
|
36
118
|
throw this.parseError(e);
|
|
37
119
|
}
|
|
38
120
|
}
|
|
121
|
+
/**
|
|
122
|
+
* @description Deletes a resource by ID via HTTP DELETE
|
|
123
|
+
* @summary Implementation of the abstract delete method from HttpAdapter.
|
|
124
|
+
* This method sends a DELETE request to the specified endpoint with the ID as a query parameter.
|
|
125
|
+
* @param {string} tableName - The name of the table or endpoint
|
|
126
|
+
* @param {string|number|bigint} id - The identifier for the resource to delete
|
|
127
|
+
* @return {Promise<Record<string, any>>} A promise that resolves with the deletion result
|
|
128
|
+
*/
|
|
39
129
|
async delete(tableName, id) {
|
|
40
130
|
try {
|
|
41
131
|
const url = this.url(tableName, { id: id });
|
|
@@ -45,6 +135,12 @@ class AxiosHttpAdapter extends adapter_1.HttpAdapter {
|
|
|
45
135
|
throw this.parseError(e);
|
|
46
136
|
}
|
|
47
137
|
}
|
|
138
|
+
/**
|
|
139
|
+
* @description Static decoration method for the AxiosHttpAdapter class
|
|
140
|
+
* @summary Placeholder method for class decoration functionality.
|
|
141
|
+
* This method is currently empty but can be used for decorator-based configuration.
|
|
142
|
+
*/
|
|
143
|
+
static decoration() { }
|
|
48
144
|
}
|
|
49
145
|
exports.AxiosHttpAdapter = AxiosHttpAdapter;
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXhpb3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXhpb3MvYXhpb3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsOENBQXlDO0FBTXpDLE1BQWEsZ0JBQWlCLFNBQVEscUJBS3JDO0lBQ0MsWUFBWSxNQUFhLEVBQUUsTUFBa0IsRUFBRSxVQUFrQixPQUFPO1FBQ3RFLEtBQUssQ0FBQyxNQUFhLEVBQUUsTUFBTSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFUSxLQUFLLENBQUMsT0FBTyxDQUFJLE9BQTJCO1FBQ25ELE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVELEtBQUssQ0FBQyxNQUFNLENBQ1YsU0FBaUIsRUFDakIsRUFBbUIsRUFDbkIsS0FBMEI7UUFFMUIsSUFBSSxDQUFDO1lBQ0gsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUNoQyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUN0QyxDQUFDO1FBQUMsT0FBTyxDQUFNLEVBQUUsQ0FBQztZQUNoQixNQUFNLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDM0IsQ0FBQztJQUNILENBQUM7SUFDRCxLQUFLLENBQUMsSUFBSSxDQUNSLFNBQWlCLEVBQ2pCLEVBQTRCO1FBRTVCLElBQUksQ0FBQztZQUNILE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQXFCLEVBQUUsQ0FBQyxDQUFDO1lBQy9ELE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDOUIsQ0FBQztRQUFDLE9BQU8sQ0FBTSxFQUFFLENBQUM7WUFDaEIsTUFBTSxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzNCLENBQUM7SUFDSCxDQUFDO0lBRUQsS0FBSyxDQUFDLE1BQU0sQ0FDVixTQUFpQixFQUNqQixFQUFtQixFQUNuQixLQUEwQjtRQUUxQixJQUFJLENBQUM7WUFDSCxNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ2hDLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ3JDLENBQUM7UUFBQyxPQUFPLENBQU0sRUFBRSxDQUFDO1lBQ2hCLE1BQU0sSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMzQixDQUFDO0lBQ0gsQ0FBQztJQUVELEtBQUssQ0FBQyxNQUFNLENBQ1YsU0FBaUIsRUFDakIsRUFBNEI7UUFFNUIsSUFBSSxDQUFDO1lBQ0gsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBcUIsRUFBRSxDQUFDLENBQUM7WUFDL0QsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNqQyxDQUFDO1FBQUMsT0FBTyxDQUFNLEVBQUUsQ0FBQztZQUNoQixNQUFNLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDM0IsQ0FBQztJQUNILENBQUM7Q0FDRjtBQTlERCw0Q0E4REMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQWRhcHRlciB9IGZyb20gXCIuLi9hZGFwdGVyXCI7XG5pbXBvcnQgeyBBeGlvcywgQXhpb3NSZXF1ZXN0Q29uZmlnIH0gZnJvbSBcImF4aW9zXCI7XG5pbXBvcnQgeyBIdHRwQ29uZmlnIH0gZnJvbSBcIi4uL3R5cGVzXCI7XG5pbXBvcnQgeyBBeGlvc0ZsYWdzIH0gZnJvbSBcIi4vdHlwZXNcIjtcbmltcG9ydCB7IENvbnRleHQgfSBmcm9tIFwiQGRlY2FmLXRzL2RiLWRlY29yYXRvcnNcIjtcblxuZXhwb3J0IGNsYXNzIEF4aW9zSHR0cEFkYXB0ZXIgZXh0ZW5kcyBIdHRwQWRhcHRlcjxcbiAgQXhpb3MsXG4gIEF4aW9zUmVxdWVzdENvbmZpZyxcbiAgQXhpb3NGbGFncyxcbiAgQ29udGV4dDxBeGlvc0ZsYWdzPlxuPiB7XG4gIGNvbnN0cnVjdG9yKG5hdGl2ZTogQXhpb3MsIGNvbmZpZzogSHR0cENvbmZpZywgZmxhdm91cjogc3RyaW5nID0gXCJheGlvc1wiKSB7XG4gICAgc3VwZXIobmF0aXZlIGFzIGFueSwgY29uZmlnLCBmbGF2b3VyKTtcbiAgfVxuXG4gIG92ZXJyaWRlIGFzeW5jIHJlcXVlc3Q8Vj4oZGV0YWlsczogQXhpb3NSZXF1ZXN0Q29uZmlnKTogUHJvbWlzZTxWPiB7XG4gICAgcmV0dXJuIHRoaXMubmF0aXZlLnJlcXVlc3QoZGV0YWlscyk7XG4gIH1cblxuICBhc3luYyBjcmVhdGUoXG4gICAgdGFibGVOYW1lOiBzdHJpbmcsXG4gICAgaWQ6IHN0cmluZyB8IG51bWJlcixcbiAgICBtb2RlbDogUmVjb3JkPHN0cmluZywgYW55PlxuICApOiBQcm9taXNlPFJlY29yZDxzdHJpbmcsIGFueT4+IHtcbiAgICB0cnkge1xuICAgICAgY29uc3QgdXJsID0gdGhpcy51cmwodGFibGVOYW1lKTtcbiAgICAgIHJldHVybiB0aGlzLm5hdGl2ZS5wb3N0KHVybCwgbW9kZWwpO1xuICAgIH0gY2F0Y2ggKGU6IGFueSkge1xuICAgICAgdGhyb3cgdGhpcy5wYXJzZUVycm9yKGUpO1xuICAgIH1cbiAgfVxuICBhc3luYyByZWFkKFxuICAgIHRhYmxlTmFtZTogc3RyaW5nLFxuICAgIGlkOiBzdHJpbmcgfCBudW1iZXIgfCBiaWdpbnRcbiAgKTogUHJvbWlzZTxSZWNvcmQ8c3RyaW5nLCBhbnk+PiB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IHVybCA9IHRoaXMudXJsKHRhYmxlTmFtZSwgeyBpZDogaWQgYXMgc3RyaW5nIHwgbnVtYmVyIH0pO1xuICAgICAgcmV0dXJuIHRoaXMubmF0aXZlLmdldCh1cmwpO1xuICAgIH0gY2F0Y2ggKGU6IGFueSkge1xuICAgICAgdGhyb3cgdGhpcy5wYXJzZUVycm9yKGUpO1xuICAgIH1cbiAgfVxuXG4gIGFzeW5jIHVwZGF0ZShcbiAgICB0YWJsZU5hbWU6IHN0cmluZyxcbiAgICBpZDogc3RyaW5nIHwgbnVtYmVyLFxuICAgIG1vZGVsOiBSZWNvcmQ8c3RyaW5nLCBhbnk+XG4gICk6IFByb21pc2U8UmVjb3JkPHN0cmluZywgYW55Pj4ge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCB1cmwgPSB0aGlzLnVybCh0YWJsZU5hbWUpO1xuICAgICAgcmV0dXJuIHRoaXMubmF0aXZlLnB1dCh1cmwsIG1vZGVsKTtcbiAgICB9IGNhdGNoIChlOiBhbnkpIHtcbiAgICAgIHRocm93IHRoaXMucGFyc2VFcnJvcihlKTtcbiAgICB9XG4gIH1cblxuICBhc3luYyBkZWxldGUoXG4gICAgdGFibGVOYW1lOiBzdHJpbmcsXG4gICAgaWQ6IHN0cmluZyB8IG51bWJlciB8IGJpZ2ludFxuICApOiBQcm9taXNlPFJlY29yZDxzdHJpbmcsIGFueT4+IHtcbiAgICB0cnkge1xuICAgICAgY29uc3QgdXJsID0gdGhpcy51cmwodGFibGVOYW1lLCB7IGlkOiBpZCBhcyBzdHJpbmcgfCBudW1iZXIgfSk7XG4gICAgICByZXR1cm4gdGhpcy5uYXRpdmUuZGVsZXRlKHVybCk7XG4gICAgfSBjYXRjaCAoZTogYW55KSB7XG4gICAgICB0aHJvdyB0aGlzLnBhcnNlRXJyb3IoZSk7XG4gICAgfVxuICB9XG59XG4iXX0=
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"axios.js","sourceRoot":"","sources":["../../src/axios/axios.ts"],"names":[],"mappings":";;;AAAA,8CAAyC;AAKzC,+CAA2C;AAE3C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,MAAa,gBAAiB,SAAQ,qBAKrC;IACC,YAAY,MAAa,EAAE,MAAkB,EAAE,KAAc;QAC3D,KAAK,CAAC,MAAa,EAAE,MAAM,EAAE,wBAAY,EAAE,KAAK,CAAC,CAAC;IACpD,CAAC;IAED;;;;;;;OAOG;IACM,KAAK,CAAC,OAAO,CAAI,OAA2B;QACnD,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACtC,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,MAAM,CACV,SAAiB,EACjB,EAAmB,EACnB,KAA0B;QAE1B,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YAChC,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QACtC,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAC3B,CAAC;IACH,CAAC;IACD;;;;;;;OAOG;IACH,KAAK,CAAC,IAAI,CACR,SAAiB,EACjB,EAA4B;QAE5B,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,EAAE,EAAE,EAAE,EAAqB,EAAE,CAAC,CAAC;YAC/D,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAC9B,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAC3B,CAAC;IACH,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,MAAM,CACV,SAAiB,EACjB,EAAmB,EACnB,KAA0B;QAE1B,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YAChC,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QACrC,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAC3B,CAAC;IACH,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,MAAM,CACV,SAAiB,EACjB,EAA4B;QAE5B,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,EAAE,EAAE,EAAE,EAAqB,EAAE,CAAC,CAAC;YAC/D,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACjC,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAC3B,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,UAAU,KAAI,CAAC;CACvB;AA/GD,4CA+GC","sourcesContent":["import { HttpAdapter } from \"../adapter\";\nimport { Axios, AxiosRequestConfig } from \"axios\";\nimport { HttpConfig } from \"../types\";\nimport { AxiosFlags } from \"./types\";\nimport { Context } from \"@decaf-ts/db-decorators\";\nimport { AxiosFlavour } from \"./constants\";\n\n/**\n * @description Axios implementation of the HTTP adapter\n * @summary Concrete implementation of HttpAdapter using Axios as the HTTP client.\n * This adapter provides CRUD operations for RESTful APIs using Axios for HTTP requests.\n * @template Axios - The Axios client type\n * @template AxiosRequestConfig - The Axios request configuration type\n * @template AxiosFlags - The flags type extending HttpFlags\n * @template Context<AxiosFlags> - The context type for this adapter\n * @param {Axios} native - The Axios instance\n * @param {HttpConfig} config - Configuration for the HTTP adapter\n * @param {string} [alias] - Optional alias for the adapter\n * @class\n * @example\n * ```typescript\n * import axios from 'axios';\n * import { AxiosHttpAdapter } from '@decaf-ts/for-http';\n * \n * const config = { protocol: 'https', host: 'api.example.com' };\n * const adapter = new AxiosHttpAdapter(axios.create(), config);\n * \n * // Use the adapter with a repository\n * const userRepo = adapter.getRepository(User);\n * const user = await userRepo.findById('123');\n * ```\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant AxiosHttpAdapter\n *   participant Axios\n *   participant API\n *   \n *   Client->>AxiosHttpAdapter: create(table, id, data)\n *   AxiosHttpAdapter->>AxiosHttpAdapter: url(table)\n *   AxiosHttpAdapter->>Axios: post(url, data)\n *   Axios->>API: HTTP POST Request\n *   API-->>Axios: Response\n *   Axios-->>AxiosHttpAdapter: Response Data\n *   AxiosHttpAdapter-->>Client: Created Resource\n *   \n *   Client->>AxiosHttpAdapter: read(table, id)\n *   AxiosHttpAdapter->>AxiosHttpAdapter: url(table, {id})\n *   AxiosHttpAdapter->>Axios: get(url)\n *   Axios->>API: HTTP GET Request\n *   API-->>Axios: Response\n *   Axios-->>AxiosHttpAdapter: Response Data\n *   AxiosHttpAdapter-->>Client: Resource Data\n */\nexport class AxiosHttpAdapter extends HttpAdapter<\n  Axios,\n  AxiosRequestConfig,\n  AxiosFlags,\n  Context<AxiosFlags>\n> {\n  constructor(native: Axios, config: HttpConfig, alias?: string) {\n    super(native as any, config, AxiosFlavour, alias);\n  }\n\n  /**\n   * @description Sends an HTTP request using Axios\n   * @summary Implementation of the abstract request method from HttpAdapter.\n   * This method uses the Axios instance to send HTTP requests with the provided configuration.\n   * @template V - The response value type\n   * @param {AxiosRequestConfig} details - The Axios request configuration\n   * @return {Promise<V>} A promise that resolves with the response data\n   */\n  override async request<V>(details: AxiosRequestConfig): Promise<V> {\n    return this.native.request(details);\n  }\n\n  /**\n   * @description Creates a new resource via HTTP POST\n   * @summary Implementation of the abstract create method from HttpAdapter.\n   * This method sends a POST request to the specified endpoint with the model data.\n   * @param {string} tableName - The name of the table or endpoint\n   * @param {string|number} id - The identifier for the resource (not used in URL for POST)\n   * @param {Record<string, any>} model - The data model to create\n   * @return {Promise<Record<string, any>>} A promise that resolves with the created resource\n   */\n  async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    try {\n      const url = this.url(tableName);\n      return this.native.post(url, model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n  /**\n   * @description Retrieves a resource by ID via HTTP GET\n   * @summary Implementation of the abstract read method from HttpAdapter.\n   * This method sends a GET request to the specified endpoint with the ID as a query parameter.\n   * @param {string} tableName - The name of the table or endpoint\n   * @param {string|number|bigint} id - The identifier for the resource to retrieve\n   * @return {Promise<Record<string, any>>} A promise that resolves with the retrieved resource\n   */\n  async read(\n    tableName: string,\n    id: string | number | bigint\n  ): Promise<Record<string, any>> {\n    try {\n      const url = this.url(tableName, { id: id as string | number });\n      return this.native.get(url);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  /**\n   * @description Updates an existing resource via HTTP PUT\n   * @summary Implementation of the abstract update method from HttpAdapter.\n   * This method sends a PUT request to the specified endpoint with the updated model data.\n   * @param {string} tableName - The name of the table or endpoint\n   * @param {string|number} id - The identifier for the resource (not used in URL for PUT)\n   * @param {Record<string, any>} model - The updated data model\n   * @return {Promise<Record<string, any>>} A promise that resolves with the updated resource\n   */\n  async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    try {\n      const url = this.url(tableName);\n      return this.native.put(url, model);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  /**\n   * @description Deletes a resource by ID via HTTP DELETE\n   * @summary Implementation of the abstract delete method from HttpAdapter.\n   * This method sends a DELETE request to the specified endpoint with the ID as a query parameter.\n   * @param {string} tableName - The name of the table or endpoint\n   * @param {string|number|bigint} id - The identifier for the resource to delete\n   * @return {Promise<Record<string, any>>} A promise that resolves with the deletion result\n   */\n  async delete(\n    tableName: string,\n    id: string | number | bigint\n  ): Promise<Record<string, any>> {\n    try {\n      const url = this.url(tableName, { id: id as string | number });\n      return this.native.delete(url);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  /**\n   * @description Static decoration method for the AxiosHttpAdapter class\n   * @summary Placeholder method for class decoration functionality.\n   * This method is currently empty but can be used for decorator-based configuration.\n   */\n  static decoration() {}\n}\n"]}
|