Replies: 3 comments
-
Hi @JCKodel, (whoops, accidentally closed the issue - keyboard shortcuts) Have you considered DB-level filtering?
Not too clued up on your use case, so curious if this could work for you! -Kobie |
Beta Was this translation helpful? Give feedback.
-
Yes, I'm implementing that right now, but then I would duplicate any public tables (the ones that are synced without user info). Also, I could only write to the database once I have a user id, which can be challenging in some scenarios. Not perfect, but acceptable. |
Beta Was this translation helpful? Give feedback.
-
If the storage size of duplication becomes an issue, have you considered having a shared SQLite database that can be accessed by any user? Basically you'd have N+1 sqlite databases where N is the number of users on the device and the +1 is the shared database. It's possible to have multiple connections open in the same app at the same time. You could potentially also do your "userless writes" to this DB? |
Beta Was this translation helpful? Give feedback.
-
Scenario:
I have an app where some tables have shared data (no auth necessary for read) and some are user-dependent.
On the server, I'm using Hasura, and the insert, update, select and delete permissions are bound to my JWT token (actually, Firebase JWT token), so the user can only insert, update, read or delete its own data.
Problem:
[email protected] logs in. Then, he goes offline. Then, he saves or updates some data. Then, he goes offline. Then, he signs out.
Some hours later, [email protected] enables the wi-fi and logs in. It makes some changes and then, boom: PowerSync sync no longer works.
Why?
Because
PowerSyncBackendConnector
gets Zombie Steve Jobs auth token (because it is the user authenticated at the moment), but, when I ask PowerSync toconnect(connector: MyVersionOfPowerSyncBackendConnector)
,uploadData(PowerSyncDatabase database)
is called, butdb.getCrudBatch()
now contains data from both Bill Gates and Zombie Steve Jobs.The problem is: I cannot save that data to a secure server (such as Hasura with row permission by user id), because I'm trying to send data from Bill Gates, but my token is for Zombie Steve Jobs, and the whole mutation fails.
Worst yet: there is no half-
batch.complete()
: either all succeeds or all fail.Solution:
PowerSyncBackendConnector.uploadData
should have some configuration while callingdb.getCrudBatch()
, (same assync_rules.yaml
) sodb.getCrudBatch()
can fetch only the data that is possible to write at this moment (whereuser_id
iss.jobs.zombie.69
).Beta Was this translation helpful? Give feedback.
All reactions