UNPKG

triam-sdk-contract

Version:

triam-sdk is a library for working with the Triam Horizon server.

128 lines (101 loc) 5.09 kB
--- title: Overview --- The JavaScript Stellar SDK facilitates integration with the [Stellar Horizon API server](https://github.com/stellar/horizon) and submission of Stellar transactions, either on Node.js or in the browser. It has two main uses: [querying Horizon](#querying-horizon) and [building, signing, and submitting transactions to the Stellar network](#building-transactions). [Building and installing js-stellar-sdk](https://github.com/stellar/js-stellar-sdk)<br> [Examples of using js-stellar-sdk](./examples.md) # Querying Horizon js-stellar-sdk gives you access to all the endpoints exposed by Horizon. ## Building requests js-stellar-sdk uses the [Builder pattern](https://en.wikipedia.org/wiki/Builder_pattern) to create the requests to send to Horizon. Starting with a [server](https://stellar.github.io/js-stellar-sdk/Server.html) object, you can chain methods together to generate a query. (See the [Horizon reference](https://www.stellar.org/developers/reference/) documentation for what methods are possible.) ```js var StellarSdk = require('stellar-sdk'); var server = new StellarSdk.Server('https://horizon-testnet.stellar.org'); // get a list of transactions that occurred in ledger 1400 server.transactions() .forLedger(1400) .call().then(function(r){ console.log(r); }); // get a list of transactions submitted by a particular account server.transactions() .forAccount('GASOCNHNNLYFNMDJYQ3XFMI7BYHIOCFW3GJEOWRPEGK2TDPGTG2E5EDW') .call().then(function(r){ console.log(r); }); ``` Once the request is built, it can be invoked with `.call()` or with `.stream()`. `call()` will return a [promise](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise) to the response given by Horizon. ## Streaming requests Many requests can be invoked with `stream()`. Instead of returning a promise like `call()` does, `.stream()` will return an `EventSource`. Horizon will start sending responses from either the beginning of time or from the point specified with `.cursor()`. (See the [Horizon reference](https://www.stellar.org/developers/reference/) documentation to learn which endpoints support streaming.) For example, to log instances of transactions from a particular account: ```javascript var StellarSdk = require('stellar-sdk') var server = new StellarSdk.Server('https://horizon-testnet.stellar.org'); var lastCursor=0; // or load where you left off var txHandler = function (txResponse) { console.log(txResponse); }; var es = server.transactions() .forAccount(accountAddress) .cursor(lastCursor) .stream({ onmessage: txHandler }) ``` ## Handling responses ### XDR The transaction endpoints will return some fields in raw [XDR](https://www.stellar.org/developers/horizon/learn/xdr.html) form. You can convert this XDR to JSON using the `.fromXDR()` method. An example of re-writing the txHandler from above to print the XDR fields as JSON: ```javascript var txHandler = function (txResponse) { console.log( JSON.stringify(StellarSdk.xdr.TransactionEnvelope.fromXDR(txResponse.envelope_xdr, 'base64')) ); console.log( JSON.stringify(StellarSdk.xdr.TransactionResult.fromXDR(txResponse.result_xdr, 'base64')) ); console.log( JSON.stringify(StellarSdk.xdr.TransactionMeta.fromXDR(txResponse.result_meta_xdr, 'base64')) ); }; ``` ### Following links The links returned with the Horizon response are converted into functions you can call on the returned object. This allows you to simply use `.next()` to page through results. It also makes fetching additional info, as in the following example, easy: ```js server.payments() .limit(1) .call() .then(function(response){ // will follow the transactions link returned by Horizon response.records[0].transaction().then(function(txs){ console.log(txs); }); }); ``` # Transactions ## Building transactions See the [Building Transactions](https://www.stellar.org/developers/js-stellar-base/learn/building-transactions.html) guide for information about assembling a transaction. ## Submitting transactions Once you have built your transaction, you can submit it to the Stellar network with `Server.submitTransaction()`. ```js var StellarSdk = require('stellar-sdk') StellarSdk.Network.useTestNetwork(); var server = new StellarSdk.Server('https://horizon-testnet.stellar.org'); server .loadAccount(publicKey) .then(function(account){ var transaction = new StellarSdk.TransactionBuilder(account) // this operation funds the new account with XLM .addOperation(StellarSdk.Operation.payment({ destination: "GASOCNHNNLYFNMDJYQ3XFMI7BYHIOCFW3GJEOWRPEGK2TDPGTG2E5EDW", asset: StellarSdk.Asset.native(), amount: "20000000" })) .build(); transaction.sign(StellarSdk.Keypair.fromSecret(secretString)); // sign the transaction return server.submitTransaction(transaction); }) .then(function (transactionResult) { console.log(transactionResult); }) .catch(function (err) { console.error(err); }); ```