-
Notifications
You must be signed in to change notification settings - Fork 9
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
Syncronization between clients (Twik, Phashword, etc) #14
Comments
Basically, a nice idea. The problem is the portablility. I'm sure @gustavomondron wants to keep compability also to other plugins and programs. That does mean, we need a stable specification for how to transfer what where. Basic questions: What do you want to sync exactly? These questions maybe seem quite easy to answer, but they are not. Please get needed information, so we can discuss if and how we could realize a sync-module or so. Note i don't own the twik project, we should also wait for @gustavomondron's opinion. |
Sorry for such a LATE reply. :D
Everything but the hashed passwords, obviously. That means syncing all profiles, private keys, website tags, password lenghts and password policies that the user decides to save.
You can store all those variables on a file (ini, json or whatever makes it easy to read) and then .zip that file with password using the master key from the user. I think it should be possible to unpack that encrypted zip file even using javascript with something like this.
Yes, maybe a better protocol for syncing exists, that's something that can be discussed. For a start, I think it should be possible to store that zip file on a FTP / Web server provided by the user and every client app should be able to read it.
No, sorry, I didn't, but maybe invoking @gustavomondron (like you did before) helps. :)
That's something I cannot answer, I think. I'm pretty sure my initial idea is not the best solution for syncing, but I hope it can at least raise interest on the feature. Best regards, |
Hello, I'm truly sorry for the very long delay. Client synchronization is a must and, of course, this is going to be addressed. I still need to analyse this issue but I'll share some thoughts about it:
|
Hi, i've done a quick look over Keepass' Implementation and Android SAF concept. Android SAF i think is not what you wan't unless you use Android 7 (i think its to early for setting that as minimum requirement). Android 7's SAF introduces a virtual file system, wich would be excellent for that usecase and will surely be implemented by various web storage providers like dropbox. The concept of the Storage Access Framework in earlier versions is more like using files only one time. That could be used for a import/export functionality. Keepass' Implementation is an abstraction for writing Files remotely, which is more useful now. A hint for those who can't find the implementation: It's located in In both cases there is needed a import from/export into file functionality and partly also a GUI. @gustavomondron I'd like to help. To make it short what should get synchronized:
(De-)Serializing into json should not be a problem. |
Hello, I agree with you on your SAF analysis. Android 7 virtual files fit nicely to our needs but it's too early to go that way. I have been using Keepass for a couple of weeks to find out the pros and cons on my daily routine. One of the things I loved was the ability to store additional data for each account, such as the username.
Of course, @murderered, I'm glad you are willing to help, I do appreciate all contributions. |
Two-ways, continuous synchronization is hard to get right. I would use this as a one-way backup-restore approach. The only possible addition I'd consider, is maybe ask if you want to "Replace all profiles or just append new (possibly renamed) profiles" and, now that I think of it, maybe it's better to always append new renamed profiles like "Personal (restored), Work (restored), ..." and so on. Using Keepass is cool but will likely complicate the synchronization between Android and Desktop. I'm not against it but I'd first consider why easier approaches don't work. To begin with, what is what you consider the most sensitive data. As I see it: the master password and the private password. I don't want the rest of the config publicly available either but it is not as sensitive as the first two. For the master password, I wouldn't store it anywhere. Just use it on the fly and remove it from RAM as soon as possible. For the private password, I see the merit of keeping a backup. For that, I'd simply follow your thoughts: put it together with the rest of the config, serialize it, encrypt it with the master password (all of this in Twik --both the Android app and the Chrome extension) and store it in Google Drive. I know that Android apps can claim their own hidden Google Drive folder, that would be ideal if the Chrome extension could access that folder as well. I think this is the minimum viable product towards having this feature and, if it is ever extended, most of the pieces can be reused for future versions. What do you guys think? |
Maybe first define "the words":
So i agree twik should stay as stateless as possible. So never ever save the master password. But what we want to achieve with synchronization?
The first and last one are from user-view and implementation-view quite similar: They are a manual process, the user hits a button and exports its configuration. At that time he can encrypt the exported file with the synchronization key dynamically created while saving the data. The synchronization key could be protected by the master password. I think this is the situation @jamartinb meant. The second one is from the user-view the most comfortable, but from implementation view quite hard: In this case there is needed a two-way synchronization, the encryption key has to be more or less static [1]. The synchronization has to be done in background without entering the password for maximum comfort, so the synchronization key can't be protected absolutely securely by design. Also the user does not want to see deleted tags in other clients. This makes synchronization harder, as collisions can (murphy's law: will) happen. The third situation is simpler from implementation side, but not optimal from users view. In this case you may use one- or two-way synchronization and merging only incrementally. If the user deletes a tag or renames it, a copy of the old will pop up again. If we know how we want to synchronize, we can think about how to secure the whole thing. I'm sure there is a way to secure that whole thing without saving the master password. [1] There are some possibilities using asymmetic encryption algorithms, but that would be really hard to implement right. It would be also a overloaded solution for this purpose. (In german there is a adage: "Mit Kanonen auf Spatzen geschossen", translated freely: fired with cannons on sparrows :) ) |
It would be nice to have synchronization between clients.
One way this could be performed would be using a file on an user-provided FTP server. All settings could be stored on a encrypted file inside the FTP server, and the password for that encrypted file could be hashed by Twik. :)
This way, you don't depend on cloud storage, and I think most final users will be able to find an FTP server on their own.
What do you think?
The text was updated successfully, but these errors were encountered: