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

Add OKX solver #93

Open
MartinquaXD opened this issue Dec 16, 2024 · 0 comments
Open

Add OKX solver #93

MartinquaXD opened this issue Dec 16, 2024 · 0 comments
Assignees

Comments

@MartinquaXD
Copy link
Contributor

There is a deal with OKX on the horizon which would require an integration with their API.
Given that they also have an endpoint that returns calldata for a given trade it should be mostly a matter of copy and pasting the structure of one of the existing solver (e.g. 1inch) and having DTOs specific to their endpoint (meaning DTOs tailor made for their request and response JSONs).

@mstrug mstrug self-assigned this Dec 17, 2024
@mstrug mstrug mentioned this issue Jan 9, 2025
mstrug added a commit that referenced this issue Jan 10, 2025
# Description
OKX dex integration.
See also dedicated issue: #93

# Changes
Added new `okx` modules in `dex`, `config` and `tests`.
Created dto basing on documentation:
https://www.okx.com/en-au/web3/build/docs/waas/dex-swap.

OKX requires signing of swap request, it is implemented in function:
`sign_request()`, basing on documentation:
https://www.okx.com/en-au/web3/build/docs/waas/rest-authentication#signature

Also implemented custom error handling function: `handle_api_error()`,
as OKX in error cases returns valid json http body which causes that
trait implementation from `RoundtripError` to `dto::Error` is not used.

## How to test
Created dedicated tests which uses http mocking and real endpoint tests
(ignored) which requires providing API credentials. If API credentials
are needed for running ignored test I can provide that.
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

No branches or pull requests

2 participants