Mariusz Klochowicz
5650ab1ec5
Roll out xtra_productivity inside maker_inc_connections actor
3 years ago
Mariusz Klochowicz
ad4c2720bd
Use spawn_fallible inside maker_inc_connections to log errors
Preparation for removing log_error! macro from this actor.
3 years ago
Mariusz Klochowicz
0998661751
Prefer automatic links in docs
Automatic links (wrapped inside <>) are automatically turned into clickable
links when you generate documentation
3 years ago
Mariusz Klochowicz
8e2f3cfc95
Initialize Cfd actors outside of Rocket
Allows us to use `?` instead of unwrapping.
3 years ago
Philipp Hoenisch
0a51601a6d
Show cfd expiry in UI
3 years ago
Thomas Eizinger
d4ee08bd19
Remove all usages of `#[allow(dead_code)]`
This is a legacy from not having a library crate.
3 years ago
DelicioiusHair
8897754138
Added tests for matrix-solver
Added missing tests for `CSR::matrix_solve()` and fixed some
error handling in the process.
3 years ago
Mariusz Klochowicz
41e838df5e
Remove unnecessary async move
3 years ago
Mariusz Klochowicz
0238607464
Fix bug in fanning out messages to multiple actors in the maker
3 years ago
Lucas Soriano del Pino
c1381d5b14
Introduce taker ActorSystem
Co-authored-by: Mariusz Klochowicz <mariusz@klochowicz.com>
3 years ago
Daniel Karzel
c9c03b7c88
Don't fail in oracle attestation loop
3 years ago
Daniel Karzel
c798035402
Don't fail re-broadcasting tx loop
3 years ago
Daniel Karzel
dfc8b00ac7
Taker removes order from feed after cfd insert
We have a 1:1 relationship (and the fact that we don't remove cfds) between cfd and order at the moment, so once the cfd was inserted we cannot creat another cfd for the same order.
Thus, we should remove the order from the feel by sending `None`.
3 years ago
Daniel Karzel
79616e8036
Add guard to disallow adding cfd for same order
This should make this error more explicit and add understanding what goes wrong in the logs.
3 years ago
Thomas Eizinger
d18ee55146
Replace `expect` with `context` to avoid panics
3 years ago
Daniel Karzel
7b40667d4d
Macro to trace errors in loop and continue
3 years ago
Lucas Soriano del Pino
2bb8a7f592
Remove superfluous Send trait bound
The trait `xtra::MessageChannel` already implies Send.
Co-authored-by: Mariusz Klochowicz <mariusz@klochowicz.com>
3 years ago
Lucas Soriano del Pino
7d0b2374d1
Use more qualified syntax for tokio: ⌚ :Receiver
Co-authored-by: Mariusz Klochowicz <mariusz@klochowicz.com>
3 years ago
Lucas Soriano del Pino
f90dd1fa53
Convert tracing::error into anyhow::Error context
This prevents us from reporting an error when the transaction was
actually on-chain.
3 years ago
Thomas Eizinger
75cd6a1ea2
Fix precision of Usd and Percent to 2 decimal upon serialization
3 years ago
Thomas Eizinger
202c600ddc
Refer to correct ID when joining orders
3 years ago
Daniel Karzel
4f4e6133ac
Failing test
3 years ago
Thomas Eizinger
09172b2b5d
Make `OrderId` always represent as `Hyphenated` in DB
3 years ago
Thomas Eizinger
1a28131bf5
Properly shutdown DB connection before exit
3 years ago
Lucas Soriano del Pino
7cb3c4f2c7
Treat InvalidOrderId from maker as Rejected
If the maker tells the taker that the take request was for an invalid
order ID, we should do something other than panic. For example,
logging and treating the situation as if the maker had rejected the
take request.
3 years ago
Mariusz Klochowicz
5b615476a3
Test order and cfd insertion in the actor
Check whether after inserting order and the cfd the Cfd feed works as expected
3 years ago
Mariusz Klochowicz
df402180f2
Validate sqlx insertions
Check query results whether the affected rows match our expectations
3 years ago
Philipp Hoenisch
9497043478
Print git tag when starting maker/taker
3 years ago
Daniel Karzel
f5db38a724
Remove Todos in favour of tickets
https://github.com/comit-network/hermes/issues/369
https://github.com/comit-network/hermes/issues/368
3 years ago
Daniel Karzel
a328d43b74
Remove pending roll over proposal upon rejection
3 years ago
Thomas Eizinger
790eaaa4f4
Add timeouts to rollover messages
3 years ago
Thomas Eizinger
2e57f98a8b
Fix typo
3 years ago
Thomas Eizinger
c467155b71
Add timeouts to awaiting messages during contract setup
3 years ago
Thomas Eizinger
698c7b70b7
Add log statements to sections of contract-setup
3 years ago
Thomas Eizinger
932b0badf5
Remove stale TODO
3 years ago
Thomas Eizinger
38ee2b1d7c
Prefetch announcement upon proposing rollover
Fixes #361 .
3 years ago
Thomas Eizinger
3ad6eacdb1
Add log statement for completed roll over
3 years ago
Lucas Soriano del Pino
79c377a7b8
Introduce maker ActorSystem
3 years ago
Lucas Soriano del Pino
4b9dae8c7d
Make taker_cfd::Actor generic over other actor addresses
3 years ago
Lucas Soriano del Pino
20c76f6134
Use MessageChannel instead of send_to_socket::Actor
We depend on `luckysori/xtra` until
https://github.com/Restioson/xtra/pull/45 is released.
3 years ago
Thomas Eizinger
ac73ddf3a1
Embed correct frontend :face_palm:
3 years ago
Daniel Karzel
cbfb40186a
Notify monitor actor to watch for collaborative close tx
So far we only did this on startup, but not during the actual execution of the collaborative close.
3 years ago
DelicioiusHair
6d6c40436d
Fix up SQL queries
This PR does a few things:
* cleans up the SQL to make the queries clearer in terms of intent, as well as eliminating the use of an extra transaction in some write queries.
* adds some additional testing
* (mostly) eliminates the use of `serde_json::to_string()`, making the data columns behave in a more sane manner
3 years ago
Thomas Eizinger
6d033264e8
Fetch announcement in case it is not present but requested
This will make sure that if a user retries an operation, the
announcement is there.
3 years ago
Thomas Eizinger
fc2b5fe482
Sync with Olivia every 5 seconds
We are only making requests to Olivia that are absolutely necessary,
i.e. only fetch attestations when they are likely ready and only
fetch attestations that we definitely need.
As a result, we can trigger the sync much more frequent.
Fixes #349 .
3 years ago
Lucas Soriano del Pino
a2b2a04a3a
Make maker_cfd::Actor generic over other actor addresses
3 years ago
Lucas Soriano del Pino
05c1674ae3
Use MessageChannel in taker's post_cfd_action HTTP handler
3 years ago
Thomas Eizinger
7c8d5e110b
Don't expose panicking code paths to the user
An actor not being reachable is a bad internal state but it should
never lead to an actual panic.
3 years ago
Lucas Soriano del Pino
e2f926388a
Introduce taker_cfd::CfdAction enum
To reduce boilerplate and allow us to use an
`xtra::MessageChannel<taker_cfd::CfdAction>` in the (very near)
future.
3 years ago
Thomas Eizinger
d00ac5bfdd
Don't return plain-text errors to the user
3 years ago