|
| 1 | +import { detectOrigin } from "../src/utils/detect-origin" |
| 2 | + |
| 3 | +// An explicitly configured `NEXTAUTH_URL` should always take precedence over the |
| 4 | +// auto-detected forwarded host, including when trusted-host mode is enabled via |
| 5 | +// `AUTH_TRUST_HOST` or a platform default such as `VERCEL`. |
| 6 | + |
| 7 | +const FORWARDED_HOST = "forwarded.example.test" |
| 8 | +const CONFIGURED_URL = "https://app.example.test" |
| 9 | + |
| 10 | +const ENV_KEYS = ["NEXTAUTH_URL", "AUTH_TRUST_HOST", "VERCEL"] as const |
| 11 | + |
| 12 | +describe("detectOrigin", () => { |
| 13 | + const saved: Record<string, string | undefined> = {} |
| 14 | + |
| 15 | + beforeEach(() => { |
| 16 | + for (const key of ENV_KEYS) { |
| 17 | + saved[key] = process.env[key] |
| 18 | + delete process.env[key] |
| 19 | + } |
| 20 | + }) |
| 21 | + |
| 22 | + afterEach(() => { |
| 23 | + for (const key of ENV_KEYS) { |
| 24 | + if (saved[key] === undefined) delete process.env[key] |
| 25 | + else process.env[key] = saved[key] |
| 26 | + } |
| 27 | + }) |
| 28 | + |
| 29 | + it("prefers NEXTAUTH_URL over the forwarded host when AUTH_TRUST_HOST is set", () => { |
| 30 | + process.env.AUTH_TRUST_HOST = "true" |
| 31 | + process.env.NEXTAUTH_URL = CONFIGURED_URL |
| 32 | + |
| 33 | + expect(detectOrigin(FORWARDED_HOST, "https")).toBe(CONFIGURED_URL) |
| 34 | + }) |
| 35 | + |
| 36 | + it("prefers NEXTAUTH_URL over the forwarded host on Vercel", () => { |
| 37 | + process.env.VERCEL = "1" |
| 38 | + process.env.NEXTAUTH_URL = CONFIGURED_URL |
| 39 | + |
| 40 | + expect(detectOrigin(FORWARDED_HOST, "https")).toBe(CONFIGURED_URL) |
| 41 | + }) |
| 42 | + |
| 43 | + it("derives the origin from the forwarded host in trusted-host mode when NEXTAUTH_URL is not set", () => { |
| 44 | + process.env.AUTH_TRUST_HOST = "true" |
| 45 | + |
| 46 | + expect(detectOrigin("app.example.test", "https")).toBe( |
| 47 | + "https://app.example.test" |
| 48 | + ) |
| 49 | + }) |
| 50 | + |
| 51 | + it("returns NEXTAUTH_URL when not in trusted-host mode", () => { |
| 52 | + process.env.NEXTAUTH_URL = CONFIGURED_URL |
| 53 | + |
| 54 | + expect(detectOrigin(FORWARDED_HOST, "https")).toBe(CONFIGURED_URL) |
| 55 | + }) |
| 56 | + |
| 57 | + it("returns undefined when neither trusted-host mode nor NEXTAUTH_URL is configured", () => { |
| 58 | + expect(detectOrigin(FORWARDED_HOST, "https")).toBeUndefined() |
| 59 | + }) |
| 60 | +}) |
0 commit comments