-
Notifications
You must be signed in to change notification settings - Fork 514
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix(cli): version the whole client for deno compatibility
- Loading branch information
1 parent
aeb5b5b
commit 81c2bb0
Showing
10 changed files
with
13,006 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1 @@ | ||
npm/ | ||
gen/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
import type { ApiRequestOptions } from './ApiRequestOptions.ts'; | ||
import type { ApiResult } from './ApiResult.ts'; | ||
|
||
export class ApiError extends Error { | ||
public readonly url: string; | ||
public readonly status: number; | ||
public readonly statusText: string; | ||
public readonly body: unknown; | ||
public readonly request: ApiRequestOptions; | ||
|
||
constructor(request: ApiRequestOptions, response: ApiResult, message: string) { | ||
super(message); | ||
|
||
this.name = 'ApiError'; | ||
this.url = response.url; | ||
this.status = response.status; | ||
this.statusText = response.statusText; | ||
this.body = response.body; | ||
this.request = request; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
export type ApiRequestOptions<T = unknown> = { | ||
readonly body?: any; | ||
readonly cookies?: Record<string, unknown>; | ||
readonly errors?: Record<number | string, string>; | ||
readonly formData?: Record<string, unknown> | any[] | Blob | File; | ||
readonly headers?: Record<string, unknown>; | ||
readonly mediaType?: string; | ||
readonly method: | ||
| 'DELETE' | ||
| 'GET' | ||
| 'HEAD' | ||
| 'OPTIONS' | ||
| 'PATCH' | ||
| 'POST' | ||
| 'PUT'; | ||
readonly path?: Record<string, unknown>; | ||
readonly query?: Record<string, unknown>; | ||
readonly responseHeader?: string; | ||
readonly responseTransformer?: (data: unknown) => Promise<T>; | ||
readonly url: string; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
export type ApiResult<TData = any> = { | ||
readonly body: TData; | ||
readonly ok: boolean; | ||
readonly status: number; | ||
readonly statusText: string; | ||
readonly url: string; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,126 @@ | ||
export class CancelError extends Error { | ||
constructor(message: string) { | ||
super(message); | ||
this.name = 'CancelError'; | ||
} | ||
|
||
public get isCancelled(): boolean { | ||
return true; | ||
} | ||
} | ||
|
||
export interface OnCancel { | ||
readonly isResolved: boolean; | ||
readonly isRejected: boolean; | ||
readonly isCancelled: boolean; | ||
|
||
(cancelHandler: () => void): void; | ||
} | ||
|
||
export class CancelablePromise<T> implements Promise<T> { | ||
private _isResolved: boolean; | ||
private _isRejected: boolean; | ||
private _isCancelled: boolean; | ||
readonly cancelHandlers: (() => void)[]; | ||
readonly promise: Promise<T>; | ||
private _resolve?: (value: T | PromiseLike<T>) => void; | ||
private _reject?: (reason?: unknown) => void; | ||
|
||
constructor( | ||
executor: ( | ||
resolve: (value: T | PromiseLike<T>) => void, | ||
reject: (reason?: unknown) => void, | ||
onCancel: OnCancel | ||
) => void | ||
) { | ||
this._isResolved = false; | ||
this._isRejected = false; | ||
this._isCancelled = false; | ||
this.cancelHandlers = []; | ||
this.promise = new Promise<T>((resolve, reject) => { | ||
this._resolve = resolve; | ||
this._reject = reject; | ||
|
||
const onResolve = (value: T | PromiseLike<T>): void => { | ||
if (this._isResolved || this._isRejected || this._isCancelled) { | ||
return; | ||
} | ||
this._isResolved = true; | ||
if (this._resolve) this._resolve(value); | ||
}; | ||
|
||
const onReject = (reason?: unknown): void => { | ||
if (this._isResolved || this._isRejected || this._isCancelled) { | ||
return; | ||
} | ||
this._isRejected = true; | ||
if (this._reject) this._reject(reason); | ||
}; | ||
|
||
const onCancel = (cancelHandler: () => void): void => { | ||
if (this._isResolved || this._isRejected || this._isCancelled) { | ||
return; | ||
} | ||
this.cancelHandlers.push(cancelHandler); | ||
}; | ||
|
||
Object.defineProperty(onCancel, 'isResolved', { | ||
get: (): boolean => this._isResolved, | ||
}); | ||
|
||
Object.defineProperty(onCancel, 'isRejected', { | ||
get: (): boolean => this._isRejected, | ||
}); | ||
|
||
Object.defineProperty(onCancel, 'isCancelled', { | ||
get: (): boolean => this._isCancelled, | ||
}); | ||
|
||
return executor(onResolve, onReject, onCancel as OnCancel); | ||
}); | ||
} | ||
|
||
get [Symbol.toStringTag]() { | ||
return "Cancellable Promise"; | ||
} | ||
|
||
public then<TResult1 = T, TResult2 = never>( | ||
onFulfilled?: ((value: T) => TResult1 | PromiseLike<TResult1>) | null, | ||
onRejected?: ((reason: unknown) => TResult2 | PromiseLike<TResult2>) | null | ||
): Promise<TResult1 | TResult2> { | ||
return this.promise.then(onFulfilled, onRejected); | ||
} | ||
|
||
public catch<TResult = never>( | ||
onRejected?: ((reason: unknown) => TResult | PromiseLike<TResult>) | null | ||
): Promise<T | TResult> { | ||
return this.promise.catch(onRejected); | ||
} | ||
|
||
public finally(onFinally?: (() => void) | null): Promise<T> { | ||
return this.promise.finally(onFinally); | ||
} | ||
|
||
public cancel(): void { | ||
if (this._isResolved || this._isRejected || this._isCancelled) { | ||
return; | ||
} | ||
this._isCancelled = true; | ||
if (this.cancelHandlers.length) { | ||
try { | ||
for (const cancelHandler of this.cancelHandlers) { | ||
cancelHandler(); | ||
} | ||
} catch (error) { | ||
console.warn('Cancellation threw an error', error); | ||
return; | ||
} | ||
} | ||
this.cancelHandlers.length = 0; | ||
if (this._reject) this._reject(new CancelError('Request aborted')); | ||
} | ||
|
||
public get isCancelled(): boolean { | ||
return this._isCancelled; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
const getEnv = (key: string) => { | ||
return Deno.env.get(key) | ||
}; | ||
|
||
const baseUrl = getEnv("BASE_INTERNAL_URL") ?? getEnv("BASE_URL") ?? "http://localhost:8000"; | ||
const baseUrlApi = (baseUrl ?? '') + "/api"; | ||
|
||
import type { ApiRequestOptions } from './ApiRequestOptions.ts'; | ||
|
||
type Headers = Record<string, string>; | ||
type Middleware<T> = (value: T) => T | Promise<T>; | ||
type Resolver<T> = (options: ApiRequestOptions<T>) => Promise<T>; | ||
|
||
export class Interceptors<T> { | ||
_fns: Middleware<T>[]; | ||
|
||
constructor() { | ||
this._fns = []; | ||
} | ||
|
||
eject(fn: Middleware<T>): void { | ||
const index = this._fns.indexOf(fn); | ||
if (index !== -1) { | ||
this._fns = [...this._fns.slice(0, index), ...this._fns.slice(index + 1)]; | ||
} | ||
} | ||
|
||
use(fn: Middleware<T>): void { | ||
this._fns = [...this._fns, fn]; | ||
} | ||
} | ||
|
||
export type OpenAPIConfig = { | ||
BASE: string; | ||
CREDENTIALS: 'include' | 'omit' | 'same-origin'; | ||
ENCODE_PATH?: ((path: string) => string) | undefined; | ||
HEADERS?: Headers | Resolver<Headers> | undefined; | ||
PASSWORD?: string | Resolver<string> | undefined; | ||
TOKEN?: string | Resolver<string> | undefined; | ||
USERNAME?: string | Resolver<string> | undefined; | ||
VERSION: string; | ||
WITH_CREDENTIALS: boolean; | ||
interceptors: { | ||
request: Interceptors<RequestInit>; | ||
response: Interceptors<Response>; | ||
}; | ||
}; | ||
|
||
export const OpenAPI: OpenAPIConfig = { | ||
BASE: baseUrlApi, | ||
CREDENTIALS: 'include', | ||
ENCODE_PATH: undefined, | ||
HEADERS: undefined, | ||
PASSWORD: undefined, | ||
TOKEN: getEnv("WM_TOKEN"), | ||
USERNAME: undefined, | ||
VERSION: '1.398.1', | ||
WITH_CREDENTIALS: true, | ||
interceptors: { | ||
request: new Interceptors(), | ||
response: new Interceptors(), | ||
}, | ||
}; |
Oops, something went wrong.