aboutsummaryrefslogtreecommitdiffstats
path: root/apps (follow)
Commit message (Collapse)AuthorAgeFilesLines
* feat(mobile): more native screensMohamed Bassem44 hours20-409/+575
|
* feat(ai): Support restricting AI tags to a subset of existing tags (#2444)Mohamed Bassem44 hours5-9/+251
| | | | | * feat(ai): Support restricting AI tags to a subset of existing tags Co-authored-by: Claude <noreply@anthropic.com>
* feat(mcp): Support custom configurable HTTP headers (#2436)Chen Ye44 hours2-3/+19
| | | | | | | | | * feat(mcp): Support custom configurable HTTP headers * docs(mcp): Add KARAKEEP_CUSTOM_HEADERS documentation * fix(mcp): Prioritize default headers and safely parse custom headers * docs(mcp): Correct capitalization of Cloudflare headers
* feat: Added Import for Instapaper (#2434)Daniel Wieser44 hours2-0/+20
| | | | | * Added Instapaper import * Fixes #1444 Added Instapaper import support
* feat: Add drag-and-drop support for bookmarks to lists (#2469)Mohamed Bassem45 hours5-111/+265
| | | | | * feat: add drag and drop bookmark cards into sidebar lists Co-authored-by: Claude <noreply@anthropic.com>
* feat(crawler): Split bookmark metadata updates into two phases for faster ↵Mohamed Bassem47 hours1-22/+32
| | | | | | | | | | | | | | | | | | | | | | | | | | | feedback (#2467) * feat(crawler): write metadata to DB early for faster user feedback Split the single DB transaction in crawlAndParseUrl into two phases: - Phase 1: Write metadata (title, description, favicon, author, etc.) immediately after extraction, before downloading assets - Phase 2: Write content and asset references after all assets are stored (banner image, screenshot, pdf, html content) This gives users near-instant feedback with bookmark metadata while the slower asset downloads and uploads happen in the background. https://claude.ai/code/session_013vKTXDcb5CEve3WMszQJmZ * fix(crawler): move crawledAt to phase 2 DB write crawledAt should only be set once all assets are fully stored, not during the early metadata write. https://claude.ai/code/session_013vKTXDcb5CEve3WMszQJmZ --------- Co-authored-by: Claude <noreply@anthropic.com>
* feat: add source filter to query language (#2465)Mohamed Bassem2 days3-1/+70
| | | | | | | | | | | * feat: add source filter to query language Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * autocomplete source --------- Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
* fix: treat bookmark not found as a no-op in rule engine instead of a failure ↵Mohamed Bassem2 days1-2/+9
| | | | | | | | | | | (#2464) When a bookmark is deleted before the rule engine worker processes its event, the worker would throw an error, triggering failure metrics, error logging, and retries. This changes both the worker and RuleEngine.forBookmark to gracefully skip processing with an info log instead. Co-authored-by: Claude <noreply@anthropic.com>
* fix(extension): dont store tab title when saving links or images. fixes #2462Mohamed Bassem3 days1-1/+5
|
* feat: Add separate queue for import link crawling (#2452)Mohamed Bassem3 days3-35/+51
| | | | | | | * feat: add separate queue for import link crawling --------- Co-authored-by: Claude <noreply@anthropic.com>
* feat(metrics): add prometheus metric for bookmark crawl latency (#2461)Mohamed Bassem3 days3-2/+28
| | | | | | | | | | Track the time from bookmark creation to crawl completion as a histogram (karakeep_bookmark_crawl_latency_seconds). This measures the end-to-end latency users experience when adding bookmarks via extension, web, etc. Excludes recrawls (crawledAt already set) and imports (low priority jobs). https://claude.ai/code/session_019jTGGXGWzK9C5aTznQhdgz Co-authored-by: Claude <noreply@anthropic.com>
* feat(import): new import details page (#2451)Mohamed Bassem6 days5-2/+666
| | | | | | | * feat(import): new import details page * fix typecheck * review comments
* fix(ci): fix missing format errorMohamed Bassem6 days1-1/+1
|
* feat: add extra instrumentation in the otel traces (#2453)Mohamed Bassem6 days4-26/+178
|
* fix(import): sanitize error messages to prevent backend detail leakage (#2455)Mohamed Bassem6 days1-1/+26
| | | | | | | | | | | | | | | | | | The catch block in processOneBookmark was storing raw error strings via String(error) in the resultReason field, which is exposed to users through the getImportSessionResults tRPC route. This could leak internal details like database constraint errors, file paths, stack traces, or connection strings. Replace String(error) with getSafeErrorMessage() that only allows through: - TRPCError client errors (designed to be user-facing) - Known safe validation messages from the import worker - A generic fallback for all other errors The full error is still logged server-side for debugging. https://claude.ai/code/session_01F1NHE9dqio5LJ177vmSCvt Co-authored-by: Claude <noreply@anthropic.com>
* fix(import): skip counting pending items for paushed sessionsMohamedBassem6 days1-7/+16
|
* fix(import): register improt metrics to the prom registryMohamed Bassem6 days2-1/+9
|
* fix(import): propagate crawling/tagging failure to import statusMohamed Bassem6 days1-18/+50
|
* fix: extra logging for the import workerMohamed Bassem6 days1-13/+39
|
* fix: backfill old sessions and do queue backpressure (#2449)Mohamed Bassem6 days1-21/+54
| | | | | * fix: backfill old sessions and do queue backpressure * fix typo
* feat: Import workflow v3 (#2378)Mohamed Bassem6 days6-106/+722
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * feat: import workflow v3 * batch stage * revert migration * cleanups * pr comments * move to models * add allowed workers * e2e tests * import list ids * add missing indicies * merge test * more fixes * add resume/pause to UI * fix ui states * fix tests * simplify progress tracking * remove backpressure * fix list imports * fix race on claiming bookmarks * remove the codex file
* feat: Add LLM-based OCR as alternative to Tesseract (#2442)Mohamed Bassem9 days1-9/+58
| | | | | | | | | | | | | | | | | | | | | | | | | * feat(ocr): add LLM-based OCR support alongside Tesseract Add support for using configured LLM inference providers (OpenAI or Ollama) for OCR text extraction from images as an alternative to Tesseract. Changes: - Add OCR_USE_LLM environment variable flag (default: false) - Add buildOCRPrompt function for LLM-based text extraction - Add readImageTextWithLLM function in asset preprocessing worker - Update extractAndSaveImageText to route between Tesseract and LLM OCR - Update documentation with the new configuration option When OCR_USE_LLM is enabled, the system uses the configured inference model to extract text from images. If no inference provider is configured, it falls back to Tesseract. https://claude.ai/code/session_01Y7h7kDAmqXKXEWDmWbVkDs * format --------- Co-authored-by: Claude <noreply@anthropic.com>
* feat: batch meilisearch requests (#2441)Mohamed Bassem9 days1-7/+18
| | | | | * feat: batch meilisearch requests * more fixes
* fix(mobile): migrate from RN image to expo-imageMohamed Bassem9 days6-34/+55
|
* chore: replace dayjs with data-fnsMohamed Bassem9 days6-20/+10
|
* fix(web): don't bundle tiktoken in client bundlesMohamed Bassem9 days4-3/+10
|
* feat(mobile): use native tabs for mobileMohamed Bassem9 days4-90/+59
|
* fix(mobile): make the subtext in bookmark info page more subtleMohamed Bassem9 days1-3/+3
|
* feat(mobile): add signup support to the mobile appMohamed Bassem9 days1-1/+14
|
* feat: add support for redirectUrl after signup (#2439)Mohamed Bassem9 days4-14/+62
| | | | | | | | | | | * feat: add support for redirectUrl after signup * pr review * more fixes * format * another fix
* fix: better looking error message when article content is unavailableMohamed Bassem9 days2-1/+22
|
* fix(mobile): fix some mobile warning after expo 54 upgradeMohamed Bassem9 days11-30/+50
|
* refactor: remove unused trpc files from web and mobileMohamed Bassem9 days76-83/+102
|
* refactor: migrate trpc to the new react query integration mode (#2438)Mohamed Bassem9 days96-1405/+1845
| | | | | | | | | * refactor: migrate trpc to the new react query integration mode * more fixes * more migrations * upgrade trpc client
* refactor: centralize auth imports through new client module (#2437)Mohamed Bassem9 days15-15/+25
| | | | | | | | | | | | | | | * refactor(web): centralize next-auth client-side utilities Create lib/auth/client.ts to re-export all next-auth/react APIs (useSession, signIn, signOut, SessionProvider) from a single location. This prepares for future auth provider replacement by isolating the next-auth dependency. https://claude.ai/code/session_01RLLL6SquzmegG6wKHdT3Fm * format --------- Co-authored-by: Claude <noreply@anthropic.com>
* feat(mobile): show num bookmarks in the all lists viewMohamed Bassem9 days1-4/+30
|
* fix(mobile): fix mobile list stylingMohamed Bassem9 days4-12/+12
|
* refactor: lazy init background queuesMohamed Bassem9 days1-10/+50
|
* feat(cli): Add bookmark search command (#2426)Mohamed Bassem2026-01-262-12/+88
| | | | | | | | | | | | | | | | | | | | | | * feat(cli): Add search subcommand to bookmarks Add a new search subcommand that uses the searchBookmarks API endpoint. The command supports: - Full-text search with advanced query matchers (tag:, is:, list:, etc.) - Pagination with --all flag to fetch all results - Sorting by relevance, ascending, or descending order - Optional full content inclusion with --include-content - Configurable result limit per page Example usage: bookmarks search "is:fav tag:important" bookmarks search "kotlin" --sort-order desc --limit 20 bookmarks search "title:api" --include-content --all * fixes + format --------- Co-authored-by: Claude <noreply@anthropic.com>
* fix(ui): Improve visual consistency in all lists and highlights pageMohamed Bassem2026-01-195-21/+29
|
* feat: disable karakeep 2025 wrappedMohamed Bassem2026-01-193-56/+3
|
* feat(extension): autofocus on note open (#2366)Snoww2026-01-191-0/+1
| | | * Autofocus on note open
* ux(mobile): align all lists in the all lists tabMohamed Bassem2026-01-181-19/+34
|
* feat: track api key usage datesMohamed Bassem2026-01-183-19/+29
|
* deps(mobile): upgrade to sdk 54Mohamed Bassem2026-01-184-514/+36
|
* feat(rules): add "Title Contains" condition to Rule Engine (#1670) (#2354)Andrii Mokhovyk2026-01-183-1/+58
| | | | | | | | * feat(rules): add "Title Contains" condition to Rule Engine (#1670) * feat(rules): hide title conditions for bookmark created trigger * fix typecheck
* fix(mobile): Reader settings preview on mobile matches reader view ↵Evan Simkowitz2026-01-182-16/+170
| | | | | | | formatting (#2365) * fix: Reader settings preview on mobile matches reader view formatting * address comments
* fix(web): avoid masonry overflow in bookmark grids (#2400)Evan Frenkel2026-01-183-5/+25
|
* deps: upgrade react to 19.2.1Mohamed Bassem2026-01-154-7/+7
|
* fix(mobile): add custom headers to card banners. fixes #2342Mohamed Bassem2026-01-111-6/+9
|