-
Notifications
You must be signed in to change notification settings - Fork 585
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
Add option to exclude Realm file from iCloud backup #6922
Conversation
Realm welcomes all contributions! The only requirement we have is that, like many other projects, we need to have a Contributor License Agreement (CLA) in place before we can accept any external code. Our own CLA is a modified version of the Apache Software Foundation’s CLA. Our records show that CLA has not been signed by @danibonilha. Please submit your CLA electronically using our Google form so we can accept your submissions. After signing the CLA you can recheck this PR with a |
First of all. Thank you so much for picking this up - impressive stuff 💙!
This can be done through a PR to https://github.com/realm/realm-core and and updating to the submodule of this repo to point to the PR commit in realm-core. But, since this won't be generally supported by the other SDKs I would rather that we keep changes to this codebase. A possible alternative is suggested in this comment: #6922 (comment). If you really want this to be supported generally across SDKs, I'd say the logic calling into
I like this idea 👍 I agree this would make it more flexible.
Would it throw if you set it when it's already set? If not, I wouldn't be too worried of setting it while it's already set, as we'd expect it to be called once per app open.
Perhaps a |
c8215f0
to
c8952fd
Compare
Agreed, I've added a new implementation with a parameter
It does not throw, so I went ahead and update it to dynamically change based on the attribute
I've created this file, but also added a script to make it easier to test, I have created for me but I just figured it would be helpful to have it in this project Oh I also updated the |
Awesome! I assume you've already verified this fixes the issue in your own (or some test) app? |
c8952fd
to
a7cd1bf
Compare
Yes I have, it's working perfectly on my app:
@kraenhansen I'm having issues though running the android app, but it might be my environment or something, is there a check on the CI that builds the android sample app ? Since there's no implementation there, just having it the app building should be enough. |
I'll take the Android version for a spin tomorrow, before merging this and then CI will run on the merge commit on |
I reworded the note in the changelog and I ran the tests locally on Android, iOS and Node.js 👍 |
I'm seeing some compilation errors on Node.js for Windows that I need to resolve before releasing this 😕 Stay tuned. |
Could it be related maybe to using unnamed parameters on |
Sorry about the wait on this one. Unfortunately the idea of a generalized |
…cloud_backup` (#6927) * Avoid including realm core headers in platform.hpp * Add tests * Update contrib guide and script to reference integration tests * Add note in the changelog
* Add option to exclude Realm file from iCloud backup * Remove reference to deleted guide * Update changelog * Use better typedef * Add flag as param to scope feature to realmJS only * Update implementation to enable/disable icloud backup dynamically * Add guide and script to check excludeFromBackup attribute * Add missing requirement for android build * Update wording in CHANGELOG.md and adding an example --------- Co-authored-by: Kræn Hansen <[email protected]>
…cloud_backup` (#6927) * Avoid including realm core headers in platform.hpp * Add tests * Update contrib guide and script to reference integration tests * Add note in the changelog
* Add option to exclude Realm file from iCloud backup * Remove reference to deleted guide * Update changelog * Use better typedef * Add flag as param to scope feature to realmJS only * Update implementation to enable/disable icloud backup dynamically * Add guide and script to check excludeFromBackup attribute * Add missing requirement for android build * Update wording in CHANGELOG.md and adding an example --------- Co-authored-by: Kræn Hansen <[email protected]>
…cloud_backup` (#6927) * Avoid including realm core headers in platform.hpp * Add tests * Update contrib guide and script to reference integration tests * Add note in the changelog
What, How & Why?
This PR adds a flag on Realm Config to exclude realm files from iCloud backup and also removes a reference from a guide that has been deleted.
This closes #4139
Draft discussion
@kraenhansen I'm starting this as a draft to make sure I'm on the right path, and to align some things:
In order to add this flag, some changes are required on @realm/core, to basically add
exclude_from_icloud_backup
onspec.yml
andshared_realm.hpp
, how is that coordinated ?You mentioned testing might be tricky for this one, it's a bit concerning if it's too difficult because I might not have the bandwidth to do it, but I can give it a try if there are some really similar examples.
This implementation is enough to ENABLE excluding from backup, but it cannot be DISABLED once a realm file has been set with
excludedFromBackup
, since we are just checking fortrue
on the flag and then setting theNSURLIsExcludedFromBackupKey
key, there's no check to remove this key when the flag is false again. Which means that, if a realm file has been created withexcludeFromIcloudBackup=false
and then set toexcludeFromIcloudBackup=true
the file will be correctly excluded, but if the same file if set again toexcludeFromIcloudBackup=false
it will remain excluded. I see two ways to handle this:Particularly I don't think there's much usage of setting this flag dynamically, so i'd probably go with the first option since realm does provide an easy way to copy a file with different configs if needed, although the second one is more flexible, it might take longer to be done as I believe I'd need to always be checking if the files already have the excludedFromBackup key set.
Testing the fix
Generate the build files and test it on a sample react-native app on an IOS simulator, adding
excludeFromIcloudBackup: true
to the Realm configuration.To validate if the file has the exclude backup attribute, you need to check the files attributes with
xattr
on your terminal, in order to do so you need the path of realm files from the simulator Documents' folder, you can easily get that first by running:open `xcrun simctl get_app_container booted com.your.app.bundleId data`/Documents
This will open a Finder window with the files, you can just drag and drop it to the terminal after adding
xattr
if this command returns:
It means the file has been successfully marked as excluded from backup 🎉
if it returns nothing, it means the file has no attributes therefore is not excluded from backup.
☑️ ToDos
Compatibility
label is updated or copied from previous entryCOMPATIBILITY.md
package.json
s (if updating internal packages)Breaking
label has been applied or is not necessary@realm/devdocs
if documentation changes are needed