mirror of
https://github.com/karakeep-app/karakeep.git
synced 2026-04-26 00:16:03 +03:00
Closed
opened 2026-03-02 11:48:51 +03:00 by kerem
·
23 comments
No Branch/Tag specified
main
refactor/use-npm-singlefile
onetab
claude/issue-2596-20260321-1401
claude/fix-docs-button-responsive-V3aBQ
claude/review-import-backpressure-D4ArJ
claude/fix-archived-bookmarks-mobile-P9OJW
claude/issue-1189-20260211-1601
claude/fix-nested-smart-lists-3uFkt
claude/issue-2298-20251223-1704
feat/import-v3
claude/add-cli-search-subcommand-6kIe0
claude/add-bookmark-indexing-timestamps-96bPj
claude/auto-disable-failing-feeds-fkDhP
claude/add-tag-search-aliases-HzESD
feat/docker-compose-dev
claude/add-attachedby-tags-endpoint-01WYfemMGHJJjXsPYLvUJAno
claude/fix-crawler-memory-leaks-NE7Ct
bookmark-debugger
claude/issue-2352-20260106-1120
claude/issue-1977-20260102-2348
claude/add-banner-rendering-JeLUk
claude/add-descendant-qualifier-cUm26
claude/skip-metadata-refresh-archives-CAo4Y
claude/fix-archive-pending-banner-pAyGM
claude/add-embeddings-support-h2swV
claude/nested-manage-lists-QVV85
claude/privacy-type-system-MG1bT
claude/add-action-menu-icons-6hNKw
claude/issue-2299-20251223-1711
claude/bookmark-indexing-progress-QwZSI
claude/migrate-bookmark-attachments-3O2te
claude/add-2025-wrapped-feature-tIUIh
claude/improve-ai-settings-design-639tq
claude/add-youtube-metascraper-plugin-0lWC7
claude/add-problem-reporting-gSSEV
claude/add-mobile-list-menus-spcS7
claude/shadcn-bookmark-cards-WWHzP
claude/add-extensions-link-HTeXc
claude/add-onboarding-screens-hsYMO
claude/fix-settings-switch-overflow-nlzM4
claude/clamp-bookmark-titles-diAEz
claude/port-stats-mobile-expo-MuXAn
claude/whats-new-base-version-vrv8C
claude/fix-settings-auth-checks-jgyD8
claude/add-server-version-display-3sGa2
claude/fix-tag-editor-scrolling-rzdbG
claude/add-company-pricing-card-y5mHY
claude/audit-optimize-transactions-xpDVc
codex/ensure-consistent-ui-experience-across-app-pages
claude/plan-opentelemetry-integration-01Jx183mz1Ev8h8JoYj97Auw
libsql
db-indicies
claude/export-import-lists-01UuCWwdaqduAd35NppvjnMD
claude/configurable-worker-timeout-0198GQh6YrrRzqG62xnogyrz
claude/check-import-quota-01CPdxTpHp18Ba62bYcBTVbA
claude/scraper-worker-thread-01FEHen6MGrQHmdBstJSuiyA
claude/customize-dialog-styling-01CVjEv2KgyZJSpCg3mqkvR7
claude/add-asset-cache-headers-0175WhNcqwiwurrmjj52jnLT
claude/add-db-search-plugin-017Xxd4Jq3MfjWT788vgfbaq
benchmarks-2
claude/add-filtered-deletion-01DTxWNcg3hhqdNpeNLa3s6L
claude/actionbutton-loading-spinner-015DY5ZTvgPgFAXTZz3UGaYv
claude/add-broken-links-qualifier-01S31X1LsKiYb9gE1dXTKvi3
claude/docker-release-tag-trigger-01UmzFXEumhK2jdmRGtMcueo
claude/spread-feed-fetch-scheduling-01EihUtmZSyqeE1HfRMessxW
restate-idempotency
claude/align-android-ios-colors-01GJfkhEyZVBReohVioPa8ok
claude/improve-mobile-app-colors-0155LzHfkd5HyJr6YyZMsus5
codex/add-autocomplete-for-search-query-language
claude/add-bookmark-backups-016L2A8Z94n7tDgDdMPdFuAd
claude/restrict-binary-user-permissions-01FSGyy2RXGZvE26YbAejzGi
effect-ts
claude/prepare-trpc-npm-publish-0193EjfwpxSNVNcLXqXjs6Ln
shared-list-sidebar
claude/lazy-load-tiktoken-017UTNpJPTcMMQvNEBa1aFwo
codex/fix-asset-pre-processing-worker-abort-signals
add-groupid
claude/add-bookmark-list-button-01VF7uXYNLsVDzqdozWMXP5M
claude/extract-shared-ui-components-01DSVfaCr6WRqAyx1vJTZk9r
claude/migrate-shadcn-sidebar-01DKjpg9MD5PJ2potemSnbvW
claude/add-collaborators-rate-limits-01VjXyRWWPUkGQKa8d8D8qKj
claude/modernize-dark-mode-01FRfE81PAY5C44pFu1cYocf
claude/add-signed-url-bookmark-01PjYT1ZhvLK2FPJNTAhJsWf
restate-group-id
claude/add-highlights-page-012vhHpn8fVNp3gf7gBeW14s
claude/disable-shared-bookmark-features-01B9fiGUdu6NyWaxSQFsQBxP
claude/mobile-bookmark-grid-layouts-018cGBBMhPJVq6PJVRBpqT2r
claude/add-mobile-bookmark-summary-01494LYoh4sJW5Fj4GPm62Vj
claude/add-mobile-tags-screen-01WRADt4ZzvXVew1Y9vqF8SV
claude/add-highlight-notes-01LpanRLS4a2YMnT1qB5GTqX
claude/add-search-bar-014k2ngaqjwYRVSvqmbuECqr
claude/hide-collaborator-emails-01TQrkkMupC7CR9BTuDkireg
claude/list-invitation-approval-0129V89M1riXW6JqmoF74VfM
claude/add-bookmark-archive-sort-018VbGPGvtmsGgXFEERoAX7B
claude/add-mobile-smart-lists-01251tYo9u1SywE6XFezAv9e
claude/bookmark-drag-drop-01DmWq286ogHpDGHKcXjKr3z
claude/add-rss-import-01DH1Q2axcDeq8nQJR5MWjPJ
claude/mobile-inapp-browser-auth-01KiT6bwyntRPQ1X4oTtAveC
claude/offline-mode-react-query-01D1rE2bdBEPw2teGqunr5Gd
claude/add-singlefile-extension-support-01BEB9QQZABzwfZDvR9Bz5b2
claude/custom-list-slugs-01VxcfkNUXZ97FNpNVURopMq
claude/issue-2148-20251118-1133
claude/add-groupid-queue-fairness-011CV1r8Wb46HuGAg5o95i3m
claude/hide-viewer-shared-lists-01Fst6NBvdxrXXnDhUmjsNDP
claude/collaborative-lists-013AvDvMqkoszDVcSoCYgBcM
claude/implement-feature-01LT5XzGsbEhZkYXNEjEwdui
claude/fix-bookmark-loading-state-01AgF4H2drxwuTCJDB2Xgiu4
claude/admin-user-edit-013tbiRmb1KX2fhSYqmGKCu8
claude/expose-all-api-01YTruEW72WQYMtq4iZoaPkA
claude/add-doc-link-main-016NYLxShpKuH6R8XCBgeZtc
claude/fix-issue-2133-019JLvdSRAUbU4FtjQztcM6S
claude/explore-effect-ts-integration-01F7xb1dWwP1ma4LnLbFGfDD
claude/optimize-dockerfile-build-011CV5gDnPZbdbbVSPDofC4e
claude/add-custom-headers-guide-011CV249t16aWDRb1mCrzQdC
claude/mobile-app-signup-011CUxPtCXgU6U3T8GShTR2Q
claude/crawler-worker-fetch-browser-011CUvcRc24XEr9DTWDW6MX8
claude/fix-issue-784-011CUvubQrcZHG9S3KjpCKbK
codex/add-user-settings-for-inference-language-and-screenshots
claude/fix-mobile-signin-server-address-011CUnaUWwY2Fhq5Xbwhgr8H
better-auth-2
claude/issue-2028-20251012-1429
claude/issue-1010-20251012-1154
codex/update-feed-refresh-job-idempotency-key
restate
import-v2
fix-public-lists
recurse-delete-list
abort-dangling-processing
tag-pagination
ratelimit-plugin
claude/issue-1937-20250914-0912
codex/implement-title-search-query-qualifier
copilot/add-edit-button-for-notes
cookie-path
ai-tag-cleanup
codex/add-allowlist-and-blocklist-env-variables
mobile-retheme
expo-next-upgrade
opencode/issue1788-20250727215611
fix-trailing-slash-deduplication
edit-bookmark-dialog
bookmark-embeddings
rag
nextjs-15
bookmark-hover-bar
sapling-pr-archive-MohamedBassem
track-bookmark-assets
json-cli
admin-settings
mobile-dark-mode
android/v1.9.2-0
ios/v1.9.1-1
android/v1.9.1-0
ios/v1.9.1-0
ios/v1.9.0-2
ios/v1.9.0-1
android/v1.9.0-1
extension/v1.2.9
cli/v0.31.0
sdk/v0.31.0
mcp/v0.31.0
android/v1.9.0-0
ios/v1.9.0-0
v0.31.0
android/v1.8.5-0
cli/v0.30.0
sdk/v0.30.0
ios/v1.8.4-0
android/v1.8.4-0
v0.30.0
cli/v0.29.1
v0.29.3
v0.29.2
v0.29.1
sdk/v0.29.0
cli/v0.29.0
mcp/v0.29.0
ios/v1.8.3-0
android/v1.8.3-0
extension/v1.2.8
v0.29.0
android/v1.8.2-2
android/v1.8.2-1
ios/v1.8.2-0
android/v1.8.2-0
extension/v1.2.7
android/v1.8.1-0
ios/v1.8.1-0
v0.28.0
cli/v0.27.1
cli/v0.27.0
v0.27.1
sdk/v0.27.0
v0.27.0
android/v1.8.0-1
ios/v1.8.0-1
mcp/v0.26.0
sdk/v0.26.0
v0.26.0
cli/v0.25.0
ios/v1.7.0-1
mcp/v0.25.0
v0.25.0
extension/v1.2.6
ios/v1.7.0-0
android/v1.7.0-0
v0.24.1
v0.24.0
mcp/v0.23.10
mcp/v0.23.9
mcp/v0.23.8
extension/v1.2.5
mcp/v0.23.7
mcp/v0.23.6
mcp/v0.23.5
mcp/v0.23.4
sdk/v0.23.2
cli/v0.23.0
extension/v1.2.4
android/v1.6.9-1
ios/v1.6.9-1
v0.23.2
v0.23.1
sdk/v0.23.0
v0.23.0
ios/v1.6.9-0
sdk/v0.22.0
v0.22.0
android/v1.6.8-0
ios/v1.6.8-0
sdk/v0.21.2
sdk/v0.21.1
sdk/v0.21.0
v0.21.0
cli/v0.20.0
v0.20.0
ios/v1.6.7-4
android/v1.6.7-4
ios/v1.6.7-3
android/v1.6.7-3
android/v1.6.7-2
ios/v1.6.7-2
android/v1.6.7-1
ios/v1.6.7-1
ios/v1.6.7-0
android/v1.6.7-0
v0.19.0
android/v1.6.6-0
android/v1.6.5-0
ios/v1.6.5-0
ios/v1.6.4-0
android/v1.6.4-0
v0.18.0
v0.17.1
v0.17.0
ios/v1.6.3-0
android/v1.6.3-0
extension/v1.2.3
ios/v1.6.2-1
android/v1.6.2-1
ios/v1.6.2-0
android/v1.6.2-0
v0.16.0
ios/v1.6.1-3
android/v1.6.1-3
ios/v1.6.1-2
android/v1.6.1-2
android/v1.6.1-1
ios/v1.6.1-1
android/v1.6.1-0
ios/v1.6.1-0
extension/v1.2.2
android/v1.6.0-1
ios/v1.6.0-1
ios/v1.6.0
android/v1.6.0
cli/v0.13.7
cli/v0.13.6
v0.15.0
cli/v0.13.5
extension/v1.2.1
v0.14.0
cli/v0.13.3
cli/v0.13.2
cli/v0.13.1
cli/v0.13.0
v0.13.1
v0.13.0
mobile-v1.5.0
mobile-v1.4.0
v0.12.2
v0.12.1
v0.12.0
v0.11.1
v0.11.0
v0.10.1
v0.10.0
v0.9.0
v0.8.0
v0.7.0
v0.6.0
v0.5.0
v0.4.1
v.0.4.0
v.0.3.1
v0.3.0
v0.2.2
v0.2.1
v0.2.0
v0.1.0
Labels
Clear labels
Mirrored from GitHub Pull Request
UI/UX
android
bug
dependencies
documentation
documentation
extension
feature request
feature request
good first issue
ios
long-term
performance
pri/high
pri/low
pri/medium
pull-request
Mirrored from GitHub Pull Request
question
status/approved
status/icebox
status/pending_clarification
status/untriaged
No labels
UI/UX
android
bug
dependencies
documentation
documentation
extension
feature request
feature request
good first issue
ios
long-term
performance
pri/high
pri/low
pri/medium
pull-request
question
status/approved
status/icebox
status/pending_clarification
status/untriaged
Milestone
Clear milestone
No items
No milestone
Projects
Clear projects
No items
No project
Assignees
Clear assignees
No assignees
1 participant
Notifications
Due date
The due date is invalid or out of range. Please use the format "yyyy-mm-dd".
No due date set.
Dependencies
No dependencies set.
Reference
starred/karakeep#326
Loading…
Add table
Add a link
Reference in a new issue
No description provided.
Delete branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Originally created by @cpuks on GitHub (Oct 7, 2024).
Original GitHub issue: https://github.com/karakeep-app/karakeep/issues/504
I've got hoarder deployed on my selfhosted server and it's hidden behind Authentik.


