refactor(security): harden temp-path handling for inbound media

This commit is contained in:
Peter Steinberger
2026-02-19 14:06:11 +01:00
parent 9f9cd5cbb2
commit ec232a9e2d
10 changed files with 235 additions and 41 deletions

View File

@@ -0,0 +1,20 @@
import { describe, expect, it } from "vitest";
import { normalizeFeishuExternalKey } from "./external-keys.js";
describe("normalizeFeishuExternalKey", () => {
it("accepts a normal feishu key and trims surrounding spaces", () => {
expect(normalizeFeishuExternalKey(" img_v3_01abcDEF123 ")).toBe("img_v3_01abcDEF123");
});
it("rejects traversal and path separator patterns", () => {
expect(normalizeFeishuExternalKey("../etc/passwd")).toBeUndefined();
expect(normalizeFeishuExternalKey("a/../../b")).toBeUndefined();
expect(normalizeFeishuExternalKey("a\\..\\b")).toBeUndefined();
});
it("rejects empty, non-string, and control-char values", () => {
expect(normalizeFeishuExternalKey(" ")).toBeUndefined();
expect(normalizeFeishuExternalKey(123)).toBeUndefined();
expect(normalizeFeishuExternalKey("abc\u0000def")).toBeUndefined();
});
});