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
Lucas Soriano del Pino
1dbe127db9
Use MessageChannel in post_order_request HTTP handler
3 years ago
Thomas Eizinger
443e206a0b
Remove unused tempfile dependency
3 years ago
Thomas Eizinger
907f6b97f6
Run tests against in-memory DB
This prevents left-over temporary files on the system.
3 years ago
Thomas Eizinger
296be594a4
Add test for a variety of state updates
Co-authored-by: DelicioiusHair <mshepit@gmail.com>
3 years ago
Thomas Eizinger
bfabf0c7b1
Make it less verbose to construct simple states
3 years ago
Thomas Eizinger
44e62cff29
Reduce boilerplate in constructing `CfdStateCommon`
3 years ago
Thomas Eizinger
ca93714746
Refactor `insert_new_cfd_state_by_order_id` to `append_cfd_state`
We almost always have the entire `Cfd` available when we call this
function. It is therefore much easier to simply pass the entire
`Cfd` in instead of selective data.
3 years ago
Thomas Eizinger
8d72104641
Make DB tests more readable by reducing boilerplate
3 years ago
Thomas Eizinger
9c3ef98965
Use pretty assertions
3 years ago
Thomas Eizinger
b5dd3d0caa
Take `Cfd` by reference if we don't need to consume it
3 years ago
Thomas Eizinger
18d5506f46
Don't use Default for test instance
3 years ago
Thomas Eizinger
ed63d595f3
Directly return `PoolConnection`
Saves us a line of code in every test!
3 years ago
Daniel Karzel
b47d91ad6e
Extend DB test suite
3 years ago
Thomas Eizinger
8c8cbe759c
Close connections with takers that don't adhere to the message format
3 years ago
Thomas Eizinger
414d520afd
Introduce dedicated actor for forwarding only `Ok` messages
3 years ago
Daniel Karzel
7355c339a6
Remove todo in favour of warning for awareness
Better log a warning, the assumption is that we rarely see this. Let's see if that is true.
3 years ago
Daniel Karzel
0d9cf7df85
Always cleanup order upon rejection
Upon rejection, we always have to remove the order on the maker side, otherwise a taker cannot re-try taking (with e.g. a different amount) because there is already a rejected cfd in the taker database.
3 years ago
Lucas Soriano del Pino
1342db80b1
Use MessageChannel in post_cfd_action HTTP handler
3 years ago
Lucas Soriano del Pino
f393e42113
Introduce maker_cfd::CfdAction enum
To reduce boilerplate and allow us to use an
`xtra::MessageChannel<maker_cfd::CfdAction>` in the (very near)
future.
3 years ago
Thomas Eizinger
237f4c25bf
Revert "Db refactor"
3 years ago
Lucas Soriano del Pino
3d9601e665
Use MessageChannel in post_sell_order HTTP handler
3 years ago
Mariusz Klochowicz
3730cfae36
Reduce code duplication in cfd actors
Extract shared handlers code into a common module
3 years ago
Philipp Hoenisch
e1206d38f0
Provide margin of counterparty
3 years ago
Lucas Soriano del Pino
370d40f0c2
Use MessageChannels in maker_inc_connections::Actor
We would have liked to attach the stream of `TakerStreamMessage`s
directly to the `MessageChannel`, but we failed and instead decided to
let the `maker_inc_connections::Actor` send these messages to itself
and then forward them to the `maker_cfd::Actor`.
3 years ago
Philipp Hoenisch
6b116bfdbd
Log details if order was rejected
3 years ago
Philipp Hoenisch
2cc2822075
Set default log level for whole crate
3 years ago
Mariusz Klochowicz
6779486f76
Create wrapper functions to avoid the need for manually refreshing feed
Inserting cfd or updating its state requires a follow-up update on the Cfd feed
sent to the UI. Encapsulate the behaviour in functions that are shared
across Cfd actors.
3 years ago
Mariusz Klochowicz
dc0abb92d3
Remove stale TODO
The Payout enum got implemented
3 years ago
Philipp Hoenisch
535e238d52
Add hard boundaries to take order request
If an order request is not in between min and max it will automatically be rejected.
3 years ago
Daniel Karzel
dce6eb3c3d
Remove Todo because we already have a ticket
Todo already tracked here:
https://github.com/comit-network/hermes/issues/278
3 years ago