Dragonchain Go SDK
A self-contained Go SDK for interacting with Dragonchain nodes.
Installation
go get git.dragonchain.com/dragonchain/dragonchain-prime-sdk-go
Usage
package main
import (
"context"
"fmt"
"log"
"time"
"git.dragonchain.com/dragonchain/dragonchain-prime-sdk-go"
"git.dragonchain.com/dragonchain/dragonchain-prime-sdk-go/models"
)
func main() {
// Initialize the SDK
client := sdk.NewDragonchainSDK(
"your-public-id",
"your-auth-key-id",
"your-auth-key",
"https://your-dragonchain-endpoint.com",
)
// Create a context with timeout
ctx, cancel := context.WithTimeout(context.Background(), 30*time.Second)
defer cancel()
// Check system health
if err := client.System.Health(ctx); err != nil {
log.Fatal("Health check failed:", err)
}
// Get system status
status, err := client.System.Status(ctx)
if err != nil {
log.Fatal("Failed to get status:", err)
}
fmt.Printf("Chain ID: %s, Level: %d\n", status.ID, status.Level)
// Create a transaction
txn := &models.TransactionCreateRequest{
TxnType: "my-transaction-type",
Payload: map[string]interface{}{
"message": "Hello Dragonchain",
},
Tag: "example-tag",
}
resp, err := client.Transaction.Create(ctx, txn)
if err != nil {
log.Fatal("Failed to create transaction:", err)
}
fmt.Printf("Created transaction: %s\n", resp.TransactionID)
}
Available Endpoints
All API methods accept a context.Context as their first parameter for timeout and cancellation control.
System
Health(ctx)- Check system healthStatus(ctx)- Get system status
Transaction
Create(ctx, req)- Create a new transactionCreateBulk(ctx, req)- Create multiple transactionsGet(ctx, transactionID)- Get transaction by IDList(ctx)- List all transactions
Transaction Type
Create(ctx, req)- Create a new transaction typeGet(ctx, txnType)- Get transaction type by nameList(ctx)- List all transaction typesDelete(ctx, txnType)- Delete a transaction type
Smart Contract
Create(ctx, req)- Create a new smart contractGet(ctx, contractID)- Get smart contract by IDList(ctx)- List all smart contractsUpdate(ctx, contractID, req)- Update a smart contractUpload(ctx, contractID, filepath)- Upload smart contract codeDelete(ctx, contractID)- Delete a smart contract
Block
Get(ctx, blockID)- Get block by ID
Authentication
The SDK uses HMAC-SHA256 authentication. You need to provide:
publicID- Your Dragonchain public IDauthKeyID- Your authentication key IDauthKey- Your authentication keybaseURL- The base URL of your Dragonchain node (e.g., "https://chains.dragonchain.com")
Description
Languages
Go
100%