I can access and login to hoarder via domain and IP, but I cannot access Hoarder via Android app - it works through IP:port but not via domain.
Tried with API tried with email/passwd nothing works.
@kamtschatka commented on GitHub (Oct 7, 2024):
"Unexpected character: <" means in 99,99999% of the cases, that this is not getting a JSON response, but HTML.
My guess is, since you said "it's hidden behind Authentik", that you have set it up wrong.
To me that sounds like you are using a Proxy authenticator in authentik, which is not supported. You have to use the OAuth2/OpenID provider.
@cpuks commented on GitHub (Oct 7, 2024):
I've got OAuth2 provided ready but... I cannot get this option to work:

And my .env part of OAUTH
OAUTH_WELLKNOWN_URL=<redacted> OAUTH_CLIENT_SECRET=<redacted> OAUTH_CLIENT_ID=<redacted> OAUTH_SCOPE=openid email profile OAUTH_PROVIDER_NAME=Authentik OAUTH_ALLOW_DANGEROUS_EMAIL_ACCOUNT_LINKING=trueWith those env set I should see OAuth login but it's not there - tried different browsers
@MohamedBassem commented on GitHub (Oct 7, 2024):
@cpuks this usually indicates problems in your
NEXTAUTH_URL. Do you see errors like this one in the logs of the web container?@cpuks commented on GitHub (Oct 8, 2024):
That's my error:

