📣 NOTE: This section is still heavily subjected to changes, and we are open to suggestions or feedbacks on ways to improve and streamline the integration. If you are interested in being a MM on Jupiter RFQ, please read the below toolkit and reach out to Soju / Ben on Telegram to register your webhook.
The RFQ functionality depends on the mainnet deployment of the Order Engine Program for order fulfillment.
- Source Code: The program's source is located in the
programs/order-engine
directory. - IDL: The Interface Definition Language (IDL) file is available here.
- Offside labs audit report: Offside labs has audited the order engine program
programs/order-engine
and the off-chain validationorder-engine-sdk/src/fill.rs
The following diagram gives an overview of the request workflow:
sequenceDiagram
participant FE
participant API as Jupiter RFQ API
participant MM as Market Makers
FE->>API: /quote
activate API
activate MM
API->>MM: /quote
MM->>API: quotesResponse
deactivate MM
API->>API: Create Tx
API->>FE: Best quoteResponse with Tx
deactivate API
activate FE
FE ->> FE: Partial Sign Tx
FE ->> API: /swap with partial signed Tx
deactivate FE
activate API
API->>API: Checks Tx
API->>MM: /swap with partial signed Tx
activate MM
MM->>MM: Sign and send Tx
MM->>API: swapResponse (acceptance/bail)
deactivate MM
activate FE
API->>FE: swapResponse (acceptance/bail)
deactivate API
FE->>FE: Poll userAcc for Tx confirmation
deactivate FE
Note over FE,MM: end
To facilitate the integration into Jupiter's RFQ module, you will need to provide a webhook for us to register the quotation and swap endpoints with the corresponding request and response format.
https://your-api-endpoint.com/jupiter/rfq
Endpoints we will call after registration
POST https://your-api-endpoint.com/jupiter/rfq/quote
POST https://your-api-endpoint.com/jupiter/rfq/swap
If you require an API key to access your endpoints, please provide it to us during the registration process. The API Key will be passed to the webhook as a header X-API-KEY
.
REST API documentation is provided in OpenAPI format. You can find the documentation here.
A sample server with the API documentation is provider in the server-example
directory. To launch the server, run the following commands (requires rust and cargo to be installed):
make run-server-example
and open the following URL in your browser: http://localhost:8080/swagger-ui/
Market Makers should return appropriate HTTP status codes along with error messages. The following status codes are supported:
400 Bad Request
: When the request parameters sent by Jupiter are invalid or malformed401 Unauthorized
: When authentication fails, e.g x-api-key is not provided or invalid
404 Not Found
: When the requested resource doesn't exist, as in case of a token not being supported
This is when the market maker is unable to fulfill the request due to internal issues. Jupiter may stop sending requests to the market maker if this happens too frequently.
500 Internal Server Error
: When an unexpected error occurs on the market maker's side503 Service Unavailable
: When the market maker service is temporarily unavailable
We have provided a set of acceptance tests that you can run to verify that your implementation is correct. The tests can be found in the acceptance
directory.
To run the tests, you will need to have a recent nodejs version, pnpm and vitest installed. To run the tests, after installing the dependencies, run the following command:
make prepare-acceptance-tests
and then run the tests with:
WEBHOOK_URL=<your_webhook_url> make run-acceptance-tests
for an example, you can run the tests against the sample server:
make run-acceptance-tests-against-sample-server
We enforce a fixed expiry timing flow for all quotes and transactions:
- When creating a quote, we set transaction expiry to 55 seconds from creation time
- On the frontend:
- If remaining time before expiry is less than 40 seconds when user needs to sign, we will automatically requote
- The frontend will also do a requote every 15s
- On the backend:
- If remaining time before expiry is less than 25 seconds when our /swap endpoint receives the request, we will reject the swap before forwarding to market makers
This fixed expiry flow simplifies the integration by:
- Removing the need for market makers to specify custom expiry times in quote requests
- Providing consistent behavior across all quotes and transactions
- Allowing for clear timeout boundaries at different stages of the flow
Note: These expiry thresholds may be adjusted based on performance and feedback.
Market makers are expected to comply with 90% of the quotation swap requests provided before getting penalized.
Current implementation enforces that Jupiter RFQ API will be the one crafting the instructions and transactions, however in the future we are working to improve on the flow to allow market makers to have the flexibility to craft their own transactions with a set of whitelisted instructions.
Some market makers may not wish to be the ones handling the sending of transactions on chain. We may look into helping market makers land their transactions on chain in the future.
We will likely introduce a fee in the range bps applied to the MM, based on total filled volume. More details to be announced on the introduction of fees on Jupiter RFQ. Currently, we welcome all MMs to integrate Jupiter RFQ with 0 fees for a limited, testing period.