Skip to content
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

[Bug]: Syncing (shared) calendar misses some events #36644

Closed
6 of 9 tasks
Fjodor42 opened this issue Feb 9, 2023 · 48 comments · Fixed by #38639
Closed
6 of 9 tasks

[Bug]: Syncing (shared) calendar misses some events #36644

Fjodor42 opened this issue Feb 9, 2023 · 48 comments · Fixed by #38639
Labels
0. Needs triage Pending check for reproducibility or if it fits our roadmap 25-feedback bug feature: caldav Related to CalDAV internals

Comments

@Fjodor42
Copy link

Fjodor42 commented Feb 9, 2023

⚠️ This issue respects the following points: ⚠️

  • This is a bug, not a question or a configuration/webserver/proxy issue.
  • This issue is not already reported on Github (I've searched it).
  • Nextcloud Server is up to date. See Maintenance and Release Schedule for supported versions.
  • Nextcloud Server is running on 64bit capable CPU, PHP and OS.
  • I agree to follow Nextcloud's Code of Conduct.

Bug description

For a number of years, I have run my own NextCloud instance, on which I have renamed my user's default calendar to "Fælles Kalender" (Danish for Common Calendar), so my wife and I can both enter events into it, to update each other on events that affect us both.

Both of us sync from Android phones (via DAVX5 as recommended), and I have also been subscribed via Thunderbird on both my personal and my work computers.

As for the latter subscriptions, I used to just use the built-in CalDAV functionality, but have switched to the CalDAV connector for TbSync as per recommended, but to no avail of the problem described below.

For quite some time, we have experienced the unfortunate state of affairs that, seemingly at random, her updates from her Android phone will not show up in my sync'ed applications, vice versa, and sometimes previously sync'ed events seem to "go missing".

Due to lack of mental and chronological surplus, I have postponed looking further into this, but it cannot continue.

I have recently noticed that the events will typically be shown in the web view of the calendar, and will, typically, show up if I un- and resubscribe, leading me to believe that the problem does not lie in actually storing new events or alterations to existing events, but I am at a loss regarding how to even ascertain whether this is even a NextCloud problem, or a problem shared between CalDAV implementations of Thunderbird, TbSync and DAVX5.

Hence, initially, I am asking for help pinpointing where the problem lies, but have labeled is a bug, as the common denominator seem to be NextCloud, rather than the various clients.

Please advise

Steps to reproduce

  1. Have more than one user share a calendar
  2. Have them sync with multiple clients
  3. ???
  4. Events disappear

Expected behavior

Shared access to a calendar should mean that all participants, whatever their CalDAV client, should be able to create and alter events and have their events, or changes to such, be reflected to all participants, regardless of the CalDAV-compliant client software used to sync.

Installation method

Community Web installer on a VPS or web space

Operating system

Debian/Ubuntu

PHP engine version

PHP 8.0

Web server

Apache (supported)

Database engine version

PostgreSQL

Is this bug present after an update or on a fresh install?

None

Are you using the Nextcloud Server Encryption module?

Encryption is Disabled

What user-backends are you using?

  • Default user-backend (database)
  • LDAP/ Active Directory
  • SSO - SAML
  • Other

Configuration report

{
    "system": {
        "instanceid": "***REMOVED SENSITIVE VALUE***",
        "passwordsalt": "***REMOVED SENSITIVE VALUE***",
        "hashingCost": 10,
        "trusted_domains": [
            "nephele.molgaard.org"
        ],
        "datadirectory": "***REMOVED SENSITIVE VALUE***",
        "overwrite.cli.url": "https:\/\/nephele.molgaard.org",
        "version": "25.0.3.2",
        "dbtype": "pgsql",
        "dbhost": "***REMOVED SENSITIVE VALUE***",
        "dbname": "***REMOVED SENSITIVE VALUE***",
        "dbuser": "***REMOVED SENSITIVE VALUE***",
        "dbpassword": "***REMOVED SENSITIVE VALUE***",
        "dbtableprefix": "oc_",
        "logtimezone": "UTC",
        "installed": true,
        "mail_domain": "***REMOVED SENSITIVE VALUE***",
        "mail_from_address": "***REMOVED SENSITIVE VALUE***",
        "mail_smtpmode": "smtp",
        "filelocking.enabled": true,
        "memcache.local": "\\OC\\Memcache\\Redis",
        "redis": {
            "host": "***REMOVED SENSITIVE VALUE***",
            "port": 6379,
            "timeout": 0
        },
        "maintenance": false,
        "loglevel": 2,
        "logfile": "\/var\/log\/nextcloud\/nextcloud.log",
        "mail_smtphost": "***REMOVED SENSITIVE VALUE***",
        "mail_smtpport": "25",
        "trusted_proxies": "***REMOVED SENSITIVE VALUE***",
        "overwritehost": "nephele.molgaard.org",
        "overwriteprotocol": "https",
        "overwritecondaddr": "^195\\.201\\.133\\.130$",
        "enable_previews": true,
        "updatechecker": true,
        "htaccess.RewriteBase": "\/",
        "theme": "",
        "updater.release.channel": "stable",
        "app_install_overwrite": [
            "files_downloadactivity",
            "ojsxc",
            "calendar",
            "contacts",
            "spreed",
            "socialsharing_twitter",
            "bruteforcesettings",
            "socialsharing_facebook",
            "files_trackdownloads"
        ],
        "default_phone_region": "ISO 3166-2:DK",
        "secret": "***REMOVED SENSITIVE VALUE***"
    }
}

List of activated Apps

Enabled:
  - activity: 2.17.0
  - admin_audit: 1.15.0
  - bruteforcesettings: 2.5.0
  - calendar: 4.2.3
  - circles: 25.0.0
  - cloud_federation_api: 1.8.0
  - comments: 1.15.0
  - contacts: 5.1.0
  - contactsinteraction: 1.6.0
  - dashboard: 7.5.0
  - dav: 1.24.0
  - deck: 1.8.3
  - federatedfilesharing: 1.15.0
  - federation: 1.15.0
  - files: 1.20.1
  - files_downloadactivity: 1.15.0
  - files_external: 1.17.0
  - files_pdfviewer: 2.6.0
  - files_rightclick: 1.4.0
  - files_sharing: 1.17.0
  - files_trackdownloads: 1.11.0
  - files_trashbin: 1.15.0
  - files_versions: 1.18.0
  - firstrunwizard: 2.14.0
  - logreader: 2.10.0
  - lookup_server_connector: 1.13.0
  - nextcloud_announcements: 1.14.0
  - notifications: 2.13.1
  - oauth2: 1.13.0
  - password_policy: 1.15.0
  - photos: 2.0.1
  - privacy: 1.9.0
  - provisioning_api: 1.15.0
  - recommendations: 1.4.0
  - related_resources: 1.0.4
  - serverinfo: 1.15.0
  - settings: 1.7.0
  - sharebymail: 1.15.0
  - socialsharing_facebook: 2.5.0
  - socialsharing_twitter: 2.5.0
  - support: 1.8.0
  - survey_client: 1.13.0
  - systemtags: 1.15.0
  - text: 3.6.0
  - theming: 2.0.1
  - twofactor_backupcodes: 1.14.0
  - updatenotification: 1.15.0
  - user_status: 1.5.0
  - viewer: 1.9.0
  - weather_status: 1.5.0
  - workflowengine: 2.7.0
Disabled:
  - encryption: 2.10.0
  - ojsxc: 5.0.0
  - spreed: 15.0.3
  - suspicious_login: 4.2.1
  - twofactor_totp
  - user_ldap

Nextcloud Signing status

No errors have been found.

Nextcloud Logs

Irrelevant for now, I think, as I have not myself been able to find anything in the logs.

Please do advise as to changes to logging levels if relevant.

Additional info

No response

@Fjodor42 Fjodor42 added 0. Needs triage Pending check for reproducibility or if it fits our roadmap bug labels Feb 9, 2023
@gohrner
Copy link

gohrner commented Feb 21, 2023

Currently, Thunderbird will randomly hide / not show events from Nextcloud calendars.

I've no idea if it's a Thunderbird or a Nextcloud bug.

I reported that a while ago in the Thunderbird Bugzilla, unfortunately with no official reaction so far:

https://bugzilla.mozilla.org/show_bug.cgi?id=1795720

Currently, Nextcloud calendars in Thunderbird are basically unusable due to this. (Without exaggaration, you just never now if you have an appointment or not if you check the calendar view in Thunderbird.)

@Fjodor42
Copy link
Author

I will add that this holds both for syncing directly with Thunderbird, via TbSync and on our phones with DAVX5 - whether or not this is a result of Thunderbird shenanigans, though, I cannot say, but it might not be the case.

@gohrner
Copy link

gohrner commented Feb 22, 2023

@Fjodor42: Mh, I'm also using DAVx⁵ on my Android with the same Nextcloud calendars, and the Android calendar is flawlessly synced with Nextcloud.

It's only Thunderbird (using its built-in CalDAV support, I didn't try TBSync) which randomly hides many appointments / events in the synced calendars.

