Skip to content

A toolkit for implementing Jupiter RFQ webhooks

License

Notifications You must be signed in to change notification settings

jup-ag/rfq-webhook-toolkit

Repository files navigation

RFQ Webhook Toolkit

📣 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.

Order Engine

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.

Audit

Market Maker Integration Guidelines

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
Loading

Integration specifications

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.

Example URL that we will register into our api

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

In addition, the webhook will be called at regular intervals to fetch the list of supported tokens (see below):

GET https://your-api-endpoint.com/jupiter/rfq/tokens

API Key

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.

Api Documentation

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/

Webhook Error Responses

Market Makers should return appropriate HTTP status codes along with error messages. The following status codes are supported:

Severe errors

  • 400 Bad Request: When the request parameters sent by Jupiter are invalid or malformed
  • 401 Unauthorized: When authentication fails, e.g x-api-key is not provided or invalid

Warnings

  • 404 Not Found: When the requested resource doesn't exist, as in case of a token not being supported

Service errors

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 side
  • 503 Service Unavailable: When the market maker service is temporarily unavailable

Expiry information

We enforce a fixed expiry timing flow for all quotes and transactions:

  1. When creating a quote, we set transaction expiry to 55 seconds from creation time
  2. 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
  3. 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.

Advertising supported tokens

In order to receive relevant quote requests, market makers need to advertise the tokens they support. This is done by providing a list of supported tokens in the response to the /tokens route. The response should be a JSON array of token addresses. The list of tokens is refreshed every 10 minutes.

By default, webhooks will be always asked to quote for the following tokens

  • SOL
  • USDC

Technical integration

To facilitate the integration, in this repository you will find a sample server that implements the webhook API. The server is written in Rust and can be found in the server-example directory.

In addition, we provide a set of test suites to verify the implementation of the webhook. The tests, and their instructions, can be found in the tests directory.

Future considerations/plans

Fulfillment Requirements

Market makers are expected to comply with 90% of the quotation swap requests provided before getting penalized.

Transaction Crafting

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.

Transaction sending

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.

Fees

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.