-
Notifications
You must be signed in to change notification settings - Fork 107
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Passkey support #297
Comments
Yes, good point, thank you! |
For tracking: keepassxreboot/keepassxc#1870 |
See draft pull request for current implementation |
@jasperweiss , @hkaancaliskan , the nudges are well noted, thanks :) |
@keepassium on keepassxc side passkey support merged :) any progress on keepassium side? |
@hkaancaliskan It's not released yet. Some breaking changes might still be made so it's probably a good idea for KeePassium to wait for KeePassXC to release their final implementation. |
@hkaancaliskan @jasperweiss KeePassXC's passkey release is currently pending this issue: keepassxreboot/keepassxc#10197 |
It appears that KeePassXC moved that issue to 2.8.0 and released 2.7.7. |
KeePassXC passkey support is now released and seems to be working great (tested with GithHub and passkey.org in Firefox) |
Now it would be nice to have passkey support in KeePassium |
Perhaps I should explain why this takes so long.
In order to make database editable in AutoFill, we need to rewrite database processing to use small data chunks. This should drastically reduce the memory consumption of AutoFill. However, this requires rewriting the DB processing code from the ground up — which is quite a hefty task. Albeit slowly, we are walking the path. A few days ago I finished optimization of the XML parsing process, it will make AutoFill a bit leaner already in the next update. But we also need to switch to chunked encryption/decryption. This is happening right about now, but will take a couple of months to complete (unless something else requires urgent firefightning…) Might also have to offload entry attachments to disk temporarily, since attachments are the worst offenders memory-wise. Once the ground work is done, it will unlock entry editing in AutoFill (#87). And then there will be passkeys. |
Thanks for the detailed update and working on this, sounds like a lot of work!
Just an idea that might make this doable with less complexity, obviously I'm not familiar with any of the details so I don't really know if it would be practical or even simpler, but here it goes: |
@ThinkChaos , thanks! Yes, this is also an option. I'm a bit concerned about performance overheads, though, since skipping to a position of a multilayer (cypher + gzip + another cypher) stream implies doing all the work nevertheless. And for the earlier kdbx3 format getting to an attachment is really a piece of cake. Really thick multi-layer cake: external cypher + gzip + xml + base64 + inner cypher + gzip again :) I've been thinking to just save chunks of attachments when loading the database. Each chunk padded with a random-length garbage to obscure its size, and encrypted with a random key, unique for each chunk. When the time comes to reassemble and save the database, it would be just reading and decrypting the cached chunks. And if the device is compromised and someone gets to the cached chunks, these would be just piecemeal binary blobs with random names and sizes. |
I don't know how much work it would be, or if it would be worth it, to at least temporarily only allow using already existing passkeys and not allow creating them? |
This was the case for TOTPs for a while :) But passkey implementation seems far from trivial, so I'd rather deep-dive into it only once. Otherwise there will be much time left on context switching. |
Hey. Is there any ETA on this? Just wondering about the progress because I'm really looking forward to it. |
@unoukujou , just to be clear, that "couple of months" referred to one of the building blocks (chunked encryption/decryption), rather than the whole feature. As for ETAs, I'd rather not share any timelines until everything is implemented and ready for release. We are not at that stage yet. |
I am very curious about this feature. Thanks lot for all the time. I decided to buy the software license. |
Hi Team, any update ?? |
Looking forward for passkeys |
Look what's coming in the next beta :) passkey-creation.mp4 |
Just uploaded 1.54.156 to TestFlight (beta testing) and a macOS build here. It covers the main functionality: creating passkeys and using them to sign in. Some pieces are still work-in-progress, though. Specifically, recovering when AutoFill runs out of memory and crashes while saving. (This won't corrupt the DB, just no passkey would not be created.) Early feedback is welcome! |
Great to see this in KeePassium! I have just downloaded the TestFlight build. I found a couple of issues:
debug.mp4debug2.mp4 |
@jasperweiss , thank you! I think I've fixed most of these for the upcoming beta.
In English it says
Yes, the current thing is really minimalistic. Unfortunately, this is a balancing act. Too many nice-to-haves and we end up with a full-blown entry editor, when most people might only need a "Save" button. So this will evolve based on feedback, I just want to see which parameters really need to be customizable immediately in AutoFill, and which can be left for later. (For instance, favicon downloading is likely in the latter camp.) |
It seems a bit out of place. I would read that as my identity for a given conversation. The other translations seem to translate "Caller ID" quite literally. The German and French translations are "Anruf-ID" and "ID D'appel" respectively, which you'd really use in the context of a telephone conversation, I think. The Spanish translation "Identificación de la persona que llama" quite literally means "identification of the person who is calling". In the context of "Relying party" (which I think is the phrasing used in the spec), "Vertrouwende partij" seems appropriate in Dutch. "Vertrauende Partei" in German or "Partie de confiance" in French. These all roughly mean "Trusting party" but I can only really comment on the Dutch translation. If Caller ID is the desired phrasing, "Aanvrager-ID" would work in Dutch. (Literally "applicant/requester ID") |
@jasperweiss , wow, quite a bedlam there… Clearly, "Caller ID" was not the best choice, if it leads to such diverse interpretations. I'll replace it with a more generic "Context", it should work in all the possible scenarios:
|
@jasperweiss , thanks, I never thought of testing this and indeed it does not work via QR codes.After an hour of testing, I did not find any obvious problems, so this will need a deeper dive. (Given the season, probably already in January.) |
@Jerroder, thank you for the detailed feedback. It seems you managed to encounter everything that could possibly go wrong :) Some of this is kind of expected, just not all at once.
This is by design at the moment. Just checking how many people need that function (strongly enough to ask about it). A side effect of no-analytics-collected policy.
Unfortunately, it could not do much better under the circumstances:
These are the unexpected parts, and I suspect they are related. Is the original database stored in "On My iPhone / KeePassium"? Was the new one saved there as well? |
It is a nice-to-have feature indeed but not must-have for me. Depending on the entry I'll probably need to go in there manually to rename or remove some older TOTP methods or sormthing.
That's what I thought, it makes sense.
Yes and yes. |
Good! Then it looks like bad luck mixed with a bug :) Due to some technical quirks, AutoFill cannot access KeePassium's folder easily. If you restart the device and open AutoFill before launching the main KeePassium app, AutoFill would get a "permission denied" from the system. As a plan-B, AutoFill loads an internal backup file instead — in read-only mode. (It should also show a message that the database is unreachable.) And then there is a bug. Since AutoFill is very new to this whole "database editing" thing, it does not check whether the file is read-only — it just tries to write it. And fails, because the database is actually unreachable. Long story short, there should have been a "Database is read only" message instead of passkey creation dialog. We'll get that fixed. Thanks again! |
@keepassium and yes, adding passkeys to an existing entry would be my wish, too |
@Sereby88 , noted. Regarding WebDAV: already done. |
@keepassium I would use the database from a WebDAV share (like now) and would like to use Passkeys and add them to existing entries to the database on the share. Hopefully this will work without having to change to local database per device I hope you understand what I mean :-) |
@Sereby88 , the problem was because of a locally stored DB :) Remote files should work even better in this regard. |
First of all great you've finally made initial passkey support available 👏 I've played around a bit with it the last days. And I've seen some scenarios where passkey generation didn't complete successfully. An public reproducable sample is adding a passkey to an Auth0 account: Step 2 (iphone): |
@danielwagn3r , thank you for the feedback. Yes, passkey registration via QR codes is broken at the moment. I have registered it as #408 so it does not get lost in this thread. (Chances are, there will probably be many more passkey-related issues :) |
Keepass[XC] don't support this yet, but I wanted to open an issue here to track it anyways as progress could be made even before the others apps do, for instance by storing passkeys in custom entry fields.
As per this blog post, iOS and macOS have introduced a passkey provider API already:
The text was updated successfully, but these errors were encountered: