mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-05 13:40:20 +00:00
fix(security): harden hook and device token auth
This commit is contained in:
22
src/security/secret-equal.test.ts
Normal file
22
src/security/secret-equal.test.ts
Normal file
@@ -0,0 +1,22 @@
|
||||
import { describe, expect, it } from "vitest";
|
||||
import { safeEqualSecret } from "./secret-equal.js";
|
||||
|
||||
describe("safeEqualSecret", () => {
|
||||
it("matches identical secrets", () => {
|
||||
expect(safeEqualSecret("secret-token", "secret-token")).toBe(true);
|
||||
});
|
||||
|
||||
it("rejects mismatched secrets", () => {
|
||||
expect(safeEqualSecret("secret-token", "secret-tokEn")).toBe(false);
|
||||
});
|
||||
|
||||
it("rejects different-length secrets", () => {
|
||||
expect(safeEqualSecret("short", "much-longer")).toBe(false);
|
||||
});
|
||||
|
||||
it("rejects missing values", () => {
|
||||
expect(safeEqualSecret(undefined, "secret")).toBe(false);
|
||||
expect(safeEqualSecret("secret", undefined)).toBe(false);
|
||||
expect(safeEqualSecret(null, "secret")).toBe(false);
|
||||
});
|
||||
});
|
||||
16
src/security/secret-equal.ts
Normal file
16
src/security/secret-equal.ts
Normal file
@@ -0,0 +1,16 @@
|
||||
import { timingSafeEqual } from "node:crypto";
|
||||
|
||||
export function safeEqualSecret(
|
||||
provided: string | undefined | null,
|
||||
expected: string | undefined | null,
|
||||
): boolean {
|
||||
if (typeof provided !== "string" || typeof expected !== "string") {
|
||||
return false;
|
||||
}
|
||||
const providedBuffer = Buffer.from(provided);
|
||||
const expectedBuffer = Buffer.from(expected);
|
||||
if (providedBuffer.length !== expectedBuffer.length) {
|
||||
return false;
|
||||
}
|
||||
return timingSafeEqual(providedBuffer, expectedBuffer);
|
||||
}
|
||||
Reference in New Issue
Block a user