@ayasofyazilim/saas 0.0.41 → 0.0.43

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 (123) hide show
  1. package/AccountService/AccountServiceClient.ts +68 -65
  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 +9 -9
  8. package/AccountService/schemas.gen.ts +5333 -5103
  9. package/AccountService/services.gen.ts +1539 -1452
  10. package/AccountService/types.gen.ts +3328 -9896
  11. package/AdministrationService/AdministrationServiceClient.ts +77 -74
  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 +9 -9
  18. package/AdministrationService/schemas.gen.ts +5987 -5897
  19. package/AdministrationService/services.gen.ts +1404 -1332
  20. package/AdministrationService/types.gen.ts +2851 -9024
  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 +9 -9
  27. package/BackerService/services.gen.ts +866 -866
  28. package/BackerService/types.gen.ts +2170 -14936
  29. package/CRMService/schemas.gen.ts +17444 -15928
  30. package/CRMService/services.gen.ts +2104 -2104
  31. package/CRMService/types.gen.ts +4278 -4189
  32. package/ContractService/ContractServiceClient.ts +0 -3
  33. package/ContractService/schemas.gen.ts +9512 -10590
  34. package/ContractService/services.gen.ts +1 -112
  35. package/ContractService/types.gen.ts +3504 -3709
  36. package/FundraiserService/core/ApiRequestOptions.ts +12 -12
  37. package/FundraiserService/core/BaseHttpRequest.ts +9 -9
  38. package/FundraiserService/core/FetchHttpRequest.ts +21 -21
  39. package/FundraiserService/core/OpenAPI.ts +55 -55
  40. package/FundraiserService/core/request.ts +340 -340
  41. package/FundraiserService/index.ts +9 -9
  42. package/FundraiserService/services.gen.ts +627 -627
  43. package/FundraiserService/types.gen.ts +1793 -11187
  44. package/IdentityService/IdentityServiceClient.ts +80 -77
  45. package/IdentityService/core/ApiRequestOptions.ts +12 -12
  46. package/IdentityService/core/BaseHttpRequest.ts +9 -9
  47. package/IdentityService/core/FetchHttpRequest.ts +21 -21
  48. package/IdentityService/core/OpenAPI.ts +55 -55
  49. package/IdentityService/core/request.ts +340 -340
  50. package/IdentityService/index.ts +9 -9
  51. package/IdentityService/schemas.gen.ts +6845 -6573
  52. package/IdentityService/services.gen.ts +2924 -2839
  53. package/IdentityService/types.gen.ts +5484 -17446
  54. package/LocationService/LocationServiceClient.ts +110 -110
  55. package/LocationService/core/ApiError.ts +20 -20
  56. package/LocationService/core/ApiRequestOptions.ts +12 -12
  57. package/LocationService/core/ApiResult.ts +6 -6
  58. package/LocationService/core/BaseHttpRequest.ts +9 -9
  59. package/LocationService/core/CancelablePromise.ts +125 -125
  60. package/LocationService/core/FetchHttpRequest.ts +21 -21
  61. package/LocationService/core/OpenAPI.ts +55 -55
  62. package/LocationService/core/request.ts +340 -340
  63. package/LocationService/index.ts +8 -8
  64. package/LocationService/schemas.gen.ts +10136 -10136
  65. package/LocationService/services.gen.ts +3392 -3392
  66. package/LocationService/types.gen.ts +6507 -6507
  67. package/MerchantService/core/ApiRequestOptions.ts +12 -12
  68. package/MerchantService/core/BaseHttpRequest.ts +9 -9
  69. package/MerchantService/core/FetchHttpRequest.ts +21 -21
  70. package/MerchantService/core/OpenAPI.ts +55 -55
  71. package/MerchantService/core/request.ts +340 -340
  72. package/MerchantService/schemas.gen.ts +14764 -14764
  73. package/MerchantService/services.gen.ts +1602 -1602
  74. package/ProjectService/core/ApiRequestOptions.ts +12 -12
  75. package/ProjectService/core/BaseHttpRequest.ts +9 -9
  76. package/ProjectService/core/FetchHttpRequest.ts +21 -21
  77. package/ProjectService/core/OpenAPI.ts +55 -55
  78. package/ProjectService/core/request.ts +340 -340
  79. package/ProjectService/index.ts +9 -9
  80. package/ProjectService/services.gen.ts +492 -492
  81. package/ProjectService/types.gen.ts +1303 -4978
  82. package/ProjectService.json +2937 -2937
  83. package/SaasService/core/ApiRequestOptions.ts +12 -12
  84. package/SaasService/core/BaseHttpRequest.ts +9 -9
  85. package/SaasService/core/FetchHttpRequest.ts +21 -21
  86. package/SaasService/core/OpenAPI.ts +55 -55
  87. package/SaasService/core/request.ts +340 -340
  88. package/SaasService/index.ts +9 -9
  89. package/SaasService/schemas.gen.ts +5345 -5278
  90. package/SaasService/services.gen.ts +1329 -1325
  91. package/SaasService/types.gen.ts +2737 -9052
  92. package/SettingService/schemas.gen.ts +5410 -5395
  93. package/SettingService/services.gen.ts +890 -843
  94. package/SettingService/types.gen.ts +2052 -1965
  95. package/TagService/TagServiceClient.ts +44 -0
  96. package/TagService/core/ApiError.ts +21 -0
  97. package/TagService/core/ApiRequestOptions.ts +13 -0
  98. package/TagService/core/ApiResult.ts +7 -0
  99. package/TagService/core/BaseHttpRequest.ts +10 -0
  100. package/TagService/core/CancelablePromise.ts +126 -0
  101. package/TagService/core/FetchHttpRequest.ts +22 -0
  102. package/TagService/core/OpenAPI.ts +56 -0
  103. package/TagService/core/request.ts +341 -0
  104. package/TagService/index.ts +9 -0
  105. package/TagService/schemas.gen.ts +4448 -0
  106. package/TagService/services.gen.ts +176 -0
  107. package/TagService/types.gen.ts +741 -0
  108. package/TravellerService/TravellerServiceClient.ts +56 -56
  109. package/TravellerService/core/ApiError.ts +20 -20
  110. package/TravellerService/core/ApiRequestOptions.ts +12 -12
  111. package/TravellerService/core/ApiResult.ts +6 -6
  112. package/TravellerService/core/BaseHttpRequest.ts +9 -9
  113. package/TravellerService/core/CancelablePromise.ts +125 -125
  114. package/TravellerService/core/FetchHttpRequest.ts +21 -21
  115. package/TravellerService/core/OpenAPI.ts +55 -55
  116. package/TravellerService/core/request.ts +340 -340
  117. package/TravellerService/index.ts +8 -8
  118. package/TravellerService/schemas.gen.ts +6184 -6204
  119. package/TravellerService/services.gen.ts +699 -695
  120. package/TravellerService/types.gen.ts +1805 -1808
  121. package/generator.mjs +5 -0
  122. package/package.json +1 -1
  123. package/swagger.json +4794 -4794
