Iâll remove it for now, itâs only for bugs and it means the bug has been tracked by us.
I donât see a way to add a quick tooltip for each tag, so sorry for the confusion! You donât need to add any tags when posting a topic, it might cause future confusion when managing topics. Thanks!
I think this should be merged with the âpassword protectionâ feature on trello https://trello.com/c/e7flE77k/149-password-protected-documents. Without actual client-side encryption setting a password for a document is not so useful. Why not make it client side encrypted at the same time?
I think that one is a bit different. Password protected document is so that your kid or spouse or colleague wonât accidentally see whatâs in your secret Dynalist document.
I still think they are two different use cases. Obviously page encryption is a stronger measure to protect your privacy.
I would like to use Dynalist for work, and this is a necessary component of me feeling safe to do that (along with implementing two-factor authentication). So hereâs another vote for implementation! I realize itâs likely a big task to do so.
@Erica@Shida As I see it, this could be implemented fairly easily by just encrypting each item with a client side key before sending it to the server and decrypting each async http response with items locally in the client.
When opening a new Dynalist tab, you would have to insert your keyphrase so that it is locally stored in memory of the client.
The same procedure applies to the API, all requests send encrypted data and receive encrypted data.
For shared documents, the key would have to be communicated between participants over a different channel (like person to person, encrypted email, etc).
Which commonly used encryption scheme to use would still have to be discussed.
All of this should be easy to implement, compatible with all current Dynalist features, and much easier than an offline mode or similar ideas. Furthermore, a huge selling point compared to competitors.
Totally agree that this would be very useful to have.
Couple of concerns weâre still working out the details:
Backward compatibility (or upgrade process). Depending on which part is encrypted and how the encrypted data is encoded, older dynalist clients (especially mobile app and desktop app) will either completely break, show encrypted data in the form of gibberish if stored in some ascii format like base64, undefined rendering behavior if stored in bytes (bad unicode chars).
This could be solved with an upgrade period during which people canât create encrypted documents, and once weâre confident thereâs very little old clients left, flip the feature on.
Feature support. Should we also disable dropbox/gdrive backups? Encrypted backups wonât be useful for most of the population who arenât able to implement the decryption algorithm to decrypt their backups. This is especially problematic for plaintext backups because item content and description are dumped into plaintext with newlines and tabs inserted. Same problem with google calendar sync.
Encrypted document creation. Do we allow âencryptingâ an existing document? If so, a lot of things needs to be taken care of, for example, concurrent modifications (i.e. what if a collaborator/other device made edits before you made the switch, but synced it after because that device didnât have internet access).
Synchronization. Weâll need to keep most of the item metadata unencrypted, and only encrypt the content and note fields. This is because the server needs to know item order (indices) to be able to merge new changes into the document.
If we were to keep everything decrypted on the client side, it means the user MUST enter the password when the document gets loaded into their client. Keeping it decrypted would save us the need to change the client code since we can transparently encrypt/decrypt when it syncs to the server, and the rest of the client code can just work the way it is right now. Downside of this is that a client must enter the password if an encrypted document is detected, or else the document will not even be kept locally (desktop/mobile client supporting offline mode especially). Also none of the cross-document features will work until it is decrypted, i.e. global search, tag pane, go to anywhere, link to any item, move to any item. I think itâs reasonable given the user didnât decrypt the document, just have to make extra sure things donât go haywire when the document isnât loaded.
The other option is to keep the document contents encrypted, and decrypt it in-place when the user enters the password (the first time in each user session). Weâd need to make sure all the client code doesnât âaccidentallyâ touch the encrypted data and come back with gibberish. This means things like global search, tag pane, etc. I donât really like this one.
Thatâs what I can think of right now. Pretty sure when implementation time arrives thereâs going to be loads of more issues to tackle.
Iâm not sure I understand the concern with the backups. If the backup process will encode (base64 or similar) the encrypted text as part of the process, then it can be easily restored later and doesnât risk getting mangled while in a plaintext format.
I think itâs fair to release this feature with the ability to create new encrypted documents and support converting existing documents later. Hopefully phasing this will help with the release time and effort for building the system.
Also, I fully expect to have to enter the password to decrypt a document each time it needs to be opened/edited and that searching would be restricted until that document is decrypted.
The backup process is not able to decrypt the content and note section of the item, because they are encrypted with a password not sent to the server. This means we would be putting the encrypted content in plain text, one after each other in the plaintext backup.
The OPML backup is more easily decrypted using an XML parser, but decrypting the plaintext backup would be more difficult and in my opinion, probably unnecessary.
Having encrypted OPML backups makes sense to me, users wishing to restore them simply import them back into Dynalist. Also, users who chose to encrypt their Dynalist definitely donât want unencrypted backups flying around anyways. As far as I know auto backups to Dropbox/Google drive are in OPML anyways? If you want a plain text backup you could do that manually from within the Dynalist client (the download backup option in the menu), and there the passphrase is available. Google calendar sync support would indeed break.
Easy solution: Encrypting a document duplicates it. Deleting any document must ensure that there is no trace left on the servers, i.e. delete version history, meta data, etc.
I think that is acceptable, the item content and note field is what might be sensitive.
I agree with this option in particular for its code re-usability potential. Treat all encrypted documents as non-existent until the user clicks an unlock button to enter their passphrase to unlock all encrypted documents.
@Shida@Erica is there a trello card for this already? Just want to bump this up again. I think the existing âpassword protected documentâ card will also give users a false sense of security. I would favor that if this is implemented it is proper client side encryption.
@Erica I would like to give my vote for this request on Trello, but cannot find a card. And I think that more Dynalist users would like to give their vote.
Can you please make a card for this so that we can vote?
Would love this feature as well. I put my life in this system, and one day youâll get pirated. Itâs not âifâ, itâs âwhenâ. It always happen.