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

Real-time Sync: Add persistency layer #555

Merged
merged 7 commits into from
Dec 5, 2024
Merged

Real-time Sync: Add persistency layer #555

merged 7 commits into from
Dec 5, 2024

Conversation

hydra-yse
Copy link
Member

Closes #501.

We ensure that the prost-generated files match those which have been
committed
@hydra-yse hydra-yse self-assigned this Nov 10, 2024
@hydra-yse hydra-yse changed the base branch from main to rt-sync November 10, 2024 02:01
lib/core/src/persist/migrations.rs Outdated Show resolved Hide resolved
lib/core/src/persist/migrations.rs Outdated Show resolved Hide resolved
lib/core/src/persist/sync.rs Outdated Show resolved Hide resolved
lib/core/src/sync/model/mod.rs Outdated Show resolved Hide resolved
lib/core/src/persist/migrations.rs Outdated Show resolved Hide resolved
lib/core/src/persist/sync.rs Outdated Show resolved Hide resolved
@hydra-yse hydra-yse requested a review from roeierez November 11, 2024 23:36
@hydra-yse hydra-yse force-pushed the yse-rt-persist branch 7 times, most recently from 0c56f34 to 25e3d8e Compare November 14, 2024 18:09
@hydra-yse hydra-yse force-pushed the yse-rt-persist branch 4 times, most recently from c2d2f82 to 8fce375 Compare November 18, 2024 02:20
@hydra-yse hydra-yse force-pushed the yse-rt-persist branch 3 times, most recently from eb0400b to be3091d Compare November 20, 2024 22:38
Copy link
Collaborator

@dangeross dangeross left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry for the late review

lib/core/src/persist/sync.rs Show resolved Hide resolved
lib/core/src/persist/sync.rs Show resolved Hide resolved
lib/core/src/persist/sync.rs Show resolved Hide resolved
lib/core/src/persist/sync.rs Outdated Show resolved Hide resolved
Copy link
Collaborator

@dangeross dangeross left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ACK, needs cargo fmt

:description,
:state
)",
[params, &[(":state", &PaymentState::Created)]]
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I see that when restoring the app (data is already pushed to sync server), the SDK pulls in the swap data and because it's in initially the Created state these swaps are then tracked in the swap update loop (see attached logs). Should we consider adding a state to mark that the swap needs recovering without adding it to the update loop?

1733127914391.app.log

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We have is_local on the swaps. The main question is do we need to exclude them totally from the update loop (and only count on the onchain data) or should we add them to the update loop but without initiating transactions (claim). What do you think?

Copy link
Member Author

@hydra-yse hydra-yse Dec 2, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Currently they are considered in the update loop (as Roei said using is_local from the sync_state table) so state updates are pushed outwards (and merged if necessary), then with either Boltz status/restore they're set to the right final state. May be unnecessary to push outwards and let each instance settle its own final state.

Regarding claiming, I think there was discussion about only letting the initiator broadcast. I think it's the only non-racy way to do it (since the claim checks I've added assume the chain service already has the other instance's tx indexed, which may or may not be true in some edge cases), so if this mitigation is not enough I agree we should just stick to the easy approach.

Thinking of the frequency at which this may happen, the scenario would be if the sync-out and sync-in between clients happens very quickly, so that they both receive the Boltz lockup status update at the same time and try claiming simultaneously. Not that uncommon if you ask me, so I'm inclined to the easier approach too.

Another idea could also be to maybe track the claims for a few confirmations to see whether the claim info actually matches, that way if two instances claim we can still settle on which one got confirmed (via script history), but I think that may just be unnecessary overhead, let me know what you think.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm wondering if we first set them to a Recover state, then after the recovery/chain sync if the swap is ongoing then add it the the update loop for tracking.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we should start simple means:

  1. Not claiming if it is not a local swap
  2. We can still track all swaps in the swapper web socket loop
  3. We can let the recover run as currently in its own interval. @dangeross comment is valid IMO and it would be nice to run the swaps retrieved from the sync through the recovery process before persisting them.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Best way I see of going about that is to persist them instantly anyway, but as Ross mentioned with a Recovered/new state that allows them to be tracked explicitly. It's also easier to debug what's happening that way

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

From testing I think Recover state is helpful. The SDK is behaving differently depending if the rt-sync pull is completed before we start to track swaps. The Recover state will also allow us to start tracking the swap if needed.

I also see an issue sometimes with the initial chain sync from a fresh state, if the rt-sync pulls after the first chain sync, where the SDK events are suppressed, in the next chain sync all the pulled rt-sync swaps events are emitted.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good points @hydra-yse as Ross mentioned let's add the recovery to the sync in pipeline just before persisting the swaps. Results will be more predictable this way and we will avoid weird behaviors.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Done in 79b3d8d

@hydra-yse hydra-yse merged commit f820436 into rt-sync Dec 5, 2024
2 of 9 checks passed
hydra-yse added a commit that referenced this pull request Dec 5, 2024
hydra-yse added a commit that referenced this pull request Dec 11, 2024
hydra-yse added a commit that referenced this pull request Dec 13, 2024
hydra-yse added a commit that referenced this pull request Dec 14, 2024
hydra-yse added a commit that referenced this pull request Dec 24, 2024
hydra-yse added a commit that referenced this pull request Dec 24, 2024
* feat(rt-sync): add persistency layer (#555)

* feat(rt-sync): add pull and merge (#556)

* feat(rt-sync): add push logic and run method (#568)

* feat(rt-sync): integrate rt-sync with the sdk

fix: add formatting command to build

feat: add secondary trigger to sync

deps: add tonic tls-webpki-roots

feat: prevent double claiming on status stream handlers

fix: add tx commit to chain swap update (#588)

fix: ensure we pull records before prepare_send

fix: fmt and tests

* fix: set initial pulled state to `Recoverable`

* feat(rt-sync): add `last_derivation_index` to sync service

* Single chain source

* Handle Recoverable state

* fix(rt-sync): chain recovery integration (#590)

Co-authored-by: yse <[email protected]>

* feat(rt-sync): add `pair_fees_json`

* fix(rt-sync): clean already persisted incoming records

* feat: cache wallet info (#591)

* log: add status-stream logging for non-local swaps

* Sync improvements (#598)

* Full sync on new Bitcoin block

* Track the last unconfirmed refund tx

* Trigger synced event on partial sync

* fix: remove `REPLACE` clause from swap insert/update

* fix(rt-sync): update chain swap payer/receiver amount (#604)

* Fix syncing last derivation index

* fix: update bindings and lockfile

* remove logs

* fix(rt-sync): avoid reuse of derivation index update logic (#608)

* Add 5 index buffer to full scan

* Fix storing claim_address (#609)

* Filter incoming MRH txs by swap timestamp

* fix liquid panding timestamp

* persist tx data timestamp

* Update unconfirmed transactions

* feat: add API key (#618)

* Use configured lazy connect channel in sync service

* fix: set lower-case header (#624)

* fix error message

* Store & Sync LNURL info (#617)

* Persist and decrypt LNURL info

* Update Notification Plugin

* Sync payment details

* Update list payments to include chain swaps with only user lockup (#620)

* Update payments query to include chain swaps without txs

* Allow emitting a payment event without tx_id

* fix: bindings

---------

Co-authored-by: Ross Savage <[email protected]>
Co-authored-by: Ross Savage <[email protected]>
Co-authored-by: Roei Erez <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Real-time Sync: Add database structures and persistency layer
3 participants