Can you describe exactly under which circumstances you're missing events / calendars on your phone?

@Fjodor42
Copy link
Author

Unfortunately, I cannot.

There seems to be a bias to what my wife puts into the calendar going missing, but this may very well just be a function of her being the one who puts in the most new events.

And, for the record, while Thunderbird has been set up on her computer, she mostly uses her phone anyway, which means DAVX5.

So, to recap the broad outline, it's DAVX5 on two devices, Thunderbird on 2 (three including my wife's), and a haze of hit-and-miss as to whether events stick, leading me to speculate that Nextcloud might also have a problem, but your trouble with Thunderbird certainly does lend credence to theories about that being the/a culprit.

@OliverBreuer
Copy link

I have a similar, probably the same problem:

In the last four weeks I had twice the problem that some calendar entries on shared calendars were not synced to phones.

Here is the information I have:

Setup:

  • self-hosted nextcloud (current version)
  • 3 android phones
  • syncing on the phones via davx5

first problem (about two weeks ago):

  • about 3-5 entries (probably more) were synced to one phone but not to the other two
  • new entries were synced normally
  • unsyncing the calendar on the phones and resyncing finally synced the missing entries

second problem (today):

  • 4 entries (probably more) were entered in the nextcloud calendar via browser
  • none of the three phones synced these entries
  • new entries were synced normally
  • exporting (in the nextcloud web app) the not-synced and a new synced entry showed no difference in the vcal-data other than in the expected properties (CREATED, DTSTAMP, LAST-MODIFIED, UID, DTSTART, DTEND, SUMMARY)
  • changing one of the not-synced entries via browser resulted in syncing this entry to the phones
  • unsyncing the calendar on the phones and resyncing finally synced all the missing entries

