diff options
| author | Mohamed Bassem <me@mbassem.com> | 2024-11-03 17:09:47 +0000 |
|---|---|---|
| committer | Mohamed Bassem <me@mbassem.com> | 2024-11-03 17:09:47 +0000 |
| commit | cf1a25131fd45ab7c9a72b837be525c24457cd8b (patch) | |
| tree | cb8b3d4a57a4ce06e500e4c7ceea43924d64a5d4 /packages/shared | |
| parent | 2efc7c8c01866fafad5322fb8783d94821e32ff1 (diff) | |
| download | karakeep-cf1a25131fd45ab7c9a72b837be525c24457cd8b.tar.zst | |
feature: Add support for subscribing to RSS feeds. Fixes #202
Diffstat (limited to 'packages/shared')
| -rw-r--r-- | packages/shared/queues.ts | 17 | ||||
| -rw-r--r-- | packages/shared/types/feeds.ts | 27 |
2 files changed, 44 insertions, 0 deletions
diff --git a/packages/shared/queues.ts b/packages/shared/queues.ts index 6189a633..7baae535 100644 --- a/packages/shared/queues.ts +++ b/packages/shared/queues.ts @@ -116,3 +116,20 @@ export async function triggerVideoWorker(bookmarkId: string, url: string) { url, }); } + +// Feed Worker +export const zFeedRequestSchema = z.object({ + feedId: z.string(), +}); +export type ZFeedRequestSchema = z.infer<typeof zFeedRequestSchema>; + +export const FeedQueue = new SqliteQueue<ZFeedRequestSchema>( + "feed_queue", + queueDB, + { + defaultJobArgs: { + // One retry is enough for the feed queue given that it's periodic + numRetries: 1, + }, + }, +); diff --git a/packages/shared/types/feeds.ts b/packages/shared/types/feeds.ts new file mode 100644 index 00000000..3771624b --- /dev/null +++ b/packages/shared/types/feeds.ts @@ -0,0 +1,27 @@ +import { z } from "zod"; + +const MAX_FEED_URL_LENGTH = 500; +const MAX_FEED_NAME_LENGTH = 100; + +export const zAppliesToEnumSchema = z.enum(["all", "text", "images"]); + +export const zFeedSchema = z.object({ + id: z.string(), + name: z.string().min(1).max(MAX_FEED_NAME_LENGTH), + url: z.string().url(), + lastFetchedStatus: z.enum(["success", "failure", "pending"]).nullable(), + lastFetchedAt: z.date().nullable(), +}); + +export type ZFeed = z.infer<typeof zFeedSchema>; + +export const zNewFeedSchema = z.object({ + name: z.string().min(1).max(MAX_FEED_NAME_LENGTH), + url: z.string().max(MAX_FEED_URL_LENGTH).url(), +}); + +export const zUpdateFeedSchema = z.object({ + feedId: z.string(), + name: z.string().min(1).max(MAX_FEED_NAME_LENGTH), + url: z.string().max(MAX_FEED_URL_LENGTH).url(), +}); |
