feat(domain): pendingConfirmation flag on the Feed aggregate

This commit is contained in:
Julien Herr
2026-05-25 08:58:26 +02:00
parent d561b6b81f
commit 79bb4902b9
3 changed files with 103 additions and 0 deletions
+19
View File
@@ -155,6 +155,11 @@ export class Feed {
return this._metadata.iconDomain;
}
/** True while at least one unactioned confirmation email is present. */
get pendingConfirmation(): boolean {
return this._metadata.pendingConfirmation ?? false;
}
allowedSenders(): string[] {
return [...this._state.allowedSenders];
}
@@ -258,6 +263,10 @@ export class Feed {
};
}
if (entry.confirmation) {
this._metadata.pendingConfirmation = true;
}
this._events.push({
type: "EmailIngested",
feedId: this.id,
@@ -295,9 +304,19 @@ export class Feed {
(target.has(entry.key) ? removed : kept).push(entry);
}
this._metadata.emails = kept;
// Lower-only: clear when no confirmation email remains. Never re-raise here,
// so an admin "dismiss" survives deletion of unrelated emails.
if (!kept.some((e) => e.confirmation)) {
this._metadata.pendingConfirmation = false;
}
return { removed };
}
/** Mark the pending confirmation as handled — "stop reminding me". */
dismissConfirmation(): void {
this._metadata.pendingConfirmation = false;
}
/**
* The single edit path. Apply the patch (only the fields it carries) and
* recompute expiry when the application supplies a `Lifetime` — an absent