metaapi.cloud-sdk
Version:
SDK for MetaApi, a professional cloud forex API which includes MetaTrader REST API and MetaTrader websocket API. Supports both MetaTrader 5 (MT5) and MetaTrader 4 (MT4). CopyFactory copy trading API included. (https://metaapi.cloud)
87 lines (73 loc) • 3.44 kB
JavaScript
let MetaApi = require('metaapi.cloud-sdk').default;
let token = process.env.TOKEN || '<put in your token here>';
let accountId = process.env.ACCOUNT_ID || '<put in your account id here>';
const api = new MetaApi(token);
async function testMetaApiSynchronization() {
try {
const account = await api.metatraderAccountApi.getAccount(accountId);
const initialState = account.state;
const deployedStates = ['DEPLOYING', 'DEPLOYED'];
if(!deployedStates.includes(initialState)) {
// wait until account is deployed and connected to broker
console.log('Deploying account');
await account.deploy();
}
console.log('Waiting for API server to connect to broker (may take couple of minutes)');
await account.waitConnected();
// connect to MetaApi API
let connection = account.getRPCConnection();
await connection.connect();
// wait until terminal state synchronized to the local state
console.log('Waiting for SDK to synchronize to terminal state (may take some time depending on your history size)');
await connection.waitSynchronized();
// invoke RPC API (replace ticket numbers with actual ticket numbers which exist in your MT account)
console.log('Testing MetaAPI RPC API');
console.log('account information:', await connection.getAccountInformation());
console.log('positions:', await connection.getPositions());
//console.log(await connection.getPosition('1234567'));
console.log('open orders:', await connection.getOrders());
//console.log(await connection.getOrder('1234567'));
console.log('history orders by ticket:', await connection.getHistoryOrdersByTicket('1234567'));
console.log('history orders by position:', await connection.getHistoryOrdersByPosition('1234567'));
console.log('history orders (~last 3 months):',
await connection.getHistoryOrdersByTimeRange(new Date(Date.now() - 90 * 24 * 60 * 60 * 1000), new Date()));
console.log('history deals by ticket:', await connection.getDealsByTicket('1234567'));
console.log('history deals by position:', await connection.getDealsByPosition('1234567'));
console.log('history deals (~last 3 months):',
await connection.getDealsByTimeRange(new Date(Date.now() - 90 * 24 * 60 * 60 * 1000), new Date()));
console.log('server time', await connection.getServerTime());
// calculate margin required for trade
console.log('margin required for trade', await connection.calculateMargin({
symbol: 'GBPUSD',
type: 'ORDER_TYPE_BUY',
volume: 0.1,
openPrice: 1.1
}));
// trade
console.log('Submitting pending order');
try {
let result = await
connection.createLimitBuyOrder('GBPUSD', 0.07, 1.0, 0.9, 2.0, {
comment: 'comm',
clientId: 'TE_GBPUSD_7hyINWqAlE',
expiration: {
type: 'ORDER_TIME_SPECIFIED',
time: new Date(Date.now() + 24 * 60 * 60 * 1000)
}
});
console.log('Trade successful, result code is ' + result.stringCode);
} catch (err) {
console.log('Trade failed with result code ' + err.stringCode);
}
if(!deployedStates.includes(initialState)) {
// undeploy account if it was undeployed
console.log('Undeploying account');
await connection.close();
await account.undeploy();
}
} catch (err) {
console.error(err);
}
process.exit();
}
testMetaApiSynchronization();