-
-
Notifications
You must be signed in to change notification settings - Fork 42
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
[Feature] Normalized VCARD contents? #157
Comments
I'd be open to this in general, but last time I tried a naive approach that didn't work. Some clients have a specific idea about the formatting of files, and will do normalisation themselves. If their formatting differs from what the server uses you can end up in this endless loop where the server and client both keep reformatting. Of course this issue also exists when there are two clients that keep reformatting files. Downside of normalizing is also in terms of overhead - a client that does an upload will have to then also pull down the newly reformatted file - i.e. it looks like somebody has changed the file after they uploaded. This is why I've taken the approach of rejecting invalid files but not modifying files that are uploaded. This is also consistent with the CalDAV/CardDAV/WebDAV specs. I'm open to the idea of optionally reformatting, if we can come up with a good way of doing so. |
I'm sorry that I don't know anything about the CardDav protocol, but what mechanism does a client base its decision to pull on? How does it know that what got stored is different to what it uploaded? Presumably some kind of hash or last-modification-date? What about normalizing what's stored in Git, but reporting to clients the last received or uploaded hash/date value? |
The clients regularly poll to see whether files have changed. There are different ways of doing this. Right now, in the most efficient mode the client provides a sync token. Xandikos simply relies on the Git tree and blob shas to determine whether things have changed since that token, without keeping any additional data - that's part of its power. Whenever those SHAs change, the contents have changed and that triggers a fetch from the clients. Keeping two sets of shas (and potentially two sets of files), one normalized and one not, will open another can of worms. It also will do the opposite of making it easier to debug what's going on, because now clients have a different version of the file for the same ETag (at least in terms of formatting) than the server. I think there is something to be said for (optionally) normalizing the files on the server, but that will have to involve also synchronising those changes to the clients. It's extra network overhead at the cost of more consistent files at the server side, essentially - and that may be a reasonable tradeoff in some cases. Let's see whether using the branch lock works per #156 Another option would be to normalize the output you're getting out of git repository before diffing, when analysing the history? |
Well I thought I'd worked out an alternative way to normalize using Git filters instead of hooks. In
And in
The above works fine for manual commits, but it seems xandikos (dulwich?) doesn't take the above configuration changes into account. So I guess I'm going to have to investigate |
Filters could potentially work here (though not currently supported), although they'd have the same effect as hooks in terms of interactions with clients when #516 is fixed. |
Each CardDAV client seems to have its own idea about how vcard files are formatted, for example:
This makes the Git diff history rather noisy and therefore hard to debug when investigating what clients are actually changing.
It would be ideal if xandikos (or some underlying library) would parse and format VCARD files before commit in a standard way. I.e:
This is perhaps a bit of a naive request as I don't know if modifying what the client provides affects synchronization....
The text was updated successfully, but these errors were encountered: