mirror of
https://github.com/juherr/kill-the-news.git
synced 2026-06-20 22:03:48 +00:00
1a4a479190
Separate the two feed identities so the public read URL never reveals the inbound address and vice-versa: - FeedId becomes an opaque high-entropy token (read id + KV key); MailboxId (noun.noun.NN) owns the inbound address and the untrusted-input boundary via MailboxId.parse. They map only through the inbound:<mailbox> secondary index, resolved solely at reception. - inbound index lifecycle is owned by FeedRepository: written by save/saveConfig, dropped by removeFromList(Bulk) — symmetric, never mirrored by hand (removes the manual delete in feed-service + the cron loop, and a silent empty-catch). - Feed.mailboxId exposes a MailboxId VO (symmetry with Feed.id); the mailbox@domain shape lives on MailboxId.emailAddress(domain). - Distinguish mailbox_unknown (no feed claims the address) from feed_not_found (dangling index) for observability; both forwardable, both 404. - Drop the redundant EmailParser.extractMailbox pass-through so MailboxId.parse is the single parse boundary. Docs (README/INSTALL/CLAUDE.md/landing) and tests updated; 439 tests green, tsc clean, build dry-run OK. Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
28 lines
792 B
TypeScript
28 lines
792 B
TypeScript
import { describe, it, expect } from "vitest";
|
|
import { FeedId } from "./feed-id";
|
|
|
|
describe("FeedId.generate", () => {
|
|
it("produces an opaque base64url token", () => {
|
|
for (let i = 0; i < 50; i++) {
|
|
expect(FeedId.generate().value).toMatch(/^[A-Za-z0-9_-]{22}$/);
|
|
}
|
|
});
|
|
|
|
it("is unguessable: 50 ids are all distinct", () => {
|
|
const ids = new Set(
|
|
Array.from({ length: 50 }, () => FeedId.generate().value),
|
|
);
|
|
expect(ids.size).toBe(50);
|
|
});
|
|
|
|
it("does not produce the legacy noun.noun.NN format", () => {
|
|
expect(FeedId.generate().value).not.toMatch(/^[a-z]+\.[a-z]+\.\d{2}$/);
|
|
});
|
|
});
|
|
|
|
describe("FeedId.unchecked", () => {
|
|
it("wraps a value without validation", () => {
|
|
expect(FeedId.unchecked("anything").value).toBe("anything");
|
|
});
|
|
});
|