-
Notifications
You must be signed in to change notification settings - Fork 98
Home
You can either create an instance of WebSocket
and pass it as connection
or
pass the endpoint
and app_id
to the constructor to create the connection for
you.
If you pass the connection
it's up to you to reconnect in case the connection
drops (cause API doesn't know how to create the same connection).
const connection = new WebSocket('wss://frontend.binaryws.com/websockets/v3?l=EN&app_id=1234');
const api = new DerivAPI({ connection });
const api = new DerivAPI({ endpoint: 'frontend.binaryws.com', lang: 'EN', app_id: 1234 });
All API methods are asynchronous, they return a Promise
that will resolve to
an abstract object with the requested data and onUpdate()
which receives the
updated instance on every update of that object either through a callback
passed to onUpdate()
or as an observer listening on the observable returned
by onUpdate()
(if no callback is specified).
const range = { start: await api.time - 10, end: await api.time };
// a ticks object you can get the ticks from or listen to updates
const ticks = await api.tickStream('R_100');
// By default the last 1000 ticks
const list_of_ticks = ticks.list;
const list_of_old_ticks = await ticks.history(range);
// Get the tick updates with a callback
ticks.onUpdate(tick => /* updates for the ticks */);
// Get the tick updates with an observable
ticks.onUpdate().subscribe(tick => /* updates for the ticks */);
// Same as ticks, default is the last 1000 1min candle
// either 'R_100' or { symbol: 'R_100', granularity: ... }
const candles = await api.candleStream('R_100');
const candle = candles.list.slice(-1)[0] // current
candles.onUpdate(candle => {
chart.add(candle);
})
const contract = await api.contract({
contract_type: 'call',
symbol: 'R_100',
duration: 1,
duration_unit: 't',
...contract_options
});
contract.onUpdate().subscribe(contract => {
if (contract.is_sold) {
sell_pop_up.set(contract);
}
});
const underlying = await api.underlying('R_100');
// You can also call ticks and candles related calls on an underlying instance
const ticks = await underlying.tickStream();
// You can create a contract from an underlying
const contract = await underlying.contract(contract_options);
const account = await api.account('AccountToken');
const balance = account.balance;
// You can create a contract from an account instance
const contract = await account.contract(contract_options);
const transaction_stream = await account.transactionStream();
transaction_stream.onUpdate(console.log)
const assets = await api.assets();
if (!assets.underlyings.find(u => u.symbol === 'R_100').is_trading_suspended) {
const contract = await api.contract(contract_options);
// The rest
}
const website_status_stream = await api.websiteStatusStream();
website_status_stream.onUpdate(({ status, is_website_up, limits }) => {
console.log(`Website is ${status}`);
console.log('limits: %s', limits);
})
const api = new DerivAPI(/* options here */);
const accout = await api.account('YourToken');
const assets = await api.assets();
assets.open_markets.forEach(market => {
console.log('Market %s is open', market.name.full);
});
const underlying = await api.underlying('R_100');
const { callput } = underlying.contract_groups;
const { min: duration, unit: duration_unit } = callput.duration.tick;
const { forward_sessions } = callput;
const [ first_session ] = forwardSessions;
const $el = <input type="date" value={await api.time} min={first_session.open.value} max={first_session.close.value}>
const account = await api.account('YourToken');
// Loop through all associated accounts and print whether they're virtual
account.siblings.forEach(u => {
console.log('Is %s virtual? %s', u.loginid, u.is_virtual);
});
const sibling = await account.siblings[0].switch();
// account.balance is not available anymore.
const balance = sibling.balance;
console.log('%s has %s %s', sibling.loginid, balance.currency, balance.format);
balance.onUpdate(({ account: { loginid }, currency, format }) => {
console.log('%s has now %s %s', loginid, currency, format);
});
const underlying = await api.underlying('R_100');
const ticks = await underlying.tickStream();
ticks.onUpdate(tick => {
// Update chart info with the new ticks
chart.show(tick);
});
// Initialize the chart with the list of ticks available
chart.init(ticks.list);
const underlying = await api.underlying('R_100');
if (underlying.is_trading_suspended) {
console.log('Trading is suspended for %s', underlying.name.full);
} else {
// Get the contract group for Rise/Fall
const callput = underlying.contract_groups.callput;
// Get the duration allowed for tick contracts
const { value: duration, unit: duration_unit } = callput.durations.tick.min;
const [contract_type] = callput.contract_types;
const contract = await api.contract({
symbol: underlying.symbol,
contract_type,
duration,
duration_unit,
});
}
Each font face indicates a different type of field:
Bold: a link to another class object(s)
endingWithParenthesis(): A method name, usually doing some action on the object
normal_properties: The snake case name of a property accessible from the object