66bc911652
chore: fix typos found by codespell
2023-07-07 15:31:14 +02:00
91de6e001e
fix(GODT-2763): Missing Answered flag on Sync and Message Create
...
Ensure we are using the same flag conversion code for all IMAP updates.
2023-07-06 14:02:05 +02:00
7411073c08
feat(GODT-2759): Add prompt to download missing messages for analysis
...
This will download the missing messages into a temporary directory and
decrypt them along with the metadata so we can attempt analyze them once
submitted to see what is going wrong.
2023-07-06 14:02:05 +02:00
7d838375bb
feat(GODT-2759): CLI debug commands
...
Add debug commands to CLI to diagnose potential bride problems.
Currently we only have a command which validates whether the state of
all the mailboxes reported by IMAP matches what is currently available
on the proton servers.
2023-07-06 14:02:05 +02:00
f545f30ec0
fix(GODT-2774): only check telemetry availability for the current user.
2023-07-06 13:38:06 +02:00
40c48ba804
fix(GODT-2774): Add external context to telemetry tasks
...
This ensures they get cancelled if the parent context becomes invalid
2023-07-06 13:09:35 +02:00
eaa673c4e4
fix(GODT-2708): fix dimensions event format + handling of ReportClicked event.
2023-07-04 13:04:30 +02:00
cc17366c1c
fix(GODT-2578): Refresh literals appended to Sent folder
...
Whenever a message gets moved to the sent folder we should retrieve the
new literal in order to guarantee that, if another client modifies and
sends the message, we always see the latest version of the message and
not a previous state stored in the Gluon cache.
Includes the following Gluon MRs:
* https://github.com/ProtonMail/gluon/pull/374
* https://github.com/ProtonMail/gluon/pull/376
Includes the followin gpa MR:
https://github.com/ProtonMail/go-proton-api/pull/88
2023-07-04 10:39:07 +02:00
234554b459
feat(GODT-2709): Remove the config status file when user is removed.
2023-07-01 07:21:27 +02:00
238929c3ec
feat(GODT-2712): Feed config_status with user action while pending.
2023-06-30 09:43:26 +00:00
a55572e5b3
feat(GODT-2714): Set Configuration Status to Failure and send Recovery event when issue is solved.
2023-06-30 09:43:26 +00:00
098eb7cb7a
feat(GODT-2713): Send config_progress event once a day if the configuration is stucked in pending for more than a day.
2023-06-30 09:43:26 +00:00
68334e3bb8
feat(GODT-2711): Send config_abort event on User removal.
2023-06-30 09:43:26 +00:00
124231c3c7
feat(GODT-2710): Send config success on IMAP/SMTP connection..
2023-06-30 09:43:26 +00:00
f591af2cbd
feat(GODT-2716): Make Configuration Statistics persistent.
2023-06-30 09:43:26 +00:00
ff11d20d9c
feat(GODT-2709): Init Configuration status.
2023-06-30 09:43:26 +00:00
4352154b84
test: Force sync limits to minimum with env variable
...
Set `BRIDGE_SYNC_FORCE_MINIMUM_SPEC` as environment variable to force
all the sync limits to minimum spec.
This is enabled for windows builds.
2023-06-29 13:31:03 +02:00
b7a2371220
chore: Log failed message ids during sync
2023-06-22 11:05:36 +00:00
ab70e85f1c
fix(GODT-2653): Only log when err is not nil
2023-06-22 10:12:03 +02:00
12f9fb03c3
chore: Log errors on failed message Downloads
2023-06-07 16:38:57 +02:00
5c606aee73
chore: Fix linter errors
2023-06-05 13:48:56 +02:00
51315d5d2b
feat(GODT-2653): Log API error details on Message import and send
2023-06-05 13:21:04 +02:00
ade2fd9403
chore: Add error logs when messages fail to build during sync
2023-06-02 13:17:08 +02:00
84a771d9fe
fix(GODT-2437): Silence harmless report to sentry.
2023-05-24 17:18:56 +02:00
35f0e081a5
fix(GODT-2628): Attempt to fix closed channel panic on logout
...
It should not be possible to reach this state on purpose. But due to
scheduling and synchronization variances, it is possible in theory that
a UserDeathEvent can occur at the same time as the bridge is closing,
causing a call to `User.Close()` to be executed 2 times.
To avoid this in the future we just clear the map after all the channels
have been closed.
2023-05-17 11:54:02 +00:00
5fee2f707b
fix(GODT-2627): Properly handle recording of message with Bcc fields
...
Ensure the SMTP send recorder properly handles the recording of messages
which may have the same body hash but have different recipients. E.g.:
send the same message twice to 2 different users via Bcc.
The send recorder now maintains a list of send requests and waiting for
a message to be sent is done one the oldest of the messages.
2023-05-17 11:01:30 +02:00
d6304b087a
fix(GODT-2627): Fix crash on closed channel
...
See `TestSendHasher_DualAddDoesNotCauseCrash`'s comment for more
details.
2023-05-17 11:01:30 +02:00
d8ccc6c05d
fix(GODT-2626): Handle rare crash due to missing address update ch
...
Ensure that we can handle the rare case that can cause a crash if for
whichever reason we end up with an Address Delete and Message
Create/Update in the same event object.
2023-05-16 10:41:36 +02:00
4e3ad4f7fa
fix(GODT-2626): Server Events should not be merged.
...
d18e5932b28f83b201709a04fb7b8c6f74003574
Includes GPA bump: https://github.com/ProtonMail/go-proton-api/pull/80
2023-05-16 09:53:41 +02:00
98031d296e
Revert "fix(GODT-2588): Always perma-delete from Drafts/Trash"
...
This reverts commit f9a0c35daa .
2023-05-12 10:19:56 +02:00
0417e495ae
fix(GODT-2618): Crash when address does not have unlocked keyring
2023-05-09 08:31:28 +02:00
bda158d6c6
feat(GODT-2346): treat external address as disabled one.
2023-05-09 04:12:12 +00:00
a0db1645f2
fix(GODT-2614): Handle failed update during sync
...
The sync process was getting stuck since we never handled the case where
the update to Gluon failed. This caused the flush stage to exist, but
the sync process would continue until it eventually gets stuck due to
lack of progress.
2023-05-05 16:09:23 +02:00
b51d85e768
chore: upgraded golangci-lint v1.52.2 and fixed all issues.
2023-05-05 07:57:22 +02:00
543c35041d
fix(GODT-2464): Filter attachment name from content-type parameter to not send it twice to the API.
2023-05-02 07:13:21 +00:00
910060a14c
fix(GODT-2598): Map Message Size Error to Gluon Error
...
Prevents messages with invalid size from ending up in the recovery
mailbox.
2023-04-28 11:44:02 +02:00
fbbd0245de
feat(GODT-2569): Add functional test to validate community PR.
2023-04-27 12:21:48 +00:00
7002806999
feat(GODT-2569): Support multiple externalID matching if we send one of it when looking for parentID.
...
Change behavior of `getParentID`: when `getParentID` gets called on an
external ID and more than one message with that ID is found, inspect the
metadata flags and if only one of those messages is `MessageFlagSent`,
then choose that as the parent.
2023-04-27 12:21:48 +00:00
c49b42060e
chore(GODT-2576): Connector can send any flags to Gluon
...
Requires Gluon bump: https://github.com/ProtonMail/gluon/pull/344
2023-04-27 11:52:55 +02:00
d8fa2fb3e3
fix(GODT-2582): Update Gluon for updated GetMessageHash
...
This patch also update getMessageHash to use the fixed version in Gluon.
https://github.com/ProtonMail/gluon/pull/342
2023-04-26 14:53:38 +02:00
f9a0c35daa
fix(GODT-2588): Always perma-delete from Drafts/Trash
2023-04-25 13:49:05 +02:00
3ef3ab72ed
feat(GODT-2553): Try to send telemetry every hour.
2023-04-24 18:33:50 +00:00
b250d49af8
feat(GODT-2552): Send first heartbeat.
2023-04-24 18:33:50 +00:00
8093bbf5f6
feat(GODT-2502): Additional info.
2023-04-14 10:27:37 +02:00
7bb925b6d7
feat(GODT-2502): Improve logs.
2023-04-14 10:27:37 +02:00
3928ed08f6
feat(GODT-2554): Compute telemetry availability from API UserSettings.
2023-04-13 08:06:48 +00:00
7d51e9123d
chore: merge release/quebec to devel
2023-04-12 08:52:12 +02:00
098f294cac
fix(GODT-2573): Crash on null update
...
Ensure that if we don't produce an update we don't construct an update
array with nil values.
2023-04-11 10:36:26 +02:00
c84919faae
chore: merge release/Quebec into devel
2023-04-05 13:55:22 +02:00
7330406752
fix(GODT-2500): Recover in deferred function.
2023-04-05 09:25:24 +02:00