txnbuild
is a Stellar SDK, implemented in Go. It provides a reference implementation of the complete set of operations that compose transactions for the Stellar distributed ledger.
This project is maintained by the Stellar Development Foundation.
import (
"log"
"github.com/lantah/go/clients/horizonclient"
"github.com/lantah/go/keypair"
"github.com/lantah/go/network"
"github.com/lantah/go/txnbuild"
)
// Make a keypair for a known account from a secret seed
kp, _ := keypair.Parse("SBPQUZ6G4FZNWFHKUWC5BEYWF6R52E3SEP7R3GWYSM2XTKGF5LNTWW4R")
// Get the current state of the account from the network
client := horizonclient.DefaultTestNetClient
ar := horizonclient.AccountRequest{AccountID: kp.Address()}
sourceAccount, err := client.AccountDetail(ar)
if err != nil {
log.Fatalln(err)
}
// Build an operation to create and fund a new account
op := txnbuild.CreateAccount{
Destination: "GCCOBXW2XQNUSL467IEILE6MMCNRR66SSVL4YQADUNYYNUVREF3FIV2Z",
Amount: "10",
}
// Construct the transaction that holds the operations to execute on the network
tx, err := txnbuild.NewTransaction(
txnbuild.TransactionParams{
SourceAccount: &sourceAccount,
IncrementSequenceNum: true,
Operations: []txnbuild.Operation{&op},
BaseFee: txnbuild.MinBaseFee,
Timebounds: txnbuild.NewTimeout(300),
},
)
if err != nil {
log.Fatalln(err)
)
// Sign the transaction
tx, err = tx.Sign(network.TestNetworkPassphrase, kp.(*keypair.Full))
if err != nil {
log.Fatalln(err)
)
// Get the base 64 encoded transaction envelope
txe, err := tx.Base64()
if err != nil {
log.Fatalln(err)
}
// Send the transaction to the network
resp, err := client.SubmitTransactionXDR(txe)
if err != nil {
log.Fatalln(err)
}
This library is aimed at developers building Go applications on top of the Lantah Network. Transactions constructed by this library may be submitted to any Horizon instance for processing onto the ledger, using any Lantah SDK client. The recommended client for Go programmers is horizonclient. Together, these two libraries provide a complete Stellar SDK.
An easy-to-follow demonstration that exercises this SDK on the TestNet with actual accounts is also included! See the Demo section below.
- Go (this repository is officially supported on the last two releases of Go)
- Modules to manage dependencies
go get github.com/lantah/go/txnbuild
Run the unit tests from the package directory: go test
To see the SDK in action, build and run the demo:
- Enter the demo directory:
cd $GOPATH/src/github.com/lantah/go/txnbuild/cmd/demo
- Build the demo:
go build
- Run the demo:
./demo init
Please read Code of Conduct to understand this project's communication rules.
To submit improvements and fixes to this library, please see CONTRIBUTING.
This project is licensed under the Apache License - see the LICENSE file for details.