In both cases it looks like the entries weren't transferred in one incremental update. Of course, in the next incremental updates they weren't send because they didn't change. After changing one of the entries it was synced because it was included in the next incremental update.

Unfortunately I have no log of the original sync. So I don't now whether the first incremental update, where the entries should have been included, just missed these entries or whether this update was somehow aborted or whether something else went wrong.

If anyone has any idea what to try to reproduce this issue, I'm happy helping testing and gathering logs.

@gohrner
Copy link

gohrner commented Mar 6, 2023

@OliverBreuer: That's different from what I encounter - I'd assume it's a different problem and should be reported as a different bug (though not sure whether it's a Nextcloud bug or DavX5 then):

  • I also use DavX5 and have not detected even one missing event.
  • In my Thunderbird calendar, also events which were displayed suddenly disappear. It's also not only few events that disappear, but over the course of a day actually most of them for that day.

So there's not single eventy missing from the calendar, but basically the other way around - in the end, only a few events still show up in Thunderbird.

Maybe there's the same underlying cause, but I'm not sure... The observation described in the original bug description above more seems to match what I'm observing and less what you're experiencing...

@Fjodor42
Copy link
Author

Fjodor42 commented Mar 6, 2023

@gohrner , @OliverBreuer: As for the original bug description, being written by me, I would like to state that both of your observations seem to fit within what I tried to describe.

@flortsch
Copy link

flortsch commented May 23, 2023

I am experiencing the same issue across various clients (macOS/iOS, Thunderbird/Evolution, DavX5) since I upgraded to Nextcloud 26.0.1.

A client creates an event and this is synced to the Nextcloud server (the event appears in the Nextcloud calendar app). But the entries sometimes don't appear on some clients, even if I force refresh the calendar on the client. I can't tell whether the new entries are not synced to the clients or synced but simply not shown due to some other issue.

