-
-
Notifications
You must be signed in to change notification settings - Fork 5k
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
AWS S3 Synchronisation Error on iOS deivce #4810
Comments
Also experiencing this! |
Hey there, it looks like there has been no activity on this issue recently. Has the issue been fixed, or does it still require the community's attention? This issue may be closed if no further activity occurs. You may comment on the issue and I will leave it open. Thank you for your contributions. |
Switching from WebDav to S3 today I hit this. I've narrowed it down to files that were edited on iOS causing the problem. If you only create new files, and delete files on iOS sync will work, but once you edit a file it will throw the error. I've spent a few hours trying to debug it but still no dice. An error that seems to point to the root of the problem: Leonidas-from-XIV/node-xml2js#345 (it seems like the problem is related to XML format parsing.) The problem i'm struggling with now is trying to figure out is it bombing when attempting to read the edited file on the local device, or when it tries to send the file over the wire.
@laurent22 do you know on iOS which FileAPI drivers are being used? it doesn't appear to be I was able to generate that |
I just restarted my test env, and am now seeing more error logging so inching closer. Lemme look again tomorrow with fresh eyes! |
Thank you for your contribution! To attract the attention, I suggest you to start a new issue and post what you have found, thank you again! |
@zxkmm I'm gonna use this thread for now until I have a pull request to hopefully close this one out for good :D I have pinpointed the source of the error: joplin/packages/lib/file-api-driver-amazon-s3.js Lines 60 to 70 in 0765cf5
For some reason, this can sometimes returns an error, but also, a response:
So the code rejects, even though we actually have the response we expect. i hacked around this in my simulator by ignoring the error for now and syncing in the simulator works. I think upgrading the aws-sdk to https://github.com/aws/aws-sdk-js/blob/master/CHANGELOG.md#2723 will fix this, and I'm hoping to try that later today! EDIT: that version is way older than the current pinned version, so still trying to figure out a way to properly work around this. |
The plot continues to thicken. I now have a state where my joplin simulator generates an error attempting to read the head for this file above, but an abstracted test case using the same logic outside of joplin never generates an error. I'm also running the latest 2.94 branch of the aws-sdk. I'm thinking it's something related to aws-react-native and an assumption it's making. My gameplan is to try two things:
|
I have a branch built that just replaces the head s3 api call with the aws-sdk-v3-js library, and it works perfectly! I'm going to submit a pull request for the fix but we'll need Laurent's input to decide if we want to replace all of the s3 endpoints (now) or just this one, and migrate over time. |
Wow that’s amazing! Thank you so much! |
Did this get backed out, and is there another effort to fix? Still cannot sync from iOS via S3 driver. |
@spacemonkey -- There is a new MR now -- some merge conflicts but looking to get it sorted out. (I'm still affected by this as the MR creator so I'm motivated to fix 😛) #5312 |
Environment
Joplin version: 10.7.2 (Latest on iOS for now)
Platform: iOS
OS specifics: 14.4.1 on iPhone (Latest for now)
Steps to reproduce
“XMLParserError:Non-whitespace before first tag.
Line: 0
Column: 1
Char: S”。
Describe what you expected to happen
The notes seems fine in the first time that I synchronisation on iOS (This Error message appear when the synchronisation is almost finished) , but when this error appear, the synchronisation function is totally broken and noting can be synchronisation neither other platform---->iOS nor iOS-----> other platform.
The notes that I have, almost all notes is I manually added, and a few is I import form md files that I exported from Notion app.
I tried 10 times, even change the provider of the server and it can be resocced every time.
Logfile
The text was updated successfully, but these errors were encountered: