@wener/utils 1.1.20 → 1.1.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/index.cjs +5 -5
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/cjs/server.cjs +1 -1
- package/dist/cjs/server.cjs.map +1 -1
- package/dist/esm/index.js +4 -4
- package/dist/esm/index.js.map +1 -1
- package/dist/system/index.js +5 -5
- package/dist/system/index.js.map +1 -1
- package/lib/asyncs/createAsyncIterator.js.map +1 -1
- package/lib/asyncs/createLazyPromise.js.map +1 -1
- package/lib/errors/Errors.js +137 -0
- package/lib/errors/Errors.js.map +1 -0
- package/lib/fetch/dumpResponse.js +1 -1
- package/lib/fetch/dumpResponse.js.map +1 -1
- package/lib/http/HttpStatus.js +85 -0
- package/lib/http/HttpStatus.js.map +1 -0
- package/lib/index.js +3 -1
- package/lib/index.js.map +1 -1
- package/package.json +7 -6
- package/src/asyncs/createAsyncIterator.ts +10 -7
- package/src/asyncs/createLazyPromise.test.ts +9 -8
- package/src/asyncs/createLazyPromise.ts +1 -1
- package/src/errors/Errors.ts +199 -0
- package/src/fetch/dumpResponse.ts +3 -3
- package/src/http/HttpStatus.ts +96 -0
- package/src/index.ts +9 -1
- package/src/types/global.d.ts +11 -0
- package/src/types/index.d.ts +8 -0
- package/types.d.ts +1 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createAsyncIterator.js","sources":["../../src/asyncs/createAsyncIterator.ts"],"sourcesContent":["import { createLazyPromise, LazyPromise } from './createLazyPromise';\n\nexport function createAsyncIterator<T>(\n fn: (next: (val: [T | undefined, boolean] | undefined, err?: any) => void) => void,\n) {\n const values: Array<Promise<
|
|
1
|
+
{"version":3,"file":"createAsyncIterator.js","sources":["../../src/asyncs/createAsyncIterator.ts"],"sourcesContent":["import { type MaybePromise } from './MaybePromise';\nimport { createLazyPromise, type LazyPromise } from './createLazyPromise';\n\ntype Val<T> = [val: MaybePromise<T> | undefined, done: boolean, err?: any];\n\nexport function createAsyncIterator<T>(\n fn: (next: (val: [MaybePromise<T> | undefined, boolean] | undefined, err?: any) => void) => void,\n): AsyncGenerator<T, void, unknown> {\n const values: Array<Promise<Val<T>>> = [];\n let recv: (val: [MaybePromise<T> | undefined, boolean] | undefined, err?: any) => void;\n {\n let next: LazyPromise<Val<T>>;\n values.push((next = createLazyPromise()));\n recv = (val, err) => {\n if (err !== undefined) {\n next.resolve([undefined, true, err]);\n } else if (val !== undefined) {\n next.resolve(val);\n } else {\n return;\n }\n values.push((next = createLazyPromise()));\n };\n }\n\n fn(recv);\n\n return (async function* () {\n let value: Val<T>[0];\n let err: any;\n for (let i = 0, done = false; !done; i++) {\n let result = await values[i];\n delete values[i];\n [value, done, err] = result;\n if (err) {\n throw err;\n }\n if (value !== undefined) {\n yield value;\n }\n }\n })();\n}\n"],"names":[],"mappings":";;AAKO,SAAS,oBACd,EACkC,EAAA;AAClC,EAAA,MAAM,SAAiC,EAAC,CAAA;AACxC,EAAI,IAAA,IAAA,CAAA;AACJ,EAAA;AACE,IAAI,IAAA,IAAA,CAAA;AACJ,IAAO,MAAA,CAAA,IAAA,CAAM,IAAO,GAAA,iBAAA,EAAoB,CAAA,CAAA;AACxC,IAAO,IAAA,GAAA,CAAC,KAAK,GAAQ,KAAA;AACnB,MAAA,IAAI,QAAQ,KAAW,CAAA,EAAA;AACrB,QAAA,IAAA,CAAK,OAAQ,CAAA,CAAC,KAAW,CAAA,EAAA,IAAA,EAAM,GAAG,CAAC,CAAA,CAAA;AAAA,OACrC,MAAA,IAAW,QAAQ,KAAW,CAAA,EAAA;AAC5B,QAAA,IAAA,CAAK,QAAQ,GAAG,CAAA,CAAA;AAAA,OACX,MAAA;AACL,QAAA,OAAA;AAAA,OACF;AACA,MAAO,MAAA,CAAA,IAAA,CAAM,IAAO,GAAA,iBAAA,EAAoB,CAAA,CAAA;AAAA,KAC1C,CAAA;AAAA,GACF;AAEA,EAAA,EAAA,CAAG,IAAI,CAAA,CAAA;AAEP,EAAA,OAAQ,mBAAmB;AACzB,IAAI,IAAA,KAAA,CAAA;AACJ,IAAI,IAAA,GAAA,CAAA;AACJ,IAAA,KAAA,IAAS,IAAI,CAAG,EAAA,IAAA,GAAO,KAAO,EAAA,CAAC,MAAM,CAAK,EAAA,EAAA;AACxC,MAAI,IAAA,MAAA,GAAS,MAAM,MAAA,CAAO,CAAC,CAAA,CAAA;AAC3B,MAAA,OAAO,OAAO,CAAC,CAAA,CAAA;AACf,MAAC,CAAA,KAAA,EAAO,IAAM,EAAA,GAAG,CAAI,GAAA,MAAA,CAAA;AACrB,MAAA,IAAI,GAAK,EAAA;AACP,QAAM,MAAA,GAAA,CAAA;AAAA,OACR;AACA,MAAA,IAAI,UAAU,KAAW,CAAA,EAAA;AACvB,QAAM,MAAA,KAAA,CAAA;AAAA,OACR;AAAA,KACF;AAAA,GACC,EAAA,CAAA;AACL;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createLazyPromise.js","sources":["../../src/asyncs/createLazyPromise.ts"],"sourcesContent":["import type { MaybePromise } from './MaybePromise';\nimport { isPromise } from './isPromise';\n\nexport type LazyPromise<T> = Promise<T> & {\n reject(reason?: any): void;\n resolve(v?:
|
|
1
|
+
{"version":3,"file":"createLazyPromise.js","sources":["../../src/asyncs/createLazyPromise.ts"],"sourcesContent":["import type { MaybePromise } from './MaybePromise';\nimport { isPromise } from './isPromise';\n\nexport type LazyPromise<T> = Promise<T> & {\n reject(reason?: any): void;\n resolve(v?: MaybePromise<T>): void;\n};\n\n/**\n * createLazyPromise return a promise that can be resolved or rejected manually.\n * if you pass a function to it, it will be executed when the promise try to resolve.\n */\nexport function createLazyPromise<T = any>(\n executor?:\n | ((resolve: LazyPromise<T>['resolve'], reject: LazyPromise<T>['reject']) => void)\n | ((resolve: LazyPromise<T>['resolve'], reject: LazyPromise<T>['reject']) => MaybePromise<T>),\n): LazyPromise<T> {\n const holder = {\n resolve(_: any): void {\n throw new Error('pending resolve');\n },\n reject(_: any): void {\n throw new Error('pending reject');\n },\n };\n const future = Object.assign(\n new Promise<T>((resolve, reject) => {\n holder.reject = reject;\n holder.resolve = resolve;\n }),\n {\n resolve(v: any) {\n holder.resolve(v);\n },\n reject(v: any) {\n holder.resolve(v);\n },\n },\n );\n if (executor) {\n const r = holder.resolve;\n let shouldExec = true;\n holder.resolve = (v: any) => {\n shouldExec = false;\n r(v);\n };\n const then = future.then.bind(future);\n future.then = (...args) => {\n if (shouldExec) {\n shouldExec = false;\n try {\n // kind of bad\n const result = executor(holder.resolve, holder.reject);\n // ensure resolve/reject is called\n if (isPromise(result)) {\n result.then(holder.resolve, holder.reject);\n } else if (result !== undefined) {\n holder.resolve(result);\n }\n } catch (e) {\n holder.reject(e);\n }\n }\n return then(...args);\n };\n const like = holder as LazyPromise<T>;\n like.then = future.then;\n like.catch = future.catch.bind(future);\n if (future.finally) like.finally = future.finally;\n\n void Object.defineProperty(like, Symbol.species, {\n get() {\n return Promise;\n },\n });\n return like;\n }\n return future;\n}\n"],"names":[],"mappings":";;AAYO,SAAS,kBACd,QAGgB,EAAA;AAChB,EAAA,MAAM,MAAS,GAAA;AAAA,IACb,QAAQ,CAAc,EAAA;AACpB,MAAM,MAAA,IAAI,MAAM,iBAAiB,CAAA,CAAA;AAAA,KACnC;AAAA,IACA,OAAO,CAAc,EAAA;AACnB,MAAM,MAAA,IAAI,MAAM,gBAAgB,CAAA,CAAA;AAAA,KAClC;AAAA,GACF,CAAA;AACA,EAAA,MAAM,SAAS,MAAO,CAAA,MAAA;AAAA,IACpB,IAAI,OAAA,CAAW,CAAC,OAAA,EAAS,MAAW,KAAA;AAClC,MAAA,MAAA,CAAO,MAAS,GAAA,MAAA,CAAA;AAChB,MAAA,MAAA,CAAO,OAAU,GAAA,OAAA,CAAA;AAAA,KAClB,CAAA;AAAA,IACD;AAAA,MACE,QAAQ,CAAQ,EAAA;AACd,QAAA,MAAA,CAAO,QAAQ,CAAC,CAAA,CAAA;AAAA,OAClB;AAAA,MACA,OAAO,CAAQ,EAAA;AACb,QAAA,MAAA,CAAO,QAAQ,CAAC,CAAA,CAAA;AAAA,OAClB;AAAA,KACF;AAAA,GACF,CAAA;AACA,EAAA,IAAI,QAAU,EAAA;AACZ,IAAA,MAAM,IAAI,MAAO,CAAA,OAAA,CAAA;AACjB,IAAA,IAAI,UAAa,GAAA,IAAA,CAAA;AACjB,IAAO,MAAA,CAAA,OAAA,GAAU,CAAC,CAAW,KAAA;AAC3B,MAAa,UAAA,GAAA,KAAA,CAAA;AACb,MAAA,CAAA,CAAE,CAAC,CAAA,CAAA;AAAA,KACL,CAAA;AACA,IAAA,MAAM,IAAO,GAAA,MAAA,CAAO,IAAK,CAAA,IAAA,CAAK,MAAM,CAAA,CAAA;AACpC,IAAO,MAAA,CAAA,IAAA,GAAO,IAAI,IAAS,KAAA;AACzB,MAAA,IAAI,UAAY,EAAA;AACd,QAAa,UAAA,GAAA,KAAA,CAAA;AACb,QAAI,IAAA;AAEF,UAAA,MAAM,MAAS,GAAA,QAAA,CAAS,MAAO,CAAA,OAAA,EAAS,OAAO,MAAM,CAAA,CAAA;AAErD,UAAI,IAAA,SAAA,CAAU,MAAM,CAAG,EAAA;AACrB,YAAA,MAAA,CAAO,IAAK,CAAA,MAAA,CAAO,OAAS,EAAA,MAAA,CAAO,MAAM,CAAA,CAAA;AAAA,WAC3C,MAAA,IAAW,WAAW,KAAW,CAAA,EAAA;AAC/B,YAAA,MAAA,CAAO,QAAQ,MAAM,CAAA,CAAA;AAAA,WACvB;AAAA,iBACO,CAAG,EAAA;AACV,UAAA,MAAA,CAAO,OAAO,CAAC,CAAA,CAAA;AAAA,SACjB;AAAA,OACF;AACA,MAAO,OAAA,IAAA,CAAK,GAAG,IAAI,CAAA,CAAA;AAAA,KACrB,CAAA;AACA,IAAA,MAAM,IAAO,GAAA,MAAA,CAAA;AACb,IAAA,IAAA,CAAK,OAAO,MAAO,CAAA,IAAA,CAAA;AACnB,IAAA,IAAA,CAAK,KAAQ,GAAA,MAAA,CAAO,KAAM,CAAA,IAAA,CAAK,MAAM,CAAA,CAAA;AACrC,IAAA,IAAI,MAAO,CAAA,OAAA;AAAS,MAAA,IAAA,CAAK,UAAU,MAAO,CAAA,OAAA,CAAA;AAE1C,IAAA,KAAK,MAAO,CAAA,cAAA,CAAe,IAAM,EAAA,MAAA,CAAO,OAAS,EAAA;AAAA,MAC/C,GAAM,GAAA;AACJ,QAAO,OAAA,OAAA,CAAA;AAAA,OACT;AAAA,KACD,CAAA,CAAA;AACD,IAAO,OAAA,IAAA,CAAA;AAAA,GACT;AACA,EAAO,OAAA,MAAA,CAAA;AACT;;;;"}
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { getHttpStatusText } from '../http/HttpStatus.js';
|
|
2
|
+
|
|
3
|
+
class DetailError extends Error {
|
|
4
|
+
constructor(detail) {
|
|
5
|
+
super(detail.message, {
|
|
6
|
+
cause: detail.cause
|
|
7
|
+
});
|
|
8
|
+
this.detail = detail;
|
|
9
|
+
this.status = detail.status;
|
|
10
|
+
this.description = detail.description;
|
|
11
|
+
}
|
|
12
|
+
status;
|
|
13
|
+
description;
|
|
14
|
+
toJSON() {
|
|
15
|
+
return {
|
|
16
|
+
code: this.detail.code,
|
|
17
|
+
message: this.message,
|
|
18
|
+
status: this.status,
|
|
19
|
+
description: this.description,
|
|
20
|
+
cause: this.cause
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
class DetailHolder {
|
|
25
|
+
message;
|
|
26
|
+
status;
|
|
27
|
+
code;
|
|
28
|
+
metadata;
|
|
29
|
+
description;
|
|
30
|
+
cause;
|
|
31
|
+
constructor({
|
|
32
|
+
status,
|
|
33
|
+
message = getHttpStatusText(status),
|
|
34
|
+
code = status,
|
|
35
|
+
metadata,
|
|
36
|
+
description,
|
|
37
|
+
cause
|
|
38
|
+
}) {
|
|
39
|
+
this.message = message != null ? message : String(status);
|
|
40
|
+
this.status = status;
|
|
41
|
+
this.code = code;
|
|
42
|
+
this.description = description;
|
|
43
|
+
this.metadata = metadata;
|
|
44
|
+
this.cause = cause;
|
|
45
|
+
}
|
|
46
|
+
with(o) {
|
|
47
|
+
if (typeof o === "string") {
|
|
48
|
+
o = { message: o };
|
|
49
|
+
}
|
|
50
|
+
if (o === void 0) {
|
|
51
|
+
return new DetailHolder(this);
|
|
52
|
+
}
|
|
53
|
+
return new DetailHolder({
|
|
54
|
+
status: this.status,
|
|
55
|
+
code: this.code,
|
|
56
|
+
message: this.message,
|
|
57
|
+
metadata: this.metadata,
|
|
58
|
+
cause: this.cause,
|
|
59
|
+
...o
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
asError(o) {
|
|
63
|
+
if (typeof o === "string") {
|
|
64
|
+
o = { message: o };
|
|
65
|
+
}
|
|
66
|
+
return new DetailError(this.with(o));
|
|
67
|
+
}
|
|
68
|
+
require(v, o) {
|
|
69
|
+
if (v === void 0 || v === null) {
|
|
70
|
+
throw this.asError(o);
|
|
71
|
+
}
|
|
72
|
+
return v;
|
|
73
|
+
}
|
|
74
|
+
check(cond, o) {
|
|
75
|
+
switch (cond) {
|
|
76
|
+
case false:
|
|
77
|
+
case void 0:
|
|
78
|
+
case null: {
|
|
79
|
+
throw this.asError(o);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
throw(o) {
|
|
84
|
+
throw this.asError(o);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
class Errors {
|
|
88
|
+
static BadRequest = this.with({ status: 400 });
|
|
89
|
+
static Unauthorized = this.with({ status: 403 });
|
|
90
|
+
static Forbidden = this.with({ status: 403 });
|
|
91
|
+
static NotFound = this.with({ status: 404 });
|
|
92
|
+
static InternalServerError = this.with({ status: 501 });
|
|
93
|
+
static NotImplemented = this.with({ status: 501 });
|
|
94
|
+
static ServiceUnavailable = this.with({ status: 503 });
|
|
95
|
+
static with(init) {
|
|
96
|
+
return new DetailHolder(init);
|
|
97
|
+
}
|
|
98
|
+
static ok(res, o) {
|
|
99
|
+
if (res.ok) {
|
|
100
|
+
return res;
|
|
101
|
+
}
|
|
102
|
+
throw this.with({
|
|
103
|
+
description: res.statusText,
|
|
104
|
+
status: res.status,
|
|
105
|
+
...o,
|
|
106
|
+
metadata: {
|
|
107
|
+
...o == null ? void 0 : o.metadata,
|
|
108
|
+
response: res
|
|
109
|
+
}
|
|
110
|
+
}).asError();
|
|
111
|
+
}
|
|
112
|
+
static resolve(e) {
|
|
113
|
+
if (e instanceof DetailHolder) {
|
|
114
|
+
return e;
|
|
115
|
+
}
|
|
116
|
+
if (e instanceof DetailError) {
|
|
117
|
+
return e.detail;
|
|
118
|
+
}
|
|
119
|
+
if (e instanceof Error) {
|
|
120
|
+
const { message, code, status } = e;
|
|
121
|
+
return new DetailHolder({
|
|
122
|
+
message,
|
|
123
|
+
status: parseInt(status) || 500,
|
|
124
|
+
code,
|
|
125
|
+
cause: e
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
return new DetailHolder({
|
|
129
|
+
message: e.message,
|
|
130
|
+
status: 500,
|
|
131
|
+
cause: e
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
export { Errors };
|
|
137
|
+
//# sourceMappingURL=Errors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Errors.js","sources":["../../src/errors/Errors.ts"],"sourcesContent":["import { getHttpStatusText } from '../http/HttpStatus';\n\nexport interface ErrorDetailInit {\n message?: string;\n status: number;\n description?: string;\n code?: number | string;\n metadata?: Record<string, any>;\n cause?: any;\n}\n\nclass DetailError extends Error {\n readonly status: number;\n readonly description?: string;\n\n constructor(readonly detail: ErrorDetail) {\n super(detail.message, {\n cause: detail.cause,\n });\n this.status = detail.status;\n this.description = detail.description;\n }\n\n toJSON() {\n return {\n code: this.detail.code,\n message: this.message,\n status: this.status,\n description: this.description,\n cause: this.cause,\n };\n }\n}\n\nclass DetailHolder implements ErrorDetail {\n readonly message: string;\n readonly status: number;\n readonly code: number | string;\n readonly metadata?: Record<string, any>;\n readonly description?: string;\n readonly cause?: any;\n\n constructor({\n status,\n message = getHttpStatusText(status),\n code = status,\n metadata,\n description,\n cause,\n }: ErrorDetailInit) {\n this.message = message ?? String(status);\n this.status = status;\n this.code = code;\n this.description = description;\n this.metadata = metadata;\n this.cause = cause;\n }\n\n with(o?: Partial<ErrorDetailInit> | string): DetailHolder {\n if (typeof o === 'string') {\n o = { message: o };\n }\n\n if (o === undefined) {\n return new DetailHolder(this);\n }\n\n return new DetailHolder({\n status: this.status,\n code: this.code,\n message: this.message,\n metadata: this.metadata,\n cause: this.cause,\n ...o,\n });\n }\n\n asError(o?: Partial<ErrorDetailInit> | string): Error {\n if (typeof o === 'string') {\n o = { message: o };\n }\n\n return new DetailError(this.with(o));\n }\n\n require(v: any, o?: Partial<ErrorDetailInit> | string): any {\n if (v === undefined || v === null) {\n throw this.asError(o);\n }\n\n return v;\n }\n\n check(cond: any, o?: Partial<ErrorDetailInit> | string) {\n switch (cond) {\n case false:\n case undefined:\n case null: {\n throw this.asError(o);\n }\n }\n }\n\n throw(o?: Partial<ErrorDetailInit>): never {\n throw this.asError(o);\n }\n}\n\nexport interface ErrorDetail {\n readonly message: string;\n readonly status: number;\n readonly code?: number | string;\n readonly metadata?: Record<string, any>;\n readonly description?: string;\n readonly cause?: any;\n\n with(message: string): ErrorDetail;\n\n with(o?: Partial<ErrorDetailInit>): ErrorDetail;\n\n asError(o?: Partial<ErrorDetailInit>): Error;\n\n asError(message: string): Error;\n\n throw(o?: Partial<ErrorDetailInit>): never;\n\n require<T>(v: T | undefined, o?: Partial<ErrorDetailInit> | string): NonNullable<T>;\n\n // 不支持 return value\n // https://stackoverflow.com/a/73252858/1870054\n\n check(condition: boolean, o?: Partial<ErrorDetailInit> | string): asserts condition;\n\n check<T>(v: T | undefined | null, o?: Partial<ErrorDetailInit> | string): asserts v is NonNullable<T>;\n}\n\nexport class Errors {\n static BadRequest: ErrorDetail = this.with({ status: 400 });\n static Unauthorized: ErrorDetail = this.with({ status: 403 });\n static Forbidden: ErrorDetail = this.with({ status: 403 });\n static NotFound: ErrorDetail = this.with({ status: 404 });\n static InternalServerError: ErrorDetail = this.with({ status: 501 });\n static NotImplemented: ErrorDetail = this.with({ status: 501 });\n static ServiceUnavailable: ErrorDetail = this.with({ status: 503 });\n\n static with(init: ErrorDetailInit): ErrorDetail {\n return new DetailHolder(init);\n }\n\n static ok(res: Response, o?: Partial<ErrorDetailInit>) {\n if (res.ok) {\n return res;\n }\n throw this.with({\n description: res.statusText,\n status: res.status,\n ...o,\n metadata: {\n ...o?.metadata,\n response: res,\n },\n }).asError();\n }\n\n static resolve(e: any): ErrorDetail {\n if (e instanceof DetailHolder) {\n return e;\n }\n\n if (e instanceof DetailError) {\n return e.detail;\n }\n\n if (e instanceof Error) {\n const { message, code, status } = e as any;\n // can get status from NestJS HttpException\n return new DetailHolder({\n message,\n status: parseInt(status) || 500,\n code,\n cause: e,\n });\n }\n\n return new DetailHolder({\n message: e.message,\n status: 500,\n cause: e,\n });\n }\n}\n\n// interface ZodError {\n// path: Array<string | number>;\n// message: string;\n// code: string;\n// expected?: any;\n// received?: any;\n// }\n"],"names":[],"mappings":"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"}
|
|
@@ -5,7 +5,7 @@ async function dumpResponse({
|
|
|
5
5
|
log = console.log
|
|
6
6
|
}) {
|
|
7
7
|
let out = `<- ${res.status} ${res.statusText} ${req.method} ${url}
|
|
8
|
-
|
|
8
|
+
${Array.from(res.headers.entries()).map(([k, v]) => `${k}: ${v}`).join("\n")}
|
|
9
9
|
`;
|
|
10
10
|
let contentType = res.headers.get("content-type");
|
|
11
11
|
if ((contentType == null ? void 0 : contentType.includes("application/json")) || (contentType == null ? void 0 : contentType.includes("text/plain"))) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dumpResponse.js","sources":["../../src/fetch/dumpResponse.ts"],"sourcesContent":["export async function dumpResponse({\n res,\n url,\n req,\n log = console.log,\n}: {\n res: Response;\n url: string;\n req: RequestInit;\n log?: (s: string) => void;\n}) {\n let out = `<- ${res.status} ${res.statusText} ${req.method} ${url}\n
|
|
1
|
+
{"version":3,"file":"dumpResponse.js","sources":["../../src/fetch/dumpResponse.ts"],"sourcesContent":["export async function dumpResponse({\n res,\n url,\n req,\n log = console.log,\n}: {\n res: Response;\n url: string;\n req: RequestInit;\n log?: (s: string) => void;\n}) {\n let out = `<- ${res.status} ${res.statusText} ${req.method} ${url}\n${Array.from(res.headers.entries())\n .map(([k, v]) => `${k}: ${v}`)\n .join('\\n')}\n `;\n let contentType = res.headers.get('content-type');\n // TODO text/event-stream\n if (contentType?.includes('application/json') || contentType?.includes('text/plain')) {\n const body = await res.text();\n out += `\\n${body}\\n`;\n res = new Response(body, res);\n }\n\n log(out);\n\n return res;\n}\n"],"names":[],"mappings":"AAAA,eAAsB,YAAa,CAAA;AAAA,EACjC,GAAA;AAAA,EACA,GAAA;AAAA,EACA,GAAA;AAAA,EACA,MAAM,OAAQ,CAAA,GAAA;AAChB,CAKG,EAAA;AACD,EAAI,IAAA,GAAA,GAAM,CAAM,GAAA,EAAA,GAAA,CAAI,MAAM,CAAA,CAAA,EAAI,GAAI,CAAA,UAAU,CAAI,CAAA,EAAA,GAAA,CAAI,MAAM,CAAA,CAAA,EAAI,GAAG,CAAA;AAAA,EACjE,KAAA,CAAM,KAAK,GAAI,CAAA,OAAA,CAAQ,SAAS,CAAA,CAC/B,IAAI,CAAC,CAAC,GAAG,CAAC,CAAA,KAAM,GAAG,CAAC,CAAA,EAAA,EAAK,CAAC,CAAE,CAAA,CAAA,CAC5B,IAAK,CAAA,IAAI,CAAC,CAAA;AAAA,GAAA,CAAA,CAAA;AAEX,EAAA,IAAI,WAAc,GAAA,GAAA,CAAI,OAAQ,CAAA,GAAA,CAAI,cAAc,CAAA,CAAA;AAEhD,EAAA,IAAA,CAAI,WAAa,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,WAAA,CAAA,QAAA,CAAS,kBAAuB,CAAA,MAAA,WAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,WAAA,CAAa,SAAS,YAAe,CAAA,CAAA,EAAA;AACpF,IAAM,MAAA,IAAA,GAAO,MAAM,GAAA,CAAI,IAAK,EAAA,CAAA;AAC5B,IAAO,GAAA,IAAA,CAAA;AAAA,EAAK,IAAI,CAAA;AAAA,CAAA,CAAA;AAChB,IAAM,GAAA,GAAA,IAAI,QAAS,CAAA,IAAA,EAAM,GAAG,CAAA,CAAA;AAAA,GAC9B;AAEA,EAAA,GAAA,CAAI,GAAG,CAAA,CAAA;AAEP,EAAO,OAAA,GAAA,CAAA;AACT;;;;"}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
const HttpStatus = {
|
|
2
|
+
100: "Continue",
|
|
3
|
+
101: "Switching Protocols",
|
|
4
|
+
102: "Processing",
|
|
5
|
+
103: "Early Hints",
|
|
6
|
+
200: "OK",
|
|
7
|
+
201: "Created",
|
|
8
|
+
202: "Accepted",
|
|
9
|
+
203: "Non-Authoritative Information",
|
|
10
|
+
204: "No Content",
|
|
11
|
+
205: "Reset Content",
|
|
12
|
+
206: "Partial Content",
|
|
13
|
+
207: "Multi-Status",
|
|
14
|
+
208: "Already Reported",
|
|
15
|
+
226: "IM Used",
|
|
16
|
+
300: "Multiple Choices",
|
|
17
|
+
301: "Moved Permanently",
|
|
18
|
+
302: "Found",
|
|
19
|
+
303: "See Other",
|
|
20
|
+
304: "Not Modified",
|
|
21
|
+
305: "Use Proxy",
|
|
22
|
+
306: "Unused",
|
|
23
|
+
307: "Temporary Redirect",
|
|
24
|
+
308: "Permanent Redirect",
|
|
25
|
+
400: "Bad Request",
|
|
26
|
+
401: "Unauthorized",
|
|
27
|
+
402: "Payment Required",
|
|
28
|
+
403: "Forbidden",
|
|
29
|
+
404: "Not Found",
|
|
30
|
+
405: "Method Not Allowed",
|
|
31
|
+
406: "Not Acceptable",
|
|
32
|
+
407: "Proxy Authentication Required",
|
|
33
|
+
408: "Request Timeout",
|
|
34
|
+
409: "Conflict",
|
|
35
|
+
410: "Gone",
|
|
36
|
+
411: "Length Required",
|
|
37
|
+
412: "Precondition Required",
|
|
38
|
+
413: "Request Entry Too Large",
|
|
39
|
+
414: "Request-URI Too Long",
|
|
40
|
+
415: "Unsupported Media Type",
|
|
41
|
+
416: "Requested Range Not Satisfiable",
|
|
42
|
+
417: "Expectation Failed",
|
|
43
|
+
418: "I'm a teapot",
|
|
44
|
+
421: "Misdirected Request",
|
|
45
|
+
422: "Unprocessable Entity",
|
|
46
|
+
423: "Locked",
|
|
47
|
+
424: "Failed Dependency",
|
|
48
|
+
425: "Too Early",
|
|
49
|
+
426: "Upgrade Required",
|
|
50
|
+
428: "Precondition Required",
|
|
51
|
+
429: "Too Many Requests",
|
|
52
|
+
431: "Request Header Fields Too Large",
|
|
53
|
+
451: "Unavailable For Legal Reasons",
|
|
54
|
+
500: "Internal Server Error",
|
|
55
|
+
501: "Not Implemented",
|
|
56
|
+
502: "Bad Gateway",
|
|
57
|
+
503: "Service Unavailable",
|
|
58
|
+
504: "Gateway Timeout",
|
|
59
|
+
505: "HTTP Version Not Supported",
|
|
60
|
+
506: "Variant Also Negotiates",
|
|
61
|
+
507: "Insufficient Storage",
|
|
62
|
+
508: "Loop Detected",
|
|
63
|
+
509: "Bandwidth Limit Exceeded",
|
|
64
|
+
510: "Not Extended",
|
|
65
|
+
511: "Network Authentication Required"
|
|
66
|
+
};
|
|
67
|
+
function getHttpStatusText(status) {
|
|
68
|
+
return HttpStatus[status];
|
|
69
|
+
}
|
|
70
|
+
function isRetryableHttpStatus(status) {
|
|
71
|
+
switch (status) {
|
|
72
|
+
case 408:
|
|
73
|
+
case 425:
|
|
74
|
+
case 429:
|
|
75
|
+
case 502:
|
|
76
|
+
case 503:
|
|
77
|
+
case 504:
|
|
78
|
+
return true;
|
|
79
|
+
default:
|
|
80
|
+
return false;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
export { getHttpStatusText, isRetryableHttpStatus };
|
|
85
|
+
//# sourceMappingURL=HttpStatus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HttpStatus.js","sources":["../../src/http/HttpStatus.ts"],"sourcesContent":["// http://httpstat.us/\n// https://en.wikipedia.org/wiki/List_of_HTTP_status_codes\nconst HttpStatus: Record<string, string> = {\n 100: 'Continue',\n 101: 'Switching Protocols',\n 102: 'Processing',\n 103: 'Early Hints',\n 200: 'OK',\n 201: 'Created',\n 202: 'Accepted',\n 203: 'Non-Authoritative Information',\n 204: 'No Content',\n 205: 'Reset Content',\n 206: 'Partial Content',\n 207: 'Multi-Status',\n 208: 'Already Reported',\n 226: 'IM Used',\n 300: 'Multiple Choices',\n 301: 'Moved Permanently',\n 302: 'Found',\n 303: 'See Other',\n 304: 'Not Modified',\n 305: 'Use Proxy',\n 306: 'Unused',\n 307: 'Temporary Redirect',\n 308: 'Permanent Redirect',\n\n 400: 'Bad Request',\n 401: 'Unauthorized',\n 402: 'Payment Required',\n 403: 'Forbidden',\n 404: 'Not Found',\n 405: 'Method Not Allowed',\n 406: 'Not Acceptable',\n 407: 'Proxy Authentication Required',\n 408: 'Request Timeout',\n 409: 'Conflict',\n 410: 'Gone',\n 411: 'Length Required',\n 412: 'Precondition Required',\n 413: 'Request Entry Too Large',\n 414: 'Request-URI Too Long',\n 415: 'Unsupported Media Type',\n 416: 'Requested Range Not Satisfiable',\n 417: 'Expectation Failed',\n 418: \"I'm a teapot\",\n 421: 'Misdirected Request',\n 422: 'Unprocessable Entity',\n 423: 'Locked',\n 424: 'Failed Dependency',\n 425: 'Too Early',\n 426: 'Upgrade Required',\n 428: 'Precondition Required',\n 429: 'Too Many Requests',\n 431: 'Request Header Fields Too Large',\n 451: 'Unavailable For Legal Reasons',\n 500: 'Internal Server Error',\n 501: 'Not Implemented',\n 502: 'Bad Gateway',\n 503: 'Service Unavailable',\n 504: 'Gateway Timeout',\n 505: 'HTTP Version Not Supported',\n 506: 'Variant Also Negotiates',\n 507: 'Insufficient Storage',\n 508: 'Loop Detected',\n 509: 'Bandwidth Limit Exceeded',\n 510: 'Not Extended',\n 511: 'Network Authentication Required',\n};\n\nexport function getHttpStatusText(status: number | string): string | undefined {\n return HttpStatus[status];\n}\n\nexport function isRetryableHttpStatus(status: number) {\n switch (status) {\n /*\n408 Request Timeout\n425 Too Early\n429 Too Many Requests\n500 Internal Server Error\n502 Bad Gateway\n503 Service Unavailable\n504 Gateway Timeout\n */\n case 408:\n case 425:\n case 429:\n case 502:\n case 503:\n case 504:\n return true;\n default:\n return false;\n }\n}\n"],"names":[],"mappings":"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"}
|
package/lib/index.js
CHANGED
|
@@ -8,6 +8,7 @@ export { createLazyPromise } from './asyncs/createLazyPromise.js';
|
|
|
8
8
|
export { clearAsyncInterval, setAsyncInterval } from './asyncs/AsyncInterval.js';
|
|
9
9
|
export { createAsyncIterator } from './asyncs/createAsyncIterator.js';
|
|
10
10
|
export { firstOfAsyncIterator } from './asyncs/firstOfAsyncIterator.js';
|
|
11
|
+
export { nextOfAsyncIterator } from './asyncs/nextOfAsyncIterator.js';
|
|
11
12
|
export { isIterator } from './asyncs/isIterator.js';
|
|
12
13
|
export { sleep } from './asyncs/sleep.js';
|
|
13
14
|
export { TimeoutError, timeout } from './asyncs/timeout.js';
|
|
@@ -56,5 +57,6 @@ export { createFetchWithLogging } from './fetch/createFetchWithLogging.js';
|
|
|
56
57
|
export { dumpRequest } from './fetch/dumpRequest.js';
|
|
57
58
|
export { dumpResponse } from './fetch/dumpResponse.js';
|
|
58
59
|
export { default as ms } from './libs/ms.js';
|
|
59
|
-
export {
|
|
60
|
+
export { Errors } from './errors/Errors.js';
|
|
61
|
+
export { getHttpStatusText, isRetryableHttpStatus } from './http/HttpStatus.js';
|
|
60
62
|
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@wener/utils",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.21",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"description": "Utils for daily use",
|
|
6
6
|
"repository": {
|
|
@@ -15,6 +15,7 @@
|
|
|
15
15
|
"index.ts",
|
|
16
16
|
"lib",
|
|
17
17
|
"server.ts",
|
|
18
|
+
"types.d.ts",
|
|
18
19
|
"src",
|
|
19
20
|
"tsconfig.json"
|
|
20
21
|
],
|
|
@@ -37,12 +38,12 @@
|
|
|
37
38
|
}
|
|
38
39
|
},
|
|
39
40
|
"devDependencies": {
|
|
40
|
-
"@types/lodash": "^4.14.
|
|
41
|
-
"@types/ws": "^8.5.
|
|
42
|
-
"https-proxy-agent": "^7.0.
|
|
41
|
+
"@types/lodash": "^4.14.199",
|
|
42
|
+
"@types/ws": "^8.5.6",
|
|
43
|
+
"https-proxy-agent": "^7.0.2",
|
|
43
44
|
"lodash": "^4.17.21",
|
|
44
45
|
"node-fetch": "^3.3.2",
|
|
45
|
-
"undici": "^5.
|
|
46
|
+
"undici": "^5.25.2"
|
|
46
47
|
},
|
|
47
48
|
"publishConfig": {
|
|
48
49
|
"registry": "https://registry.npmjs.org",
|
|
@@ -58,6 +59,7 @@
|
|
|
58
59
|
"crypto",
|
|
59
60
|
"jsdom",
|
|
60
61
|
"node-fetch",
|
|
62
|
+
"ws",
|
|
61
63
|
"undici"
|
|
62
64
|
]
|
|
63
65
|
},
|
|
@@ -83,7 +85,6 @@
|
|
|
83
85
|
"system": "./dist/system/server.js",
|
|
84
86
|
"import": "./lib/server.js"
|
|
85
87
|
},
|
|
86
|
-
"./src/*": "./src/*",
|
|
87
88
|
"./package.json": "./package.json"
|
|
88
89
|
}
|
|
89
90
|
}
|
|
@@ -1,12 +1,15 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { type MaybePromise } from './MaybePromise';
|
|
2
|
+
import { createLazyPromise, type LazyPromise } from './createLazyPromise';
|
|
3
|
+
|
|
4
|
+
type Val<T> = [val: MaybePromise<T> | undefined, done: boolean, err?: any];
|
|
2
5
|
|
|
3
6
|
export function createAsyncIterator<T>(
|
|
4
|
-
fn: (next: (val: [T | undefined, boolean] | undefined, err?: any) => void) => void,
|
|
5
|
-
) {
|
|
6
|
-
const values: Array<Promise<
|
|
7
|
-
let recv: (val: [T | undefined, boolean] | undefined, err?: any) => void;
|
|
7
|
+
fn: (next: (val: [MaybePromise<T> | undefined, boolean] | undefined, err?: any) => void) => void,
|
|
8
|
+
): AsyncGenerator<T, void, unknown> {
|
|
9
|
+
const values: Array<Promise<Val<T>>> = [];
|
|
10
|
+
let recv: (val: [MaybePromise<T> | undefined, boolean] | undefined, err?: any) => void;
|
|
8
11
|
{
|
|
9
|
-
let next: LazyPromise<
|
|
12
|
+
let next: LazyPromise<Val<T>>;
|
|
10
13
|
values.push((next = createLazyPromise()));
|
|
11
14
|
recv = (val, err) => {
|
|
12
15
|
if (err !== undefined) {
|
|
@@ -23,7 +26,7 @@ export function createAsyncIterator<T>(
|
|
|
23
26
|
fn(recv);
|
|
24
27
|
|
|
25
28
|
return (async function* () {
|
|
26
|
-
let value: T
|
|
29
|
+
let value: Val<T>[0];
|
|
27
30
|
let err: any;
|
|
28
31
|
for (let i = 0, done = false; !done; i++) {
|
|
29
32
|
let result = await values[i];
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { expect, test } from 'vitest';
|
|
2
2
|
import { createLazyPromise } from './createLazyPromise';
|
|
3
|
-
import { sleep } from './sleep';
|
|
4
3
|
|
|
5
4
|
test('basic', async () => {
|
|
6
5
|
const promise = createLazyPromise();
|
|
@@ -18,36 +17,38 @@ test('basic', async () => {
|
|
|
18
17
|
|
|
19
18
|
test('manual resolve skip exec', async () => {
|
|
20
19
|
const promise = createLazyPromise<number>(() => {
|
|
21
|
-
expect.fail();
|
|
20
|
+
expect.fail('should not exec');
|
|
22
21
|
});
|
|
23
22
|
promise.resolve(-1);
|
|
24
23
|
expect(await promise).toBe(-1);
|
|
25
24
|
});
|
|
26
25
|
|
|
27
|
-
test('exec', async () => {
|
|
26
|
+
test('lazy exec resolve by manual', async () => {
|
|
28
27
|
let r = 0;
|
|
29
28
|
const promise = createLazyPromise((resolve) => {
|
|
30
29
|
r++;
|
|
31
30
|
resolve(10);
|
|
32
31
|
});
|
|
33
|
-
await
|
|
32
|
+
await Promise.resolve();
|
|
34
33
|
expect(r).toBe(0);
|
|
35
34
|
expect(await promise).toBe(10);
|
|
36
35
|
expect(r).toBe(1);
|
|
37
36
|
promise.resolve(20);
|
|
38
37
|
expect(await promise).toBe(10);
|
|
38
|
+
expect(r).toBe(1);
|
|
39
39
|
});
|
|
40
40
|
|
|
41
|
-
test('exec
|
|
41
|
+
test('lazy exec resolve by return', async () => {
|
|
42
42
|
let r = 0;
|
|
43
43
|
const promise = createLazyPromise(() => {
|
|
44
44
|
r++;
|
|
45
45
|
return 10;
|
|
46
46
|
});
|
|
47
|
-
await
|
|
47
|
+
await Promise.resolve();
|
|
48
48
|
expect(r).toBe(0);
|
|
49
49
|
void promise.then(() => undefined);
|
|
50
|
-
|
|
50
|
+
await Promise.resolve();
|
|
51
|
+
// already resolved
|
|
51
52
|
expect(r).toBe(1);
|
|
52
53
|
expect(await promise).toBe(10);
|
|
53
54
|
expect(r).toBe(1);
|