The issue occurs on shared calendars with different users and clients, but also on a single calendar with the same user and different clients. Unfortunately, I can't reproduce the issue reliably. Any guidance on how to debug this issue is highly welcome.

@Eskawotz
Copy link

Eskawotz commented May 31, 2023

I have the same problem as Flortsch since upgrading to Nextcloud 26. I too then reinstalled various instances from scratch, but the problem remains the same.
I was able to figure out that only entries are not synced with another client if the creation of the entry is older than 12 hours.
It ALWAYS works if I, for example, create a new entry with the iPhone and start Thunderbird right after or Thunderbird is running during the creation.
So the problem occurs if I e.g. create an entry with the iPhone and Thunderbird is not running on Windows/Linux and start it12 hours later. Then this entry is not synchronized, although I can see it in the Nextcloud Calendar app.

@ckroenicke
Copy link

We have the same problem as flortsch too. Nextcloud 26 with shared calendars synced with various clients (Thunderbird, DAVx5).
Sometimes an event created on one client is correctly synced to Nextcloud but then only to some of the other clients.
Or an event that was correctly synced to all clients gets changed on one of the clients but the change will not appear on some of the others. I don't think we experienced disappearing events though.

@Eskawotz: I'll check whether I can reproduce the bug when waiting 12 hours until I reopen my Thunderbird after I created a new event/updated an existing one on another client. I'll report back what happend.

@Eskawotz
Copy link

Eskawotz commented Jun 2, 2023

One more comment on that bug:
After upgrading from nextcloud25 to nextcloud26 it was very fuzzy with that error, as mobile devices are always online and do the sync regularly which doesn't run into that error. I guess that is the reason why so less info can be found regarding this issue.

But now I figured out something out, which makes it even more weird:
I deleted the account in Thunderbird and added it again and voila:
All events have being synced!

But the general issue remains.

I made a rollback to Nextcloud25, cause this is such a nasty issue.

@ckroenicke
Copy link

Here the result of my test:
I closed my Thunderbird so it could not syncronize and then added an event and updated an existing one. Then I waited more then 24 hours before starting Thunderbird and syncronizing the calendar.

I then started to look into the source code to get an idea what change could have caused that behavior.
I found out that last october a background job was added that once a day prunes the list of sync tokens which are used to identify the (calendar) changes that need to be synced (see 6f15873). Maybe this has something to do with the strange behavior?

@flortsch
Copy link

flortsch commented Jun 4, 2023

I also thought that this prune job could be related to this issue, but the job should keep an amount of change objects in the db (10k per default) when pruning (which should be more than enough for small instances). You could test if disabling cronjobs fixes your issue.

I have upgraded my instance to 26.0.2 and will report if I still face this issue. Also will check out if this happens after the 12h of not syncing clients.

@charno
Copy link
Contributor

charno commented Jun 4, 2023

Thanks for analyzing! This bug drives me crazy since forever, and I always suspected thunderbird since no events are missing on my mobile. But the mobile syncs every hour, so...

@Eskawotz : An easier workaround (instead of deleting / readding) is to disable offline support in the thunderbird calendar, save, re-enable, save. Then all events are re-synced as well.

@ckroenicke @flortsch If I understand your comments correctly, then at least the last 10k change objects should still be present in the table oc_calendarchanges? That's clearly not the case in my installation... (And my calendar is huge, with daily changes since years, check the ID). The only change that is present is from today (the URI seems to contain a unix timestamp from today). So maybe there is a bug in this prune job which prevents keeping the last 10k changes?

MariaDB [nextcloud]> select * from oc_calendarchanges;
+-------+---------------------+-----------+------------+-----------+--------------+
| id    | uri                 | synctoken | calendarid | operation | calendartype |
+-------+---------------------+-----------+------------+-----------+--------------+
| 35573 | 1685887586.R976.ics |     19950 |          2 |         1 |            0 |
+-------+---------------------+-----------+------------+-----------+--------------+
1 row in set (0.001 sec)

@Eskawotz
Copy link

Eskawotz commented Jun 4, 2023

I have also upgraded to 26.0.2 (another test-instance, productive is 25!) and it still has that issue.

