@ayasofyazilim/saas 0.0.60 → 0.0.62

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.
Files changed (103) hide show
  1. package/AccountService/AccountServiceClient.ts +68 -68
  2. package/AccountService/core/ApiRequestOptions.ts +12 -12
  3. package/AccountService/core/BaseHttpRequest.ts +9 -9
  4. package/AccountService/core/FetchHttpRequest.ts +21 -21
  5. package/AccountService/core/OpenAPI.ts +55 -55
  6. package/AccountService/core/request.ts +340 -340
  7. package/AccountService/index.ts +8 -8
  8. package/AccountService/schemas.gen.ts +5333 -5333
  9. package/AccountService/services.gen.ts +1539 -1539
  10. package/AccountService/types.gen.ts +3328 -3328
  11. package/AdministrationService/AdministrationServiceClient.ts +77 -77
  12. package/AdministrationService/core/ApiRequestOptions.ts +12 -12
  13. package/AdministrationService/core/BaseHttpRequest.ts +9 -9
  14. package/AdministrationService/core/FetchHttpRequest.ts +21 -21
  15. package/AdministrationService/core/OpenAPI.ts +55 -55
  16. package/AdministrationService/core/request.ts +340 -340
  17. package/AdministrationService/index.ts +8 -8
  18. package/AdministrationService/schemas.gen.ts +5987 -5987
  19. package/AdministrationService/services.gen.ts +1404 -1404
  20. package/AdministrationService/types.gen.ts +2851 -2851
  21. package/BackerService/core/ApiRequestOptions.ts +12 -12
  22. package/BackerService/core/BaseHttpRequest.ts +9 -9
  23. package/BackerService/core/FetchHttpRequest.ts +21 -21
  24. package/BackerService/core/OpenAPI.ts +55 -55
  25. package/BackerService/core/request.ts +340 -340
  26. package/BackerService/index.ts +8 -8
  27. package/BackerService/services.gen.ts +866 -866
  28. package/BackerService/types.gen.ts +2170 -2170
  29. package/ContractService/ContractServiceClient.ts +50 -50
  30. package/ContractService/schemas.gen.ts +9808 -9808
  31. package/ContractService/services.gen.ts +1716 -1716
  32. package/ContractService/types.gen.ts +3755 -3755
  33. package/FundraiserService/core/ApiRequestOptions.ts +12 -12
  34. package/FundraiserService/core/BaseHttpRequest.ts +9 -9
  35. package/FundraiserService/core/FetchHttpRequest.ts +21 -21
  36. package/FundraiserService/core/OpenAPI.ts +55 -55
  37. package/FundraiserService/core/request.ts +340 -340
  38. package/FundraiserService/index.ts +8 -8
  39. package/FundraiserService/services.gen.ts +627 -627
  40. package/FundraiserService/types.gen.ts +1793 -1793
  41. package/IdentityService/IdentityServiceClient.ts +80 -80
  42. package/IdentityService/core/ApiRequestOptions.ts +12 -12
  43. package/IdentityService/core/BaseHttpRequest.ts +9 -9
  44. package/IdentityService/core/FetchHttpRequest.ts +21 -21
  45. package/IdentityService/core/OpenAPI.ts +55 -55
  46. package/IdentityService/core/request.ts +340 -340
  47. package/IdentityService/index.ts +8 -8
  48. package/LocationService/LocationServiceClient.ts +74 -74
  49. package/LocationService/core/ApiError.ts +20 -20
  50. package/LocationService/core/ApiRequestOptions.ts +12 -12
  51. package/LocationService/core/ApiResult.ts +6 -6
  52. package/LocationService/core/BaseHttpRequest.ts +9 -9
  53. package/LocationService/core/CancelablePromise.ts +125 -125
  54. package/LocationService/core/FetchHttpRequest.ts +21 -21
  55. package/LocationService/core/OpenAPI.ts +55 -55
  56. package/LocationService/core/request.ts +340 -340
  57. package/LocationService/index.ts +8 -8
  58. package/MerchantService/core/ApiRequestOptions.ts +12 -12
  59. package/MerchantService/core/BaseHttpRequest.ts +9 -9
  60. package/MerchantService/core/FetchHttpRequest.ts +21 -21
  61. package/MerchantService/core/OpenAPI.ts +55 -55
  62. package/MerchantService/core/request.ts +340 -340
  63. package/MerchantService/schemas.gen.ts +14764 -14764
  64. package/MerchantService/services.gen.ts +1602 -1602
  65. package/ProjectService/core/ApiRequestOptions.ts +12 -12
  66. package/ProjectService/core/BaseHttpRequest.ts +9 -9
  67. package/ProjectService/core/FetchHttpRequest.ts +21 -21
  68. package/ProjectService/core/OpenAPI.ts +55 -55
  69. package/ProjectService/core/request.ts +340 -340
  70. package/ProjectService/index.ts +8 -8
  71. package/ProjectService/services.gen.ts +492 -492
  72. package/ProjectService/types.gen.ts +1303 -1303
  73. package/ProjectService.json +2937 -2937
  74. package/SaasService/core/ApiRequestOptions.ts +12 -12
  75. package/SaasService/core/BaseHttpRequest.ts +9 -9
  76. package/SaasService/core/FetchHttpRequest.ts +21 -21
  77. package/SaasService/core/OpenAPI.ts +55 -55
  78. package/SaasService/core/request.ts +340 -340
  79. package/SaasService/index.ts +8 -8
  80. package/SettingService/SettingServiceClient.ts +62 -62
  81. package/TagService/TagServiceClient.ts +44 -44
  82. package/TagService/core/ApiError.ts +20 -20
  83. package/TagService/core/ApiRequestOptions.ts +12 -12
  84. package/TagService/core/ApiResult.ts +6 -6
  85. package/TagService/core/BaseHttpRequest.ts +9 -9
  86. package/TagService/core/CancelablePromise.ts +125 -125
  87. package/TagService/core/FetchHttpRequest.ts +21 -21
  88. package/TagService/core/OpenAPI.ts +55 -55
  89. package/TagService/core/request.ts +340 -340
  90. package/TagService/index.ts +8 -8
  91. package/TagService/services.gen.ts +310 -310
  92. package/TravellerService/TravellerServiceClient.ts +56 -56
  93. package/TravellerService/core/ApiError.ts +20 -20
  94. package/TravellerService/core/ApiRequestOptions.ts +12 -12
  95. package/TravellerService/core/ApiResult.ts +6 -6
  96. package/TravellerService/core/BaseHttpRequest.ts +9 -9
  97. package/TravellerService/core/CancelablePromise.ts +125 -125
  98. package/TravellerService/core/FetchHttpRequest.ts +21 -21
  99. package/TravellerService/core/OpenAPI.ts +55 -55
  100. package/TravellerService/core/request.ts +340 -340
  101. package/TravellerService/index.ts +8 -8
  102. package/package.json +1 -1
  103. package/swagger.json +4794 -4794
