@storm-software/linting-tools
Version:
⚡ A package containing various linting tools used to validate syntax, enforce design standards, and format code in a Storm workspace.
185 lines (183 loc) • 7.48 kB
JavaScript
import {
br,
init_node,
init_node_fetch_native_DfbY2q_x,
qn
} from "./chunk-LTEMM6OK.js";
import {
__esm,
init_esm_shims
} from "./chunk-6WF54AHT.js";
// ../../node_modules/.pnpm/node-fetch-native@1.6.7/node_modules/node-fetch-native/dist/chunks/multipart-parser.mjs
function v(u) {
const a = u.match(/\bfilename=("(.*?)"|([^()<>@,;:\\"/[\]?={}\s\t]+))($|;\s)/i);
if (!a) return;
const n = a[2] || a[3] || "";
let r = n.slice(n.lastIndexOf("\\") + 1);
return r = r.replace(/%22/g, '"'), r = r.replace(/&#(\d{4});/g, (d, l) => String.fromCharCode(l)), r;
}
async function Z(u, a) {
if (!/multipart/i.test(a)) throw new TypeError("Failed to fetch");
const n = a.match(/boundary=(?:"([^"]+)"|([^;]+))/i);
if (!n) throw new TypeError("no or bad content-type header, no multipart boundary");
const r = new k(n[1] || n[2]);
let d, l, c, p, e, i;
const A = [], H = new br(), O = E((s) => {
c += f.decode(s, { stream: true });
}, "onPartData"), y = E((s) => {
A.push(s);
}, "appendToFile"), o = E(() => {
const s = new qn(A, i, { type: e });
H.append(p, s);
}, "appendFileToFormData"), L = E(() => {
H.append(p, c);
}, "appendEntryToFormData"), f = new TextDecoder("utf-8");
f.decode(), r.onPartBegin = function() {
r.onPartData = O, r.onPartEnd = L, d = "", l = "", c = "", p = "", e = "", i = null, A.length = 0;
}, r.onHeaderField = function(s) {
d += f.decode(s, { stream: true });
}, r.onHeaderValue = function(s) {
l += f.decode(s, { stream: true });
}, r.onHeaderEnd = function() {
if (l += f.decode(), d = d.toLowerCase(), d === "content-disposition") {
const s = l.match(/\bname=("([^"]*)"|([^()<>@,;:\\"/[\]?={}\s\t]+))/i);
s && (p = s[2] || s[3] || ""), i = v(l), i && (r.onPartData = y, r.onPartEnd = o);
} else d === "content-type" && (e = l);
l = "", d = "";
};
for await (const s of u) r.write(s);
return r.end(), H;
}
var B, E, D, t, w, R, g, N, x, P, C, I, M, $, m, F, k;
var init_multipart_parser = __esm({
"../../node_modules/.pnpm/node-fetch-native@1.6.7/node_modules/node-fetch-native/dist/chunks/multipart-parser.mjs"() {
init_esm_shims();
init_node();
init_node_fetch_native_DfbY2q_x();
B = Object.defineProperty;
E = (u, a) => B(u, "name", { value: a, configurable: true });
D = 0;
t = { START_BOUNDARY: D++, HEADER_FIELD_START: D++, HEADER_FIELD: D++, HEADER_VALUE_START: D++, HEADER_VALUE: D++, HEADER_VALUE_ALMOST_DONE: D++, HEADERS_ALMOST_DONE: D++, PART_DATA_START: D++, PART_DATA: D++, END: D++ };
w = 1;
R = { PART_BOUNDARY: w, LAST_BOUNDARY: w *= 2 };
g = 10;
N = 13;
x = 32;
P = 45;
C = 58;
I = 97;
M = 122;
$ = E((u) => u | 32, "lower");
m = E(() => {
}, "noop");
F = class F2 {
constructor(a) {
this.index = 0, this.flags = 0, this.onHeaderEnd = m, this.onHeaderField = m, this.onHeadersEnd = m, this.onHeaderValue = m, this.onPartBegin = m, this.onPartData = m, this.onPartEnd = m, this.boundaryChars = {}, a = `\r
--` + a;
const n = new Uint8Array(a.length);
for (let r = 0; r < a.length; r++) n[r] = a.charCodeAt(r), this.boundaryChars[n[r]] = true;
this.boundary = n, this.lookbehind = new Uint8Array(this.boundary.length + 8), this.state = t.START_BOUNDARY;
}
write(a) {
let n = 0;
const r = a.length;
let d = this.index, { lookbehind: l, boundary: c, boundaryChars: p, index: e, state: i, flags: A } = this;
const H = this.boundary.length, O = H - 1, y = a.length;
let o, L;
const f = E((h) => {
this[h + "Mark"] = n;
}, "mark"), s = E((h) => {
delete this[h + "Mark"];
}, "clear"), T = E((h, S, _, U) => {
(S === void 0 || S !== _) && this[h](U && U.subarray(S, _));
}, "callback"), b = E((h, S) => {
const _ = h + "Mark";
_ in this && (S ? (T(h, this[_], n, a), delete this[_]) : (T(h, this[_], a.length, a), this[_] = 0));
}, "dataCallback");
for (n = 0; n < r; n++) switch (o = a[n], i) {
case t.START_BOUNDARY:
if (e === c.length - 2) {
if (o === P) A |= R.LAST_BOUNDARY;
else if (o !== N) return;
e++;
break;
} else if (e - 1 === c.length - 2) {
if (A & R.LAST_BOUNDARY && o === P) i = t.END, A = 0;
else if (!(A & R.LAST_BOUNDARY) && o === g) e = 0, T("onPartBegin"), i = t.HEADER_FIELD_START;
else return;
break;
}
o !== c[e + 2] && (e = -2), o === c[e + 2] && e++;
break;
case t.HEADER_FIELD_START:
i = t.HEADER_FIELD, f("onHeaderField"), e = 0;
case t.HEADER_FIELD:
if (o === N) {
s("onHeaderField"), i = t.HEADERS_ALMOST_DONE;
break;
}
if (e++, o === P) break;
if (o === C) {
if (e === 1) return;
b("onHeaderField", true), i = t.HEADER_VALUE_START;
break;
}
if (L = $(o), L < I || L > M) return;
break;
case t.HEADER_VALUE_START:
if (o === x) break;
f("onHeaderValue"), i = t.HEADER_VALUE;
case t.HEADER_VALUE:
o === N && (b("onHeaderValue", true), T("onHeaderEnd"), i = t.HEADER_VALUE_ALMOST_DONE);
break;
case t.HEADER_VALUE_ALMOST_DONE:
if (o !== g) return;
i = t.HEADER_FIELD_START;
break;
case t.HEADERS_ALMOST_DONE:
if (o !== g) return;
T("onHeadersEnd"), i = t.PART_DATA_START;
break;
case t.PART_DATA_START:
i = t.PART_DATA, f("onPartData");
case t.PART_DATA:
if (d = e, e === 0) {
for (n += O; n < y && !(a[n] in p); ) n += H;
n -= O, o = a[n];
}
if (e < c.length) c[e] === o ? (e === 0 && b("onPartData", true), e++) : e = 0;
else if (e === c.length) e++, o === N ? A |= R.PART_BOUNDARY : o === P ? A |= R.LAST_BOUNDARY : e = 0;
else if (e - 1 === c.length) if (A & R.PART_BOUNDARY) {
if (e = 0, o === g) {
A &= ~R.PART_BOUNDARY, T("onPartEnd"), T("onPartBegin"), i = t.HEADER_FIELD_START;
break;
}
} else A & R.LAST_BOUNDARY && o === P ? (T("onPartEnd"), i = t.END, A = 0) : e = 0;
if (e > 0) l[e - 1] = o;
else if (d > 0) {
const h = new Uint8Array(l.buffer, l.byteOffset, l.byteLength);
T("onPartData", 0, d, h), d = 0, f("onPartData"), n--;
}
break;
case t.END:
break;
default:
throw new Error(`Unexpected state entered: ${i}`);
}
b("onHeaderField"), b("onHeaderValue"), b("onPartData"), this.index = e, this.state = i, this.flags = A;
}
end() {
if (this.state === t.HEADER_FIELD_START && this.index === 0 || this.state === t.PART_DATA && this.index === this.boundary.length) this.onPartEnd();
else if (this.state !== t.END) throw new Error("MultipartParser.end(): stream ended unexpectedly");
}
};
E(F, "MultipartParser");
k = F;
E(v, "_fileName");
E(Z, "toFormData");
}
});
init_multipart_parser();
export {
Z as toFormData
};