@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.
180 lines (172 loc) • 8.54 kB
JavaScript
;Object.defineProperty(exports, "__esModule", {value: true});
var _chunkHT77GUTScjs = require('./chunk-HT77GUTS.cjs');
var _chunkUB72K2YDcjs = require('./chunk-UB72K2YD.cjs');
// ../../node_modules/.pnpm/node-fetch-native@1.6.7/node_modules/node-fetch-native/dist/chunks/multipart-parser.cjs
var require_multipart_parser = _chunkUB72K2YDcjs.__commonJS.call(void 0, {
"../../node_modules/.pnpm/node-fetch-native@1.6.7/node_modules/node-fetch-native/dist/chunks/multipart-parser.cjs"(exports) {
_chunkUB72K2YDcjs.init_cjs_shims.call(void 0, );
var y = Object.defineProperty;
var c = (R, o) => y(R, "name", { value: o, configurable: true });
var node = _chunkHT77GUTScjs.require_node.call(void 0, );
_chunkUB72K2YDcjs.__require.call(void 0, "http"), _chunkUB72K2YDcjs.__require.call(void 0, "https"), _chunkUB72K2YDcjs.__require.call(void 0, "zlib"), _chunkUB72K2YDcjs.__require.call(void 0, "stream"), _chunkUB72K2YDcjs.__require.call(void 0, "buffer"), _chunkUB72K2YDcjs.__require.call(void 0, "util"), _chunkHT77GUTScjs.require_node_fetch_native_DhEqb06g.call(void 0, ), _chunkUB72K2YDcjs.__require.call(void 0, "url"), _chunkUB72K2YDcjs.__require.call(void 0, "net"), _chunkUB72K2YDcjs.__require.call(void 0, "fs"), _chunkUB72K2YDcjs.__require.call(void 0, "path");
var s = 0;
var S = { START_BOUNDARY: s++, HEADER_FIELD_START: s++, HEADER_FIELD: s++, HEADER_VALUE_START: s++, HEADER_VALUE: s++, HEADER_VALUE_ALMOST_DONE: s++, HEADERS_ALMOST_DONE: s++, PART_DATA_START: s++, PART_DATA: s++, END: s++ };
var f = 1;
var F = { PART_BOUNDARY: f, LAST_BOUNDARY: f *= 2 };
var LF = 10;
var CR = 13;
var SPACE = 32;
var HYPHEN = 45;
var COLON = 58;
var A = 97;
var Z = 122;
var lower = c((R) => R | 32, "lower");
var noop = c(() => {
}, "noop");
var g = class g {
constructor(o) {
this.index = 0, this.flags = 0, this.onHeaderEnd = noop, this.onHeaderField = noop, this.onHeadersEnd = noop, this.onHeaderValue = noop, this.onPartBegin = noop, this.onPartData = noop, this.onPartEnd = noop, this.boundaryChars = {}, o = `\r
--` + o;
const t = new Uint8Array(o.length);
for (let n = 0; n < o.length; n++) t[n] = o.charCodeAt(n), this.boundaryChars[t[n]] = true;
this.boundary = t, this.lookbehind = new Uint8Array(this.boundary.length + 8), this.state = S.START_BOUNDARY;
}
write(o) {
let t = 0;
const n = o.length;
let E = this.index, { lookbehind: l, boundary: h, boundaryChars: H, index: e, state: a, flags: d } = this;
const b = this.boundary.length, m = b - 1, O = o.length;
let r, P;
const u = c((D) => {
this[D + "Mark"] = t;
}, "mark"), i = c((D) => {
delete this[D + "Mark"];
}, "clear"), T = c((D, p, _, N) => {
(p === void 0 || p !== _) && this[D](N && N.subarray(p, _));
}, "callback"), L = c((D, p) => {
const _ = D + "Mark";
_ in this && (p ? (T(D, this[_], t, o), delete this[_]) : (T(D, this[_], o.length, o), this[_] = 0));
}, "dataCallback");
for (t = 0; t < n; t++) switch (r = o[t], a) {
case S.START_BOUNDARY:
if (e === h.length - 2) {
if (r === HYPHEN) d |= F.LAST_BOUNDARY;
else if (r !== CR) return;
e++;
break;
} else if (e - 1 === h.length - 2) {
if (d & F.LAST_BOUNDARY && r === HYPHEN) a = S.END, d = 0;
else if (!(d & F.LAST_BOUNDARY) && r === LF) e = 0, T("onPartBegin"), a = S.HEADER_FIELD_START;
else return;
break;
}
r !== h[e + 2] && (e = -2), r === h[e + 2] && e++;
break;
case S.HEADER_FIELD_START:
a = S.HEADER_FIELD, u("onHeaderField"), e = 0;
case S.HEADER_FIELD:
if (r === CR) {
i("onHeaderField"), a = S.HEADERS_ALMOST_DONE;
break;
}
if (e++, r === HYPHEN) break;
if (r === COLON) {
if (e === 1) return;
L("onHeaderField", true), a = S.HEADER_VALUE_START;
break;
}
if (P = lower(r), P < A || P > Z) return;
break;
case S.HEADER_VALUE_START:
if (r === SPACE) break;
u("onHeaderValue"), a = S.HEADER_VALUE;
case S.HEADER_VALUE:
r === CR && (L("onHeaderValue", true), T("onHeaderEnd"), a = S.HEADER_VALUE_ALMOST_DONE);
break;
case S.HEADER_VALUE_ALMOST_DONE:
if (r !== LF) return;
a = S.HEADER_FIELD_START;
break;
case S.HEADERS_ALMOST_DONE:
if (r !== LF) return;
T("onHeadersEnd"), a = S.PART_DATA_START;
break;
case S.PART_DATA_START:
a = S.PART_DATA, u("onPartData");
case S.PART_DATA:
if (E = e, e === 0) {
for (t += m; t < O && !(o[t] in H); ) t += b;
t -= m, r = o[t];
}
if (e < h.length) h[e] === r ? (e === 0 && L("onPartData", true), e++) : e = 0;
else if (e === h.length) e++, r === CR ? d |= F.PART_BOUNDARY : r === HYPHEN ? d |= F.LAST_BOUNDARY : e = 0;
else if (e - 1 === h.length) if (d & F.PART_BOUNDARY) {
if (e = 0, r === LF) {
d &= ~F.PART_BOUNDARY, T("onPartEnd"), T("onPartBegin"), a = S.HEADER_FIELD_START;
break;
}
} else d & F.LAST_BOUNDARY && r === HYPHEN ? (T("onPartEnd"), a = S.END, d = 0) : e = 0;
if (e > 0) l[e - 1] = r;
else if (E > 0) {
const D = new Uint8Array(l.buffer, l.byteOffset, l.byteLength);
T("onPartData", 0, E, D), E = 0, u("onPartData"), t--;
}
break;
case S.END:
break;
default:
throw new Error(`Unexpected state entered: ${a}`);
}
L("onHeaderField"), L("onHeaderValue"), L("onPartData"), this.index = e, this.state = a, this.flags = d;
}
end() {
if (this.state === S.HEADER_FIELD_START && this.index === 0 || this.state === S.PART_DATA && this.index === this.boundary.length) this.onPartEnd();
else if (this.state !== S.END) throw new Error("MultipartParser.end(): stream ended unexpectedly");
}
};
c(g, "MultipartParser");
var MultipartParser = g;
function _fileName(R) {
const o = R.match(/\bfilename=("(.*?)"|([^()<>@,;:\\"/[\]?={}\s\t]+))($|;\s)/i);
if (!o) return;
const t = o[2] || o[3] || "";
let n = t.slice(t.lastIndexOf("\\") + 1);
return n = n.replace(/%22/g, '"'), n = n.replace(/&#(\d{4});/g, (E, l) => String.fromCharCode(l)), n;
}
c(_fileName, "_fileName");
async function toFormData(R, o) {
if (!/multipart/i.test(o)) throw new TypeError("Failed to fetch");
const t = o.match(/boundary=(?:"([^"]+)"|([^;]+))/i);
if (!t) throw new TypeError("no or bad content-type header, no multipart boundary");
const n = new MultipartParser(t[1] || t[2]);
let E, l, h, H, e, a;
const d = [], b = new node.FormData(), m = c((i) => {
h += u.decode(i, { stream: true });
}, "onPartData"), O = c((i) => {
d.push(i);
}, "appendToFile"), r = c(() => {
const i = new node.File(d, a, { type: e });
b.append(H, i);
}, "appendFileToFormData"), P = c(() => {
b.append(H, h);
}, "appendEntryToFormData"), u = new TextDecoder("utf-8");
u.decode(), n.onPartBegin = function() {
n.onPartData = m, n.onPartEnd = P, E = "", l = "", h = "", H = "", e = "", a = null, d.length = 0;
}, n.onHeaderField = function(i) {
E += u.decode(i, { stream: true });
}, n.onHeaderValue = function(i) {
l += u.decode(i, { stream: true });
}, n.onHeaderEnd = function() {
if (l += u.decode(), E = E.toLowerCase(), E === "content-disposition") {
const i = l.match(/\bname=("([^"]*)"|([^()<>@,;:\\"/[\]?={}\s\t]+))/i);
i && (H = i[2] || i[3] || ""), a = _fileName(l), a && (n.onPartData = O, n.onPartEnd = r);
} else E === "content-type" && (e = l);
l = "", E = "";
};
for await (const i of R) n.write(i);
return n.end(), b;
}
c(toFormData, "toFormData"), exports.toFormData = toFormData;
}
});
exports. default = require_multipart_parser();