@nsnanocat/util 1.8.7 → 1.8.8

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 (2) hide show
  1. package/package.json +1 -1
  2. package/polyfill/fetch.mjs +36 -29
package/package.json CHANGED
@@ -32,5 +32,5 @@
32
32
  "devDependencies": {
33
33
  "typescript": "^5.6.3"
34
34
  },
35
- "version": "1.8.7"
35
+ "version": "1.8.8"
36
36
  }
@@ -159,37 +159,44 @@ export async function fetch(resource, options = {}) {
159
159
  }),
160
160
  ]);
161
161
  case "Node.js": {
162
- const iconv = require("iconv-lite");
163
- const got = globalThis.got ? globalThis.got : require("got");
164
- const cktough = globalThis.cktough ? globalThis.cktough : require("tough-cookie");
165
- const ckjar = globalThis.ckjar ? globalThis.ckjar : new cktough.CookieJar();
166
- if (resource) {
167
- resource.headers = resource.headers ? resource.headers : {};
168
- if (undefined === resource.headers.Cookie && undefined === resource.cookieJar) resource.cookieJar = ckjar;
169
- }
162
+ const nodeFetch = globalThis.fetch ? globalThis.fetch : require("node-fetch");
163
+ const fetchCookie = globalThis.fetchCookie ? globalThis.fetchCookie : require("fetch-cookie").default;
164
+ const fetch = fetchCookie(nodeFetch);
165
+ // 转换请求参数
166
+ resource.timeout = resource.timeout * 1000;
167
+ resource.redirect = resource.redirection ? "follow" : "manual";
170
168
  const { url, ...options } = resource;
171
- return await got[method](url, options)
172
- .on("redirect", (response, nextOpts) => {
173
- try {
174
- if (response.headers["set-cookie"]) {
175
- const ck = response.headers["set-cookie"].map(cktough.Cookie.parse).toString();
176
- if (ck) ckjar.setCookieSync(ck, null);
177
- nextOpts.cookieJar = ckjar;
169
+ // 发送请求
170
+ return Promise.race([
171
+ await fetch(url, options)
172
+ .then(async response => {
173
+ const bodyBytes = await response.arrayBuffer();
174
+ let headers;
175
+ try {
176
+ headers = response.headers.raw();
177
+ } catch {
178
+ headers = Array.from(response.headers.entries()).reduce((acc, [key, value]) => {
179
+ acc[key] = acc[key] ? [...acc[key], value] : [value];
180
+ return acc;
181
+ }, {});
178
182
  }
179
- } catch (e) {
180
- Console.error(e);
181
- }
182
- // ckjar.setCookieSync(response.headers["set-cookie"].map(Cookie.parse).toString())
183
- })
184
- .then(
185
- response => {
186
- response.statusCode = response.status;
187
- response.body = iconv.decode(response.rawBody, "utf-8");
188
- response.bodyBytes = response.rawBody;
189
- return response;
190
- },
191
- error => Promise.reject(error.message),
192
- );
183
+ return {
184
+ ok: response.ok ?? /^2\d\d$/.test(response.status),
185
+ status: response.status,
186
+ statusCode: response.status,
187
+ statusText: response.statusText,
188
+ body: bodyBytes.toString("utf-8"),
189
+ bodyBytes: bodyBytes,
190
+ headers: Object.fromEntries(Object.entries(headers).map(([key, value]) => [key, key.toLowerCase() !== "set-cookie" ? value.toString() : value])),
191
+ };
192
+ })
193
+ .catch(error => Promise.reject(error.message)),
194
+ new Promise((resolve, reject) => {
195
+ setTimeout(() => {
196
+ reject(new Error(`${Function.name}: 请求超时, 请检查网络后重试`));
197
+ }, resource.timeout);
198
+ }),
199
+ ]);
193
200
  }
194
201
  }
195
202
  }