@charno: Thank you for that hint!
Just to understand:
@flortsch: you would recommend to stop the cron-job? I can try and check whether the issue remains!
My test instance is only one admin and a user with which this problem occurs. I doubt this entry has to do with it (10000 is a huge number)

@flortsch
Copy link

flortsch commented Jun 4, 2023

Okay, so I tested the prune job on my instance. I updated a calendar event on my Evolution client, synced it with Nextcloud which resulted in a new row in the oc_calendarchanges table and manually triggered the prune job (I did this by reducing the time interval in apps/dav/lib/BackgroundJob/PruneOutdatedSyncTokensJob.php to a few seconds instead of one day and run php cron.php to trigger the job).

Indeed, the job did not keep the row and cleared the whole table! Looking at the code it seems to me that an SQL delete statement with a offset parameter is created that might not be supported on all DB types (running MariaDB here).

However, I don't fully understand the impact of these missing rows in the oc_calendarchanges table and whether this could lead to missing event updates. Because I fired up my second client (Android Dav5x) after I executed the prune job that cleared my table, and the Dav5x client still synced the event update (maybe pressing the sync button in Dav5x triggers a full re-sync?).

@flortsch
Copy link

flortsch commented Jun 4, 2023

@Eskawotz Yeah, it seems to me that the prune job code is buggy. It did not keep any rows and wiped my oc_calendarchanges table. However, my second client (Dav5x) still synced my updated calendar event (maybe pressing the sync button in Dav5x triggers a full re-sync?). But it might be worth disabling this job and checking if this fixes sync issues on other types of clients (like iOS/MacOS, Thunderbird, etc.).

@flortsch
Copy link

flortsch commented Jun 4, 2023

The easiest way to disable this job without globally disabling cron for me seems to just comment all the code in the run function of apps/dav/lib/BackgroundJob/PruneOutdatedSyncTokensJob.php.

        public function run($argument) {
//              $limit = max(1, (int) $this->config->getAppValue(Application::APP_ID, 'totalNumberOfSyncTokensToKeep', '10000'));
//
//              $prunedCalendarSyncTokens = $this->calDavBackend->pruneOutdatedSyncTokens($limit);
//              $prunedAddressBookSyncTokens = $this->cardDavBackend->pruneOutdatedSyncTokens($limit);
//
//              $this->logger->info('Pruned {calendarSyncTokensNumber} calendar sync tokens and {addressBooksSyncTokensNumber} address book sync tokens', [
//                      'calendarSyncTokensNumber' => $prunedCalendarSyncTokens,
//                      'addressBooksSyncTokensNumber' => $prunedAddressBookSyncTokens
//              ]);
        }

@ckroenicke
Copy link

I forgot to add that we also use Nextcloud (26.0.2) with a MariaDB (10.3.32).
We disabled the code in PruneOutdatedSyncTokensJob.php as suggested by @flortsch and will see tomorrow whether that fixes the issue for the moment.

@Eskawotz
Copy link

Eskawotz commented Jun 4, 2023

I have commented out as well and will check.. I will let you know!
Thank you.....

@flortsch
Copy link

flortsch commented Jun 4, 2023

For completeness, I digged deeper into the code, especially CalDavBackend.php#getChangesForCalendar. Missing rows in oc_calendarchanges will definitely affect clients that request calendar changes with a given sync token. They simply won't get any updates. I also enabled SQL debugging in my MariaDB database to see what SQL statement the prune job executes, it simply is DELETE FROM oc_calendarchanges, i.e., it will delete all rows in the table no matter what. Since the prune job also calls a prune routine in the CardDavBackend that uses a similar DELETE statement, this should also be an issue when synchronizing contact updates. I will report both in a new issue and maybe also provide a fix for the SQL statement.

@charno
Copy link
Contributor

charno commented Jun 4, 2023

@flortsch I'm also on it, already have the dev environment setup.

The vscode devcontainer setup uses postgre, and the error is present there as well.

@charno
Copy link
Contributor

charno commented Jun 4, 2023

Hmm... Doesn't seem to easy a bug:

    private function getSQLForDelete(): string
    {
        $table = $this->sqlParts['from']['table']
            . ($this->sqlParts['from']['alias'] ? ' ' . $this->sqlParts['from']['alias'] : '');

        return 'DELETE FROM ' . $table
            . ($this->sqlParts['where'] !== null ? ' WHERE ' . ((string) $this->sqlParts['where']) : '');
    }