@@ -1,341 +1,341 @@
1
- import { ApiError } from './ApiError';
2
- import type { ApiRequestOptions } from './ApiRequestOptions';
3
- import type { ApiResult } from './ApiResult';
4
- import { CancelablePromise } from './CancelablePromise';
5
- import type { OnCancel } from './CancelablePromise';
6
- import type { OpenAPIConfig } from './OpenAPI';
7
-
8
- export const isString = (value: unknown): value is string => {
9
- return typeof value === 'string';
10
- };
11
-
12
- export const isStringWithValue = (value: unknown): value is string => {
13
- return isString(value) && value !== '';
14
- };
15
-
16
- export const isBlob = (value: any): value is Blob => {
17
- return value instanceof Blob;
18
- };
19
-
20
- export const isFormData = (value: unknown): value is FormData => {
21
- return value instanceof FormData;
22
- };
23
-
24
- export const base64 = (str: string): string => {
25
- try {
26
- return btoa(str);
27
- } catch (err) {
28
- // @ts-ignore
29
- return Buffer.from(str).toString('base64');
30
- }
31
- };
32
-
33
- export const getQueryString = (params: Record<string, unknown>): string => {
34
- const qs: string[] = [];
35
-
36
- const append = (key: string, value: unknown) => {
37
- qs.push(`${encodeURIComponent(key)}=${encodeURIComponent(String(value))}`);
38
- };
39
-
40
- const encodePair = (key: string, value: unknown) => {
41
- if (value === undefined || value === null) {
42
- return;
43
- }
44
-
45
- if (value instanceof Date) {
46
- append(key, value.toISOString());
47
- } else if (Array.isArray(value)) {
48
- value.forEach(v => encodePair(key, v));
49
- } else if (typeof value === 'object') {
50
- Object.entries(value).forEach(([k, v]) => encodePair(`${key}[${k}]`, v));
51
- } else {
52
- append(key, value);
53
- }
54
- };
55
-
56
- Object.entries(params).forEach(([key, value]) => encodePair(key, value));
57
-
58
- return qs.length ? `?${qs.join('&')}` : '';
59
- };
60
-
61
- const getUrl = (config: OpenAPIConfig, options: ApiRequestOptions): string => {
62
- const encoder = config.ENCODE_PATH || encodeURI;
63
-
64
- const path = options.url
65
- .replace('{api-version}', config.VERSION)
66
- .replace(/{(.*?)}/g, (substring: string, group: string) => {
67
- if (options.path?.hasOwnProperty(group)) {
68
- return encoder(String(options.path[group]));
69
- }
70
- return substring;
71
- });
72
-
73
- const url = config.BASE + path;
74
- return options.query ? url + getQueryString(options.query) : url;
75
- };
76
-
77
- export const getFormData = (options: ApiRequestOptions): FormData | undefined => {
78
- if (options.formData) {
79
- const formData = new FormData();
80
-
81
- const process = (key: string, value: unknown) => {
82
- if (isString(value) || isBlob(value)) {
83
- formData.append(key, value);
84
- } else {
85
- formData.append(key, JSON.stringify(value));
86
- }
87
- };
88
-
89
- Object.entries(options.formData)
90
- .filter(([, value]) => value !== undefined && value !== null)
91
- .forEach(([key, value]) => {
92
- if (Array.isArray(value)) {
93
- value.forEach(v => process(key, v));
94
- } else {
95
- process(key, value);
96
- }
97
- });
98
-
99
- return formData;
100
- }
101
- return undefined;
102
- };
103
-
104
- type Resolver<T> = (options: ApiRequestOptions) => Promise<T>;
105
-
106
- export const resolve = async <T>(options: ApiRequestOptions, resolver?: T | Resolver<T>): Promise<T | undefined> => {
107
- if (typeof resolver === 'function') {
108
- return (resolver as Resolver<T>)(options);
109
- }
110
- return resolver;
111
- };
112
-
113
- export const getHeaders = async (config: OpenAPIConfig, options: ApiRequestOptions): Promise<Headers> => {
114
- const [token, username, password, additionalHeaders] = await Promise.all([
115
- resolve(options, config.TOKEN),
116
- resolve(options, config.USERNAME),
117
- resolve(options, config.PASSWORD),
118
- resolve(options, config.HEADERS),
119
- ]);
120
-
121
- const headers = Object.entries({
122
- Accept: 'application/json',
123
- ...additionalHeaders,
124
- ...options.headers,
125
- })
126
- .filter(([, value]) => value !== undefined && value !== null)
127
- .reduce((headers, [key, value]) => ({
128
- ...headers,
129
- [key]: String(value),
130
- }), {} as Record<string, string>);
131
-
132
- if (isStringWithValue(token)) {
133
- headers['Authorization'] = `Bearer ${token}`;
134
- }
135
-
136
- if (isStringWithValue(username) && isStringWithValue(password)) {
137
- const credentials = base64(`${username}:${password}`);
138
- headers['Authorization'] = `Basic ${credentials}`;
139
- }
140
-
141
- if (options.body !== undefined) {
142
- if (options.mediaType) {
143
- headers['Content-Type'] = options.mediaType;
144
- } else if (isBlob(options.body)) {
145
- headers['Content-Type'] = options.body.type || 'application/octet-stream';
146
- } else if (isString(options.body)) {
147
- headers['Content-Type'] = 'text/plain';
148
- } else if (!isFormData(options.body)) {
149
- headers['Content-Type'] = 'application/json';
150
- }
151
- }
152
-
153
- return new Headers(headers);
154
- };
155
-
156
- export const getRequestBody = (options: ApiRequestOptions): unknown => {
157
- if (options.body !== undefined) {
158
- if (options.mediaType?.includes('application/json') || options.mediaType?.includes('+json')) {
159
- return JSON.stringify(options.body);
160
- } else if (isString(options.body) || isBlob(options.body) || isFormData(options.body)) {
161
- return options.body;
162
- } else {
163
- return JSON.stringify(options.body);
164
- }
165
- }
166
- return undefined;
167
- };
168
-
169
- export const sendRequest = async (
170
- config: OpenAPIConfig,
171
- options: ApiRequestOptions,
172
- url: string,
173
- body: any,
174
- formData: FormData | undefined,
175
- headers: Headers,
176
- onCancel: OnCancel
177
- ): Promise<Response> => {
178
- const controller = new AbortController();
179
-
180
- let request: RequestInit = {
181
- headers,
182
- body: body ?? formData,
183
- method: options.method,
184
- signal: controller.signal,
185
- };
186
-
187
- if (config.WITH_CREDENTIALS) {
188
- request.credentials = config.CREDENTIALS;
189
- }
190
-
191
- for (const fn of config.interceptors.request._fns) {
192
- request = await fn(request);
193
- }
194
-
195
- onCancel(() => controller.abort());
196
-
197
- return await fetch(url, request);
198
- };
199
-
200
- export const getResponseHeader = (response: Response, responseHeader?: string): string | undefined => {
201
- if (responseHeader) {
202
- const content = response.headers.get(responseHeader);
203
- if (isString(content)) {
204
- return content;
205
- }
206
- }
207
- return undefined;
208
- };
209
-
210
- export const getResponseBody = async (response: Response): Promise<unknown> => {
211
- if (response.status !== 204) {
212
- try {
213
- const contentType = response.headers.get('Content-Type');
214
- if (contentType) {
215
- const binaryTypes = ['application/octet-stream', 'application/pdf', 'application/zip', 'audio/', 'image/', 'video/'];
216
- if (contentType.includes('application/json') || contentType.includes('+json')) {
217
- return await response.json();
218
- } else if (binaryTypes.some(type => contentType.includes(type))) {
219
- return await response.blob();
220
- } else if (contentType.includes('multipart/form-data')) {
221
- return await response.formData();
222
- } else if (contentType.includes('text/')) {
223
- return await response.text();
224
- }
225
- }
226
- } catch (error) {
227
- console.error(error);
228
- }
229
- }
230
- return undefined;
231
- };
232
-
233
- export const catchErrorCodes = (options: ApiRequestOptions, result: ApiResult): void => {
234
- const errors: Record<number, string> = {
235
- 400: 'Bad Request',
236
- 401: 'Unauthorized',
237
- 402: 'Payment Required',
238
- 403: 'Forbidden',
239
- 404: 'Not Found',
240
- 405: 'Method Not Allowed',
241
- 406: 'Not Acceptable',
242
- 407: 'Proxy Authentication Required',
243
- 408: 'Request Timeout',
244
- 409: 'Conflict',
245
- 410: 'Gone',
246
- 411: 'Length Required',
247
- 412: 'Precondition Failed',
248
- 413: 'Payload Too Large',
249
- 414: 'URI Too Long',
250
- 415: 'Unsupported Media Type',
251
- 416: 'Range Not Satisfiable',
252
- 417: 'Expectation Failed',
253
- 418: 'Im a teapot',
254
- 421: 'Misdirected Request',
255
- 422: 'Unprocessable Content',
256
- 423: 'Locked',
257
- 424: 'Failed Dependency',
258
- 425: 'Too Early',
259
- 426: 'Upgrade Required',
260
- 428: 'Precondition Required',
261
- 429: 'Too Many Requests',
262
- 431: 'Request Header Fields Too Large',
263
- 451: 'Unavailable For Legal Reasons',
264
- 500: 'Internal Server Error',
265
- 501: 'Not Implemented',
266
- 502: 'Bad Gateway',
267
- 503: 'Service Unavailable',
268
- 504: 'Gateway Timeout',
269
- 505: 'HTTP Version Not Supported',
270
- 506: 'Variant Also Negotiates',
271
- 507: 'Insufficient Storage',
272
- 508: 'Loop Detected',
273
- 510: 'Not Extended',
274
- 511: 'Network Authentication Required',
275
- ...options.errors,
276
- }
277
-
278
- const error = errors[result.status];
279
- if (error) {
280
- throw new ApiError(options, result, error);
281
- }
282
-
283
- if (!result.ok) {
284
- const errorStatus = result.status ?? 'unknown';
285
- const errorStatusText = result.statusText ?? 'unknown';
286
- const errorBody = (() => {
287
- try {
288
- return JSON.stringify(result.body, null, 2);
289
- } catch (e) {
290
- return undefined;
291
- }
292
- })();
293
-
294
- throw new ApiError(options, result,
295
- `Generic Error: status: ${errorStatus}; status text: ${errorStatusText}; body: ${errorBody}`
296
- );
297
- }
298
- };
299
-
300
- /**
301
- * Request method
302
- * @param config The OpenAPI configuration object
303
- * @param options The request options from the service
304
- * @returns CancelablePromise<T>
305
- * @throws ApiError
306
- */
307
- export const request = <T>(config: OpenAPIConfig, options: ApiRequestOptions): CancelablePromise<T> => {
308
- return new CancelablePromise(async (resolve, reject, onCancel) => {
309
- try {
310
- const url = getUrl(config, options);
311
- const formData = getFormData(options);
312
- const body = getRequestBody(options);
313
- const headers = await getHeaders(config, options);
314
-
315
- if (!onCancel.isCancelled) {
316
- let response = await sendRequest(config, options, url, body, formData, headers, onCancel);
317
-
318
- for (const fn of config.interceptors.response._fns) {
319
- response = await fn(response);
320
- }
321
-
322
- const responseBody = await getResponseBody(response);
323
- const responseHeader = getResponseHeader(response, options.responseHeader);
324
-
325
- const result: ApiResult = {
326
- url,
327
- ok: response.ok,
328
- status: response.status,
329
- statusText: response.statusText,
330
- body: responseHeader ?? responseBody,
331
- };
332
-
333
- catchErrorCodes(options, result);
334
-
335
- resolve(result.body);
336
- }
337
- } catch (error) {
338
- reject(error);
339
- }
340
- });
1
+ import { ApiError } from './ApiError';
2
+ import type { ApiRequestOptions } from './ApiRequestOptions';
3
+ import type { ApiResult } from './ApiResult';
4
+ import { CancelablePromise } from './CancelablePromise';
5
+ import type { OnCancel } from './CancelablePromise';
6
+ import type { OpenAPIConfig } from './OpenAPI';
7
+
8
+ export const isString = (value: unknown): value is string => {
9
+ return typeof value === 'string';
10
+ };
11
+
12
+ export const isStringWithValue = (value: unknown): value is string => {
13
+ return isString(value) && value !== '';
14
+ };
15
+
16
+ export const isBlob = (value: any): value is Blob => {
17
+ return value instanceof Blob;
18
+ };
19
+
20
+ export const isFormData = (value: unknown): value is FormData => {
21
+ return value instanceof FormData;
22
+ };
23
+
24
+ export const base64 = (str: string): string => {
25
+ try {
26
+ return btoa(str);
27
+ } catch (err) {
28
+ // @ts-ignore
29
+ return Buffer.from(str).toString('base64');
30
+ }
31
+ };
32
+
33
+ export const getQueryString = (params: Record<string, unknown>): string => {
34
+ const qs: string[] = [];
35
+
36
+ const append = (key: string, value: unknown) => {
37
+ qs.push(`${encodeURIComponent(key)}=${encodeURIComponent(String(value))}`);
38
+ };
39
+
40
+ const encodePair = (key: string, value: unknown) => {
41
+ if (value === undefined || value === null) {
42
+ return;
43
+ }
44
+
45
+ if (value instanceof Date) {
46
+ append(key, value.toISOString());
47
+ } else if (Array.isArray(value)) {
48
+ value.forEach(v => encodePair(key, v));
49
+ } else if (typeof value === 'object') {
50
+ Object.entries(value).forEach(([k, v]) => encodePair(`${key}[${k}]`, v));
51
+ } else {
52
+ append(key, value);
53
+ }
54
+ };
55
+
56
+ Object.entries(params).forEach(([key, value]) => encodePair(key, value));
57
+
58
+ return qs.length ? `?${qs.join('&')}` : '';
59
+ };
60
+
61
+ const getUrl = (config: OpenAPIConfig, options: ApiRequestOptions): string => {
62
+ const encoder = config.ENCODE_PATH || encodeURI;
63
+
64
+ const path = options.url
65
+ .replace('{api-version}', config.VERSION)
66
+ .replace(/{(.*?)}/g, (substring: string, group: string) => {
67
+ if (options.path?.hasOwnProperty(group)) {
68
+ return encoder(String(options.path[group]));
69
+ }
70
+ return substring;
71
+ });
72
+
73
+ const url = config.BASE + path;
74
+ return options.query ? url + getQueryString(options.query) : url;
75
+ };
76
+
77
+ export const getFormData = (options: ApiRequestOptions): FormData | undefined => {
78
+ if (options.formData) {
79
+ const formData = new FormData();
80
+
81
+ const process = (key: string, value: unknown) => {
82
+ if (isString(value) || isBlob(value)) {
83
+ formData.append(key, value);
84
+ } else {
85
+ formData.append(key, JSON.stringify(value));
86
+ }
87
+ };
88
+
89
+ Object.entries(options.formData)
90
+ .filter(([, value]) => value !== undefined && value !== null)
91
+ .forEach(([key, value]) => {
92
+ if (Array.isArray(value)) {
93
+ value.forEach(v => process(key, v));
94
+ } else {
95
+ process(key, value);
96
+ }
97
+ });
98
+
99
+ return formData;
100
+ }
101
+ return undefined;
102
+ };
103
+
104
+ type Resolver<T> = (options: ApiRequestOptions) => Promise<T>;
105
+
106
+ export const resolve = async <T>(options: ApiRequestOptions, resolver?: T | Resolver<T>): Promise<T | undefined> => {
107
+ if (typeof resolver === 'function') {
108
+ return (resolver as Resolver<T>)(options);
109
+ }
110
+ return resolver;
111
+ };
112
+
113
+ export const getHeaders = async (config: OpenAPIConfig, options: ApiRequestOptions): Promise<Headers> => {
114
+ const [token, username, password, additionalHeaders] = await Promise.all([
115
+ resolve(options, config.TOKEN),
116
+ resolve(options, config.USERNAME),
117
+ resolve(options, config.PASSWORD),
118
+ resolve(options, config.HEADERS),
119
+ ]);
120
+
121
+ const headers = Object.entries({
122
+ Accept: 'application/json',
123
+ ...additionalHeaders,
124
+ ...options.headers,
125
+ })
126
+ .filter(([, value]) => value !== undefined && value !== null)
127
+ .reduce((headers, [key, value]) => ({
128
+ ...headers,
129
+ [key]: String(value),
130
+ }), {} as Record<string, string>);
131
+
132
+ if (isStringWithValue(token)) {
133
+ headers['Authorization'] = `Bearer ${token}`;
134
+ }
135
+
136
+ if (isStringWithValue(username) && isStringWithValue(password)) {
137
+ const credentials = base64(`${username}:${password}`);
138
+ headers['Authorization'] = `Basic ${credentials}`;
139
+ }
140
+
141
+ if (options.body !== undefined) {
142
+ if (options.mediaType) {
143
+ headers['Content-Type'] = options.mediaType;
144
+ } else if (isBlob(options.body)) {
145
+ headers['Content-Type'] = options.body.type || 'application/octet-stream';
146
+ } else if (isString(options.body)) {
147
+ headers['Content-Type'] = 'text/plain';
148
+ } else if (!isFormData(options.body)) {
149
+ headers['Content-Type'] = 'application/json';
150
+ }
151
+ }
152
+
153
+ return new Headers(headers);
154
+ };
155
+
156
+ export const getRequestBody = (options: ApiRequestOptions): unknown => {
157
+ if (options.body !== undefined) {
158
+ if (options.mediaType?.includes('application/json') || options.mediaType?.includes('+json')) {
159
+ return JSON.stringify(options.body);
160
+ } else if (isString(options.body) || isBlob(options.body) || isFormData(options.body)) {
161
+ return options.body;
162
+ } else {
163
+ return JSON.stringify(options.body);
164
+ }
165
+ }
166
+ return undefined;
167
+ };
168
+
169
+ export const sendRequest = async (
170
+ config: OpenAPIConfig,
171
+ options: ApiRequestOptions,
172
+ url: string,
173
+ body: any,
174
+ formData: FormData | undefined,
175
+ headers: Headers,
176
+ onCancel: OnCancel
177
+ ): Promise<Response> => {
178
+ const controller = new AbortController();
179
+
180
+ let request: RequestInit = {
181
+ headers,
182
+ body: body ?? formData,
183
+ method: options.method,
184
+ signal: controller.signal,
185
+ };
186
+
187
+ if (config.WITH_CREDENTIALS) {
188
+ request.credentials = config.CREDENTIALS;
189
+ }
190
+
191
+ for (const fn of config.interceptors.request._fns) {
192
+ request = await fn(request);
193
+ }
194
+
195
+ onCancel(() => controller.abort());
196
+
197
+ return await fetch(url, request);
198
+ };
199
+
200
+ export const getResponseHeader = (response: Response, responseHeader?: string): string | undefined => {
201
+ if (responseHeader) {
202
+ const content = response.headers.get(responseHeader);
203
+ if (isString(content)) {
204
+ return content;
205
+ }
206
+ }
207
+ return undefined;
208
+ };
209
+
210
+ export const getResponseBody = async (response: Response): Promise<unknown> => {
211
+ if (response.status !== 204) {
212
+ try {
213
+ const contentType = response.headers.get('Content-Type');
214
+ if (contentType) {
215
+ const binaryTypes = ['application/octet-stream', 'application/pdf', 'application/zip', 'audio/', 'image/', 'video/'];
216
+ if (contentType.includes('application/json') || contentType.includes('+json')) {
217
+ return await response.json();
218
+ } else if (binaryTypes.some(type => contentType.includes(type))) {
219
+ return await response.blob();
220
+ } else if (contentType.includes('multipart/form-data')) {
221
+ return await response.formData();
222
+ } else if (contentType.includes('text/')) {
223
+ return await response.text();
224
+ }
225
+ }
226
+ } catch (error) {
227
+ console.error(error);
228
+ }
229
+ }
230
+ return undefined;
231
+ };
232
+
233
+ export const catchErrorCodes = (options: ApiRequestOptions, result: ApiResult): void => {
234
+ const errors: Record<number, string> = {
235
+ 400: 'Bad Request',
236
+ 401: 'Unauthorized',
237
+ 402: 'Payment Required',
238
+ 403: 'Forbidden',
239
+ 404: 'Not Found',
240
+ 405: 'Method Not Allowed',
241
+ 406: 'Not Acceptable',
242
+ 407: 'Proxy Authentication Required',
243
+ 408: 'Request Timeout',
244
+ 409: 'Conflict',
245
+ 410: 'Gone',
246
+ 411: 'Length Required',
247
+ 412: 'Precondition Failed',
248
+ 413: 'Payload Too Large',
249
+ 414: 'URI Too Long',
250
+ 415: 'Unsupported Media Type',
251
+ 416: 'Range Not Satisfiable',
252
+ 417: 'Expectation Failed',
253
+ 418: 'Im a teapot',
254
+ 421: 'Misdirected Request',
255
+ 422: 'Unprocessable Content',
256
+ 423: 'Locked',
257
+ 424: 'Failed Dependency',
258
+ 425: 'Too Early',
259
+ 426: 'Upgrade Required',
260
+ 428: 'Precondition Required',
261
+ 429: 'Too Many Requests',
262
+ 431: 'Request Header Fields Too Large',
263
+ 451: 'Unavailable For Legal Reasons',
264
+ 500: 'Internal Server Error',
265
+ 501: 'Not Implemented',
266
+ 502: 'Bad Gateway',
267
+ 503: 'Service Unavailable',
268
+ 504: 'Gateway Timeout',
269
+ 505: 'HTTP Version Not Supported',
270
+ 506: 'Variant Also Negotiates',
271
+ 507: 'Insufficient Storage',
272
+ 508: 'Loop Detected',
273
+ 510: 'Not Extended',
274
+ 511: 'Network Authentication Required',
275
+ ...options.errors,
276
+ }
277
+
278
+ const error = errors[result.status];
279
+ if (error) {
280
+ throw new ApiError(options, result, error);
281
+ }
282
+
283
+ if (!result.ok) {
284
+ const errorStatus = result.status ?? 'unknown';
285
+ const errorStatusText = result.statusText ?? 'unknown';
286
+ const errorBody = (() => {
287
+ try {
288
+ return JSON.stringify(result.body, null, 2);
289
+ } catch (e) {
290
+ return undefined;
291
+ }
292
+ })();
293
+
294
+ throw new ApiError(options, result,
295
+ `Generic Error: status: ${errorStatus}; status text: ${errorStatusText}; body: ${errorBody}`
296
+ );
297
+ }
298
+ };
299
+
300
+ /**
301
+ * Request method
302
+ * @param config The OpenAPI configuration object
303
+ * @param options The request options from the service
304
+ * @returns CancelablePromise<T>
305
+ * @throws ApiError
306
+ */
307
+ export const request = <T>(config: OpenAPIConfig, options: ApiRequestOptions): CancelablePromise<T> => {
308
+ return new CancelablePromise(async (resolve, reject, onCancel) => {
309
+ try {
310
+ const url = getUrl(config, options);
311
+ const formData = getFormData(options);
312
+ const body = getRequestBody(options);
313
+ const headers = await getHeaders(config, options);
314
+
315
+ if (!onCancel.isCancelled) {
316
+ let response = await sendRequest(config, options, url, body, formData, headers, onCancel);
317
+
318
+ for (const fn of config.interceptors.response._fns) {
319
+ response = await fn(response);
320
+ }
321
+
322
+ const responseBody = await getResponseBody(response);
323
+ const responseHeader = getResponseHeader(response, options.responseHeader);
324
+
325
+ const result: ApiResult = {
326
+ url,
327
+ ok: response.ok,
328
+ status: response.status,
329
+ statusText: response.statusText,
330
+ body: responseHeader ?? responseBody,
331
+ };
332
+
333
+ catchErrorCodes(options, result);
334
+
335
+ resolve(result.body);
336
+ }
337
+ } catch (error) {
338
+ reject(error);
339
+ }
340
+ });
341
341
  };