Commit 5b9d003
authored
Add
closes
https://linear.app/ghost/issue/NY-1083/add-an-expire-at-timestamp-to-future-firestore-keys
## Summary
- Adds an `expires_at` field to new Firestore salt documents, computed
as the key's date + 2 days at midnight UTC
- This is a stepping stone toward using Firestore's native TTL deletion,
which will eventually replace the manual cleanup scheduler added in #582
- `expire_at` is a Firestore-only storage concern — not added to
`SaltRecord` or `ISaltStore`
## Changes
- **`FirestoreSaltStore.ts`**: Added private `getExpireAt(key,
fallbackDate)` helper that parses the date from the key format
`salt:{date}:{siteUuid}` and returns that date + 2 days. Falls back to
`fallbackDate + 2 days` for unexpected key formats. Modified `set()` to
include `expires_at` when writing documents.
- **`FirestoreSaltStore.test.ts`**: Added 6 integration tests covering
`set()`, `getOrCreate()`, fallback behavior, and verifying
`get()`/`getAll()` don't leak `expires_at` into `SaltRecord`.
## Test plan
- [x] `expires_at` written correctly via `set()` (key date + 2 days)
- [x] `expires_at` written correctly via `getOrCreate()`
- [x] Fallback to `created_at + 2 days` for unexpected key formats
- [x] `get()` does not include `expires_at` in returned `SaltRecord`
- [x] `getAll()` does not include `expires_at` in returned records
- [x] All 414 unit tests pass
- [x] All 108 integration tests pass
- [x] Lint cleanexpires_at timestamp to Firestore salt documents (#602)1 parent dd7d3c5 commit 5b9d003
5 files changed
Lines changed: 109 additions & 6 deletions
File tree
- src/services
- salt-store
- user-signature
- test/integration/services/salt-store
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
25 | 25 | | |
26 | 26 | | |
27 | 27 | | |
| 28 | + | |
28 | 29 | | |
29 | 30 | | |
30 | 31 | | |
| |||
67 | 68 | | |
68 | 69 | | |
69 | 70 | | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
70 | 96 | | |
71 | 97 | | |
72 | 98 | | |
| |||
167 | 193 | | |
168 | 194 | | |
169 | 195 | | |
170 | | - | |
171 | | - | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
172 | 201 | | |
173 | 202 | | |
174 | 203 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
1 | 3 | | |
2 | 4 | | |
3 | 5 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | | - | |
| 1 | + | |
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | | - | |
| 1 | + | |
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| |||
74 | 74 | | |
75 | 75 | | |
76 | 76 | | |
77 | | - | |
| 77 | + | |
78 | 78 | | |
79 | | - | |
| 79 | + | |
80 | 80 | | |
81 | 81 | | |
82 | 82 | | |
| |||
Lines changed: 72 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
511 | 511 | | |
512 | 512 | | |
513 | 513 | | |
| 514 | + | |
| 515 | + | |
| 516 | + | |
| 517 | + | |
| 518 | + | |
| 519 | + | |
| 520 | + | |
| 521 | + | |
| 522 | + | |
| 523 | + | |
| 524 | + | |
| 525 | + | |
| 526 | + | |
| 527 | + | |
| 528 | + | |
| 529 | + | |
| 530 | + | |
| 531 | + | |
| 532 | + | |
| 533 | + | |
| 534 | + | |
| 535 | + | |
| 536 | + | |
| 537 | + | |
| 538 | + | |
| 539 | + | |
| 540 | + | |
| 541 | + | |
| 542 | + | |
| 543 | + | |
| 544 | + | |
| 545 | + | |
| 546 | + | |
| 547 | + | |
| 548 | + | |
| 549 | + | |
| 550 | + | |
| 551 | + | |
| 552 | + | |
| 553 | + | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
| 557 | + | |
| 558 | + | |
| 559 | + | |
| 560 | + | |
| 561 | + | |
| 562 | + | |
| 563 | + | |
| 564 | + | |
| 565 | + | |
| 566 | + | |
| 567 | + | |
| 568 | + | |
| 569 | + | |
| 570 | + | |
| 571 | + | |
| 572 | + | |
| 573 | + | |
| 574 | + | |
| 575 | + | |
| 576 | + | |
| 577 | + | |
| 578 | + | |
| 579 | + | |
| 580 | + | |
| 581 | + | |
| 582 | + | |
| 583 | + | |
| 584 | + | |
| 585 | + | |
514 | 586 | | |
0 commit comments