vs.

    private function getSQLForSelect(): string
    {
        $query = 'SELECT ' . ($this->sqlParts['distinct'] ? 'DISTINCT ' : '') .
                  implode(', ', $this->sqlParts['select']);

        $query .= ($this->sqlParts['from'] ? ' FROM ' . implode(', ', $this->getFromClauses()) : '')
            . ($this->sqlParts['where'] !== null ? ' WHERE ' . ((string) $this->sqlParts['where']) : '')
            . ($this->sqlParts['groupBy'] ? ' GROUP BY ' . implode(', ', $this->sqlParts['groupBy']) : '')
            . ($this->sqlParts['having'] !== null ? ' HAVING ' . ((string) $this->sqlParts['having']) : '')
            . ($this->sqlParts['orderBy'] ? ' ORDER BY ' . implode(', ', $this->sqlParts['orderBy']) : '');

        if ($this->isLimitQuery()) {
            return $this->connection->getDatabasePlatform()->modifyLimitQuery(
                $query,
                $this->maxResults,
                $this->firstResult
            );
        }

        return $query;
    }

The query builder seems to not honor setFirstResult for delete queries... And the query builder is external (doctrine/dbal)

@charno
Copy link
Contributor

charno commented Jun 4, 2023

@charno
Copy link
Contributor

charno commented Jun 4, 2023

Pull request #38639 opened. Hoping for fast merge :-)

@flortsch
Copy link

flortsch commented Jun 5, 2023

Nice! Thanks @charno for fixing the code and creating the PR :) Hoping for fast merge!

@flortsch
Copy link

flortsch commented Jun 17, 2023

The prune job has an interval set of one day, so it is only triggered by cron.php when the time diff between the last prune job and cron.php execution is >= 1 day.

Also, some clients seem to sync calenders/contacts differently, not using sync tokens but doing a full sync I guess (e.g. I could still sync calendar changes with Dav5x, although my oc_calendarchanges table was wiped by the prune job). In this case, an empty oc_calendarchanges table has no effect.

@gohrner
Copy link

gohrner commented Jun 20, 2023

@st3iny : Are you sure that #38639 fixes this bug? @charno's patch was for NC 26 or later, while the bug was already reported against NC 25, and I also observed it in NC 24.

@st3iny
Copy link
Member

st3iny commented Jun 20, 2023

@gohrner I'll test the backport to stable25 assuming that it is the same bug. If not, I'll reopen the issue.

tcitworld pushed a commit that referenced this issue Jun 21, 2023
pruneOutdatedSyncTokens accidentally deletes all entries of the calendarchanges table
instead of leaving $limit elements in the table

Signed-off-by: Christof Arnosti <[email protected]>
tcitworld pushed a commit that referenced this issue Jun 21, 2023
Signed-off-by: Christof Arnosti <[email protected]>
tcitworld pushed a commit that referenced this issue Jun 21, 2023
pruneOutdatedSyncTokens accidentally deletes all entries of the calendarchanges table
instead of leaving $limit elements in the table

Signed-off-by: Christof Arnosti <[email protected]>
tcitworld pushed a commit that referenced this issue Jun 21, 2023
Signed-off-by: Christof Arnosti <[email protected]>
@st3iny
Copy link
Member

st3iny commented Jun 21, 2023

The linked PR does not fix this issue for 25 and below so there is another unknown bug. Reopening this issue until it's fixed.

@st3iny st3iny reopened this Jun 21, 2023
@st3iny st3iny added the feature: caldav Related to CalDAV internals label Jun 21, 2023
@Eskawotz
Copy link

This bug has been definitively introduced with version 26.
I was able to reproduce it in a clean installation
That's why I then used my backup to rollback to 25
which works fine again

@gannick
Copy link

gannick commented Jun 26, 2023

I have a NC 26.0.3 self-hosted, with a shared calendar between my NC acount and my wife account. We user DavX5 to synchronize caldenars on Android. Event are not shared anymore. If I create an event, she doesn't see it. If she creates an event, I cannot see it.