@@ -0,0 +1,44 @@
1
+ import type { BaseHttpRequest } from './core/BaseHttpRequest';
2
+ import type { OpenAPIConfig } from './core/OpenAPI';
3
+ import { Interceptors } from './core/OpenAPI';
4
+ import { FetchHttpRequest } from './core/FetchHttpRequest';
5
+
6
+ import { AbpApiDefinitionService } from './services.gen';
7
+ import { AbpApplicationConfigurationService } from './services.gen';
8
+ import { AbpApplicationLocalizationService } from './services.gen';
9
+ import { TagService } from './services.gen';
10
+
11
+ type HttpRequestConstructor = new (config: OpenAPIConfig) => BaseHttpRequest;
12
+
13
+ export class TagServiceClient {
14
+
15
+ public readonly abpApiDefinition: AbpApiDefinitionService;
16
+ public readonly abpApplicationConfiguration: AbpApplicationConfigurationService;
17
+ public readonly abpApplicationLocalization: AbpApplicationLocalizationService;
18
+ public readonly tag: TagService;
19
+
20
+ public readonly request: BaseHttpRequest;
21
+
22
+ constructor(config?: Partial<OpenAPIConfig>, HttpRequest: HttpRequestConstructor = FetchHttpRequest) {
23
+ this.request = new HttpRequest({
24
+ BASE: config?.BASE ?? '',
25
+ VERSION: config?.VERSION ?? '1',
26
+ WITH_CREDENTIALS: config?.WITH_CREDENTIALS ?? false,
27
+ CREDENTIALS: config?.CREDENTIALS ?? 'include',
28
+ TOKEN: config?.TOKEN,
29
+ USERNAME: config?.USERNAME,
30
+ PASSWORD: config?.PASSWORD,
31
+ HEADERS: config?.HEADERS,
32
+ ENCODE_PATH: config?.ENCODE_PATH,
33
+ interceptors: {
34
+ request: config?.interceptors?.request ?? new Interceptors(),
35
+ response: config?.interceptors?.response ?? new Interceptors(),
36
+ },
37
+ });
38
+
39
+ this.abpApiDefinition = new AbpApiDefinitionService(this.request);
40
+ this.abpApplicationConfiguration = new AbpApplicationConfigurationService(this.request);
41
+ this.abpApplicationLocalization = new AbpApplicationLocalizationService(this.request);
42
+ this.tag = new TagService(this.request);
43
+ }
44
+ }
@@ -0,0 +1,21 @@
1
+ import type { ApiRequestOptions } from './ApiRequestOptions';
2
+ import type { ApiResult } from './ApiResult';
3
+
4
+ export class ApiError extends Error {
5
+ public readonly url: string;
6
+ public readonly status: number;
7
+ public readonly statusText: string;
8
+ public readonly body: unknown;
9
+ public readonly request: ApiRequestOptions;
10
+
11
+ constructor(request: ApiRequestOptions, response: ApiResult, message: string) {
12
+ super(message);
13
+
14
+ this.name = 'ApiError';
15
+ this.url = response.url;
16
+ this.status = response.status;
17
+ this.statusText = response.statusText;
18
+ this.body = response.body;
19
+ this.request = request;
20
+ }
21
+ }
@@ -0,0 +1,13 @@
1
+ export type ApiRequestOptions = {
2
+ readonly method: 'GET' | 'PUT' | 'POST' | 'DELETE' | 'OPTIONS' | 'HEAD' | 'PATCH';
3
+ readonly url: string;
4
+ readonly path?: Record<string, unknown>;
5
+ readonly cookies?: Record<string, unknown>;
6
+ readonly headers?: Record<string, unknown>;
7
+ readonly query?: Record<string, unknown>;
8
+ readonly formData?: Record<string, unknown>;
9
+ readonly body?: any;
10
+ readonly mediaType?: string;
11
+ readonly responseHeader?: string;
12
+ readonly errors?: Record<number, string>;
13
+ };
@@ -0,0 +1,7 @@
1
+ export type ApiResult<TData = any> = {
2
+ readonly body: TData;
3
+ readonly ok: boolean;
4
+ readonly status: number;
5
+ readonly statusText: string;
6
+ readonly url: string;
7
+ };
@@ -0,0 +1,10 @@
1
+ import type { ApiRequestOptions } from './ApiRequestOptions';
2
+ import type { CancelablePromise } from './CancelablePromise';
3
+ import type { OpenAPIConfig } from './OpenAPI';
4
+
5
+ export abstract class BaseHttpRequest {
6
+
7
+ constructor(public readonly config: OpenAPIConfig) {}
8
+
9
+ public abstract request<T>(options: ApiRequestOptions): CancelablePromise<T>;
10
+ }
@@ -0,0 +1,126 @@
1
+ export class CancelError extends Error {
2
+ constructor(message: string) {
3
+ super(message);
4
+ this.name = 'CancelError';
5
+ }
6
+
7
+ public get isCancelled(): boolean {
8
+ return true;
9
+ }
10
+ }
11
+
12
+ export interface OnCancel {
13
+ readonly isResolved: boolean;
14
+ readonly isRejected: boolean;
15
+ readonly isCancelled: boolean;
16
+
17
+ (cancelHandler: () => void): void;
18
+ }
19
+
20
+ export class CancelablePromise<T> implements Promise<T> {
21
+ private _isResolved: boolean;
22
+ private _isRejected: boolean;
23
+ private _isCancelled: boolean;
24
+ readonly cancelHandlers: (() => void)[];
25
+ readonly promise: Promise<T>;
26
+ private _resolve?: (value: T | PromiseLike<T>) => void;
27
+ private _reject?: (reason?: unknown) => void;
28
+
29
+ constructor(
30
+ executor: (
31
+ resolve: (value: T | PromiseLike<T>) => void,
32
+ reject: (reason?: unknown) => void,
33
+ onCancel: OnCancel
34
+ ) => void
35
+ ) {
36
+ this._isResolved = false;
37
+ this._isRejected = false;
38
+ this._isCancelled = false;
39
+ this.cancelHandlers = [];
40
+ this.promise = new Promise<T>((resolve, reject) => {
41
+ this._resolve = resolve;
42
+ this._reject = reject;
43
+
44
+ const onResolve = (value: T | PromiseLike<T>): void => {
45
+ if (this._isResolved || this._isRejected || this._isCancelled) {
46
+ return;
47
+ }
48
+ this._isResolved = true;
49
+ if (this._resolve) this._resolve(value);
50
+ };
51
+
52
+ const onReject = (reason?: unknown): void => {
53
+ if (this._isResolved || this._isRejected || this._isCancelled) {
54
+ return;
55
+ }
56
+ this._isRejected = true;
57
+ if (this._reject) this._reject(reason);
58
+ };
59
+
60
+ const onCancel = (cancelHandler: () => void): void => {
61
+ if (this._isResolved || this._isRejected || this._isCancelled) {
62
+ return;
63
+ }
64
+ this.cancelHandlers.push(cancelHandler);
65
+ };
66
+
67
+ Object.defineProperty(onCancel, 'isResolved', {
68
+ get: (): boolean => this._isResolved,
69
+ });
70
+
71
+ Object.defineProperty(onCancel, 'isRejected', {
72
+ get: (): boolean => this._isRejected,
73
+ });
74
+
75
+ Object.defineProperty(onCancel, 'isCancelled', {
76
+ get: (): boolean => this._isCancelled,
77
+ });
78
+
79
+ return executor(onResolve, onReject, onCancel as OnCancel);
80
+ });
81
+ }
82
+
83
+ get [Symbol.toStringTag]() {
84
+ return "Cancellable Promise";
85
+ }
86
+
87
+ public then<TResult1 = T, TResult2 = never>(
88
+ onFulfilled?: ((value: T) => TResult1 | PromiseLike<TResult1>) | null,
89
+ onRejected?: ((reason: unknown) => TResult2 | PromiseLike<TResult2>) | null
90
+ ): Promise<TResult1 | TResult2> {
91
+ return this.promise.then(onFulfilled, onRejected);
92
+ }
93
+
94
+ public catch<TResult = never>(
95
+ onRejected?: ((reason: unknown) => TResult | PromiseLike<TResult>) | null
96
+ ): Promise<T | TResult> {
97
+ return this.promise.catch(onRejected);
98
+ }
99
+
100
+ public finally(onFinally?: (() => void) | null): Promise<T> {
101
+ return this.promise.finally(onFinally);
102
+ }
103
+
104
+ public cancel(): void {
105
+ if (this._isResolved || this._isRejected || this._isCancelled) {
106
+ return;
107
+ }
108
+ this._isCancelled = true;
109
+ if (this.cancelHandlers.length) {
110
+ try {
111
+ for (const cancelHandler of this.cancelHandlers) {
112
+ cancelHandler();
113
+ }
114
+ } catch (error) {
115
+ console.warn('Cancellation threw an error', error);
116
+ return;
117
+ }
118
+ }
119
+ this.cancelHandlers.length = 0;
120
+ if (this._reject) this._reject(new CancelError('Request aborted'));
121
+ }
122
+
123
+ public get isCancelled(): boolean {
124
+ return this._isCancelled;
125
+ }
126
+ }
@@ -0,0 +1,22 @@
1
+ import type { ApiRequestOptions } from './ApiRequestOptions';
2
+ import { BaseHttpRequest } from './BaseHttpRequest';
3
+ import type { CancelablePromise } from './CancelablePromise';
4
+ import type { OpenAPIConfig } from './OpenAPI';
5
+ import { request as __request } from './request';
6
+
7
+ export class FetchHttpRequest extends BaseHttpRequest {
8
+
9
+ constructor(config: OpenAPIConfig) {
10
+ super(config);
11
+ }
12
+
13
+ /**
14
+ * Request method
15
+ * @param options The request options from the service
16
+ * @returns CancelablePromise<T>
17
+ * @throws ApiError
18
+ */
19
+ public override request<T>(options: ApiRequestOptions): CancelablePromise<T> {
20
+ return __request(this.config, options);
21
+ }
22
+ }
@@ -0,0 +1,56 @@
1
+ import type { ApiRequestOptions } from './ApiRequestOptions';
2
+
3
+ type Headers = Record<string, string>;
4
+ type Middleware<T> = (value: T) => T | Promise<T>;
5
+ type Resolver<T> = (options: ApiRequestOptions) => Promise<T>;
6
+
7
+ export class Interceptors<T> {
8
+ _fns: Middleware<T>[];
9
+
10
+ constructor() {
11
+ this._fns = [];
12
+ }
13
+
14
+ eject(fn: Middleware<T>) {
15
+ const index = this._fns.indexOf(fn);
16
+ if (index !== -1) {
17
+ this._fns = [...this._fns.slice(0, index), ...this._fns.slice(index + 1)];
18
+ }
19
+ }
20
+
21
+ use(fn: Middleware<T>) {
22
+ this._fns = [...this._fns, fn];
23
+ }
24
+ }
25
+
26
+ export type OpenAPIConfig = {
27
+ BASE: string;
28
+ CREDENTIALS: 'include' | 'omit' | 'same-origin';
29
+ ENCODE_PATH?: ((path: string) => string) | undefined;
30
+ HEADERS?: Headers | Resolver<Headers> | undefined;
31
+ PASSWORD?: string | Resolver<string> | undefined;
32
+ TOKEN?: string | Resolver<string> | undefined;
33
+ USERNAME?: string | Resolver<string> | undefined;
34
+ VERSION: string;
35
+ WITH_CREDENTIALS: boolean;
36
+ interceptors: {
37
+ request: Interceptors<RequestInit>;
38
+ response: Interceptors<Response>;
39
+ };
40
+ };
41
+
42
+ export const OpenAPI: OpenAPIConfig = {
43
+ BASE: '',
44
+ CREDENTIALS: 'include',
45
+ ENCODE_PATH: undefined,
46
+ HEADERS: undefined,
47
+ PASSWORD: undefined,
48
+ TOKEN: undefined,
49
+ USERNAME: undefined,
50
+ VERSION: '1',
51
+ WITH_CREDENTIALS: false,
52
+ interceptors: {
53
+ request: new Interceptors(),
54
+ response: new Interceptors(),
55
+ },
56
+ };
@@ -0,0 +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
+ });
341
+ };
@@ -0,0 +1,9 @@
1
+ // This file is auto-generated by @hey-api/openapi-ts
2
+ export { TagServiceClient } from './TagServiceClient';
3
+ export { ApiError } from './core/ApiError';
4
+ export { BaseHttpRequest } from './core/BaseHttpRequest';
5
+ export { CancelablePromise, CancelError } from './core/CancelablePromise';
6
+ export { OpenAPI, type OpenAPIConfig } from './core/OpenAPI';
7
+ export * from './services.gen';
8
+ export * from './types.gen';
9
+ export * from './schemas.gen';