And
NEXTAUTH_URL=https://hoarder.<domain>But the problem is that with all those envs I should at least see option to authenticate with OAuth
@kamtschatka commented on GitHub (Oct 13, 2024):
yeah so that is exactly what I said. You are hitting a webpage and not an API endpoint.
Did you set up authentik with a proxy provider or with an OAuth provider? Hint: proxy provider does NOT work, as it will redirect everything to authentik first.
@cpuks commented on GitHub (Oct 13, 2024):
Thanks for reply as I went back to digg that issue - seems like Tailscale is problem, let me explain:
I've got tailscale setup as I don't need to expsoe services to the Internet, then to authenticate my selfhosted app I'm using Authentik with OAuth were possible or ACLs, my rev proxy is NPM, all those serivices are on different containers / PVEs but all of them are logged to my tailscale network so I can use OAuth - immich / audiobookshelf / paperless-ngx and so on are working fine.
With Hoarder only way I finally can see and login via OAuth was:
NEXTAUTH_URL=http://192.168.88.200:3111 Authentik redirect URI: .*Anytime I set NEXTAUTH_URL to domain name it throws error and never displays Login with OAuth option - probably because that domain is on wildcard and not exposed to the Internet, but for expample Immich on this very same machine just different container works fine.
Any way to make work around other than making my domain public?
EDIT
And Hoarder Android APP throws same error and there's no OAuth login option - just API or email/passwd, but in browser I authenticate with OAuth and redirects me to NEXAUTH_URL
@MohamedBassem commented on GitHub (Oct 13, 2024):
@cpuks basically the problem that you're facing is that the URL that you pass in
NEXTAUTH_URLneeds to be both accessible from the browser, and from inside the container. To get around this, I think you can use:Can you give that a shot and let me know if it'd work?
@MohamedBassem commented on GitHub (Oct 13, 2024):
The main thing that there's no way around is that whatever address that you put in the OUTH well known address it needs to be "reachable/resolvable" from within the hoarder container. Hoarder's backend needs to be able to talk to authentik.
@cpuks commented on GitHub (Oct 13, 2024):
@MohamedBassem perfect thanks that worked in browser but not in Android app - maybe that NEXAUTH_URL_INTERNAL should be added to docs?
@MohamedBassem commented on GitHub (Oct 13, 2024):
@cpuks I think I can include it in the docker container itself so that people won't need to touch it themselves.
Now for the android app, is your app still "behind" authentic or did you ditch that setup and just using OAUTH now?
@cpuks commented on GitHub (Oct 13, 2024):
Just reinstalled Android app - when I type domain address it gives me only option to login with email/passwd or API - like on 1st post, no OAuth option.
EDIT
Just tested on iPadOS and Edge incognito (Win11) and browser works fine - OAuth redirects to https domain, just app is problematic.
@MohamedBassem commented on GitHub (Oct 13, 2024):
@cpuks when using Oauth, you should be using API keys for authentication.
@cpuks commented on GitHub (Oct 13, 2024):
That's same error with API - JSON parse error - as in first post, I'm logged fine in browser on that very same phone, URL is accessible.
@MohamedBassem commented on GitHub (Oct 13, 2024):
@cpuks Basically this means that something is infront of hoarder responding with html content instead of JSON. If Hoarder is still behind "hidden" behind authentik then that's the problem.
I've also pushed
github.com/hoarder-app/hoarder@90953fdab8which will fix connection testing to debug the error you're facing. Hopefully it'll be released by google in a day and two and would help us debug this further.@cpuks commented on GitHub (Oct 13, 2024):
Perfect - I'll get back once it'll be available. Thanks a lot for help so far.
@MohamedBassem commented on GitHub (Oct 13, 2024):
@cpuks the update is now on the play store
@cpuks commented on GitHub (Oct 14, 2024):
That's the error:
@cpuks commented on GitHub (Nov 10, 2024):
Any chance that's fixable or I should leave hope and use Hoarder via browser?
@MohamedBassem commented on GitHub (Nov 10, 2024):
@cpuks sorry I missed your message. The debug logs basically shows authentik responding not hoarder. This is currently not supported. You'll need to not put Authentik in front of hoarder and the mobile app would work. You can still use authentik for oauth (and disable password logins), but you just can't use authentik for forward auth.
@cpuks commented on GitHub (Nov 10, 2024):
Ok so I'll just set rev proxy straight to Hoarder and close the issue.
@MohamedBassem commented on GitHub (Nov 10, 2024):
yeah give it a shot and let me know how it goes. I'm planning to add custom headers support to mobile logins but I still haven't got a chance to do it.
Your other option is to exclude the '/api/*' routes from authentik's forward proxy.
@Kavinraja-G commented on GitHub (Nov 16, 2025):
Noting it here for who got stumbled on this issue when using Pangolin Auth on the resources. Once I disabled the platform authentication in Pangolin - extensions, app everything works fine.
I'd like to see how we can resolve this, @MohamedBassem any thoughts? Thanks!
@MohamedBassem commented on GitHub (Nov 16, 2025):
@Kavinraja-G you need to allowlist the api endpoints used by karakeep (https://docs.pangolin.net/manage/access-control/rules). The other option is to use the newly released custom header feature in karakeep to authenticate to pangolin