That is pretty annoying. Does a patch will come, or may I tried to patch by myself as explained above ?

@flortsch
Copy link

flortsch commented Jul 2, 2023

You would have to apply the patch manually, it didn't make it into 26.0.3.

@tcitworld
Copy link
Member

Patch is scheduled for 26.0.4 #38920

st3iny pushed a commit that referenced this issue Jul 4, 2023
pruneOutdatedSyncTokens accidentally deletes all entries of the calendarchanges table
instead of leaving $limit elements in the table

Signed-off-by: Christof Arnosti <[email protected]>
st3iny pushed a commit that referenced this issue Jul 4, 2023
Signed-off-by: Christof Arnosti <[email protected]>
@zero0cool0
Copy link
Contributor

zero0cool0 commented Jul 20, 2023

For completeness, I'd would like to point out that despite patch #38920, if you have a subscribed calendar source containing many VEVENTS (like I have) the calendarchanges table can still fill up relatively quickly and reach the $keep number.

As far as I can see, the RefreshWebcalService does not check if a calendar object of a subscribed calendar is already presented and unchanged, therefore limiting the number of additions to calendarchanges.

As per the RFC, UID and DTSTAMP are mandatory fields and could therefore be used for this.

Also, on a related note, I believe there is a minor bug in the initial lines of CalDavBackend.php#getChangesForCalendar as it does not always select the proper table when fetching the current synctoken. It should respect $calendarType and select either calendars or calendarsubscriptions.

@lalbornoz
Copy link

lalbornoz commented Oct 5, 2023

I'd just like to point out that I have the same exact issue w/ Thunderbird v115.3.1, DAVx5, and Xandikos (a CalDAV server.) Seems more like a Thunderbird issue that never got fixed.
edit: sorry, Xandikos not Radicale.

@flortsch
Copy link

For completeness, I'd would like to point out that despite patch #38920, if you have a subscribed calendar source containing many VEVENTS (like I have) the calendarchanges table can still fill up relatively quickly and reach the $keep number.

As far as I can see, the RefreshWebcalService does not check if a calendar object of a subscribed calendar is already presented and unchanged, therefore limiting the number of additions to calendarchanges.

As per the RFC, UID and DTSTAMP are mandatory fields and could therefore be used for this.

Also, on a related note, I believe there is a minor bug in the initial lines of CalDavBackend.php#getChangesForCalendar as it does not always select the proper table when fetching the current synctoken. It should respect $calendarType and select either calendars or calendarsubscriptions.

Did you investigate further? I am not familiar with the code base in general, but I also think that expiring sync tokens simply by pruning all expect the last $keep (which is 10000) could still lead to issues. Maybe it can be better handled by expiring sync tokens by date and specific duration (e.g. 1 month), comparing the current sync token of a client (I guess this is send to the server?) with the last sync token in the database, and somehow force a full-resync if the gap in time is to big, instead of simply pruning the tokens and pretending no changes happened to the calendar.

@kordejong
Copy link

I am using NextCloud 28.0.1 and am experiencing similar issues as the original poster. I use current iOS clients, Thunderbird 115.6.0, NC 28.0.1. Newly created calendar items don't always get shared between all clients. The only solution that works for me is to remove and re-add the account on clients (iOS, Thunderbird). All appointments are correctly visible in the NC calendar webinterface. In my case #38639 did not fix the issue.
In previous versions of NC (probably <= 25) everything worked fine.
Any hints to fix this issue are very much appreciated. For some time I have been hoping NC updates would fix it, but they didn't unfortunately. I am happy to provide more info if that is useful.

@ChristophWurst
Copy link
Member

Did you investigate further? I am not familiar with the code base in general, but I also think that expiring sync tokens simply by pruning all expect the last $keep (which is 10000) could still lead to issues. Maybe it can be better handled by expiring sync tokens by date and specific duration (e.g. 1 month),

#44075

@ChristophWurst
Copy link
Member

We might be able to detect when our sync tokens do not have all the data since the client's last sync: #44126. Unfortunately, at least Thunderbird doesn't handle the special condition.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
0. Needs triage Pending check for reproducibility or if it fits our roadmap 25-feedback bug feature: caldav Related to CalDAV internals
Projects
None yet
Development

Successfully merging a pull request may close this issue.