Build a limit order transaction
In the following example, we will be creating a limit order.
To place a new order, you must provide the following:
For an in-depth API reference Build order transaction
Curl NodeJs (axios) Go
Copy curl --location 'https://api-staging.deltadefi.io/order/build' \
--header 'x-api-key: <your_api_key>' \
--header 'Content-Type: application/json' \
--data '{
"symbol": "ADAUSDX",
"side": "buy",
"type": "limit",
"quantity": 100,
"price": 0.93
}'
Copy const axios = require('axios');
let data = JSON.stringify({
"symbol": "ADAUSDX",
"side": "buy",
"type": "limit",
"quantity": 100,
"price": 0.93
});
let config = {
method: 'post',
maxBodyLength: Infinity,
url: 'https://api-staging.deltadefi.io/order/build',
headers: {
'x-api-key': '<your_api_key>',
'Content-Type': 'application/json'
},
data : data
};
axios.request(config)
.then((response) => {
console.log(JSON.stringify(response.data));
})
.catch((error) => {
console.log(error);
});
Copy package main
import (
"fmt"
"strings"
"net/http"
"io"
)
func main() {
url := "https://api-staging.deltadefi.io/order/build"
method := "POST"
payload := strings.NewReader(`{
"symbol": "ADAUSDX",
"side": "buy",
"type": "limit",
"quantity": 100,
"price": 0.93
}`)
client := &http.Client {
}
req, err := http.NewRequest(method, url, payload)
if err != nil {
fmt.Println(err)
return
}
req.Header.Add("x-api-key", "<your_api_key>")
req.Header.Add("Content-Type", "application/json")
res, err := client.Do(req)
if err != nil {
fmt.Println(err)
return
}
defer res.Body.Close()
body, err := io.ReadAll(res.Body)
if err != nil {
fmt.Println(err)
return
}
fmt.Println(string(body))
}
Submit a limit order transaction
After the order transaction is built, you will then need to sign it before submitting it.
To submit:
Curl NodeJs (axios) Go
Copy curl --location 'https://api-staging.deltadefi.io/order/submit' \
--header 'Authorization: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE3NDI1Mzk5NDAsInN1YiI6ImFkZHJfdGVzdDFxcXpnZzVwY2FleWVhNjl1cHRsOWRhNWc3ZmFqbTRtMHl2eG5keDlmNGx4cGtlaHFnZXp5MHMwNHJ0ZHdsYzB0bHZ4YWZwZHJmeG5zZzd3dzY4Z2UzajdsMGxuc3pzdzJ3dCJ9.OAchsj0tv06NxD9Br0aj0Zw5XzpG8kUFKBuVPtz5AKA' \
--header 'X-API-KEY: <your_api_key>' \
--header 'Content-Type: application/json' \
--data '{
"order_id": "<order_id>",
"signed_tx":"<signed_tx>"
}'
Copy const axios = require('axios');
let data = JSON.stringify({
"order_id": "<order_id>",
"signed_tx": "<signed_tx>"
});
let config = {
method: 'post',
maxBodyLength: Infinity,
url: 'https://api-staging.deltadefi.io/order/submit',
headers: {
'Authorization': 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE3NDI1Mzk5NDAsInN1YiI6ImFkZHJfdGVzdDFxcXpnZzVwY2FleWVhNjl1cHRsOWRhNWc3ZmFqbTRtMHl2eG5keDlmNGx4cGtlaHFnZXp5MHMwNHJ0ZHdsYzB0bHZ4YWZwZHJmeG5zZzd3dzY4Z2UzajdsMGxuc3pzdzJ3dCJ9.OAchsj0tv06NxD9Br0aj0Zw5XzpG8kUFKBuVPtz5AKA',
'X-API-KEY': '<your_api_key>',
'Content-Type': 'application/json'
},
data : data
};
axios.request(config)
.then((response) => {
console.log(JSON.stringify(response.data));
})
.catch((error) => {
console.log(error);
});
Copy package main
import (
"fmt"
"strings"
"net/http"
"io"
)
func main() {
url := "https://api-staging.deltadefi.io/order/submit"
method := "POST"
payload := strings.NewReader(`{
"order_id": "<order_id>",
"signed_tx":"<signed_tx>"
}`)
client := &http.Client {
}
req, err := http.NewRequest(method, url, payload)
if err != nil {
fmt.Println(err)
return
}
req.Header.Add("Authorization", "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE3NDI1Mzk5NDAsInN1YiI6ImFkZHJfdGVzdDFxcXpnZzVwY2FleWVhNjl1cHRsOWRhNWc3ZmFqbTRtMHl2eG5keDlmNGx4cGtlaHFnZXp5MHMwNHJ0ZHdsYzB0bHZ4YWZwZHJmeG5zZzd3dzY4Z2UzajdsMGxuc3pzdzJ3dCJ9.OAchsj0tv06NxD9Br0aj0Zw5XzpG8kUFKBuVPtz5AKA")
req.Header.Add("X-API-KEY", "<your_api_key>")
req.Header.Add("Content-Type", "application/json")
res, err := client.Do(req)
if err != nil {
fmt.Println(err)
return
}
defer res.Body.Close()
body, err := io.ReadAll(res.Body)
if err != nil {
fmt.Println(err)
return
}
fmt.Println(string(body))
}
Build a market order transaction
In this example we will be creating a market order.
For an in-depth API reference Build order transaction
To place a market order, provide the following:
limit_slippage / max_slippage_basis_point (either one)
limit_slippage (bool) : If set to false, the market order will allow unlimited slippage until the entire order quantity is filled, where the account's purchasing power allows
max_slippage_basis_points (int) : Maximum Slippage is the maximum acceptable deviation between the expected price (market price) and the actual executed price in a market order transaction
Curl NodeJs (axios) Go
Copy curl --location 'https://api-staging.deltadefi.io/order/build' \
--header 'x-api-key: <your_api_key>' \
--header 'Content-Type: application/json' \
--data '{
"symbol": "ADAUSDX",
"side": "buy",
"type": "market",
"quantity": 100,
"limit_slippage": true
}'
Copy const axios = require('axios');
let data = JSON.stringify({
"symbol": "ADAUSDX",
"side": "buy",
"type": "market",
"quantity": 100,
"limit_slippage": false
});
let config = {
method: 'post',
maxBodyLength: Infinity,
url: 'https://api-staging.deltadefi.io/order/build',
headers: {
'x-api-key': '<your_api_key>',
'Content-Type': 'application/json'
},
data : data
};
axios.request(config)
.then((response) => {
console.log(JSON.stringify(response.data));
})
.catch((error) => {
console.log(error);
});
Copy package main
import (
"fmt"
"strings"
"net/http"
"io"
)
func main() {
url := "https://api-staging.deltadefi.io/order/build"
method := "POST"
payload := strings.NewReader(`{
"symbol": "ADAUSDX",
"side": "buy",
"type": "market",
"quantity": 100,
"limit_slippage":false
}`)
client := &http.Client {
}
req, err := http.NewRequest(method, url, payload)
if err != nil {
fmt.Println(err)
return
}
req.Header.Add("x-api-key", "<your_api_key>")
req.Header.Add("Content-Type", "application/json")
res, err := client.Do(req)
if err != nil {
fmt.Println(err)
return
}
defer res.Body.Close()
body, err := io.ReadAll(res.Body)
if err != nil {
fmt.Println(err)
return
}
fmt.Println(string(body))
}
After the transaction is built, follow step 2 above to submit the transaction.