Create an account | Stellar Docs (2024)

Before we get started with working with Stellar in code, consider going through the following examples using the Stellar Lab. The lab allows you create accounts, fund accounts on the Stellar test network, build transactions, run any operation, and inspect responses from Horizon via the Endpoint Explorer.

Accounts are a fundamental building block of Stellar: they hold all your balances, allow you to send and receive payments, and let you place offers to buy and sell assets. Since pretty much everything on Stellar is in some way tied to an account, the first thing you generally need to do when you start developing is create one. This beginner-level tutorial will show you how to do that.

Create a Keypair

Stellar uses public key cryptography to ensure that every transaction is secure: every Stellar account has a keypair consisting of a public key and a secret key. The public key is always safe to share — other people need it to identify your account and verify that you authorized a transaction. It's like an email address. The secret key, however, is private information that proves you own — and gives you access to — your account. It's like a password, and you should never share it with anyone.

Before creating an account, you need to generate your own keypair:

  • JavaScript
  • Java
  • Go
  • Python
// create a completely new and unique pair of keys
// see more about KeyPair objects: https://stellar.github.io/js-stellar-sdk/Keypair.html
const pair = StellarSdk.Keypair.random();

pair.secret();
// SAV76USXIJOBMEQXPANUOQM6F5LIOTLPDIDVRJBFFE2MDJXG24TAPUU7
pair.publicKey();
// GCFXHS4GXL6BVUCXBWXGTITROWLVYXQKQLF4YH5O5JT3YZXCYPAFBJZB

Create Account

A valid keypair, however, does not make an account: in order to prevent unused accounts from bloating the ledger, Stellar requires accounts to hold a minimum balance of 1 XLM before they actually exist. Until it gets a bit of funding, your keypair doesn't warrant space on the ledger.

On the public network, where live users make live transactions, your next step would be to acquire XLM, which you can do by consulting our section on lumens. Because this tutorial runs on the test network, you can get 10,000 test XLM from Friendbot, which is a friendly account funding tool.

To do that, send Friendbot the public key you created. It’ll create and fund a new account using that public key as the account ID.

  • JavaScript
  • Java
  • Go
  • Python
// The SDK does not have tools for creating test accounts, so you'll have to
// make your own HTTP request.

// if you're trying this on Node, install the `node-fetch` library and
// uncomment the next line:
// const fetch = require('node-fetch');

(async function main() {
try {
const response = await fetch(
`https://friendbot.stellar.org?addr=${encodeURIComponent(
pair.publicKey(),
)}`,
);
const responseJSON = await response.json();
console.log("SUCCESS! You have a new account :)\n", responseJSON);
} catch (e) {
console.error("ERROR!", e);
}
// After you've got your test lumens from friendbot, we can also use that account to create a new account on the ledger.
try {
const server = new StellarSdk.Horizon.Server(
"https://horizon-testnet.stellar.org",
);
var parentAccount = await server.loadAccount(pair.publicKey()); //make sure the parent account exists on ledger
var childAccount = StellarSdk.Keypair.random(); //generate a random account to create
//create a transacion object.
var createAccountTx = new StellarSdk.TransactionBuilder(parentAccount, {
fee: StellarSdk.BASE_FEE,
networkPassphrase: StellarSdk.Networks.TESTNET,
});
//add the create account operation to the createAccountTx transaction.
createAccountTx = await createAccountTx
.addOperation(
StellarSdk.Operation.createAccount({
destination: childAccount.publicKey(),
startingBalance: "5",
}),
)
.setTimeout(180)
.build();
//sign the transaction with the account that was created from friendbot.
await createAccountTx.sign(pair);
//submit the transaction
let txResponse = await server
.submitTransaction(createAccountTx)
// some simple error handling
.catch(function (error) {
console.log("there was an error");
console.log(error.response);
console.log(error.status);
console.log(error.extras);
return error;
});
console.log(txResponse);
console.log("Created the new account", childAccount.publicKey());
} catch (e) {
console.error("ERROR!", e);
}
})();

Now for the last step: getting the account’s details and checking its balance. Accounts can carry multiple balances — one for each type of currency they hold.

  • JavaScript
  • Java
  • Go
  • Python
const server = new StellarSdk.Horizon.Server(
"https://horizon-testnet.stellar.org",
);

// the JS SDK uses promises for most actions, such as retrieving an account
const account = await server.loadAccount(pair.publicKey());
console.log("Balances for account: " + pair.publicKey());
account.balances.forEach(function (balance) {
console.log("Type:", balance.asset_type, ", Balance:", balance.balance);
});

Now that you’ve got an account, you can start sending and receiving payments, or, if you're ready to hunker down, you can skip ahead and build a wallet or issue a Stellar-network asset.

info

In the above code samples, proper error checking is omitted for brevity. However, you should always validate your results, as there are many ways that requests can fail. You should refer to the guide on Error Handling for tips on error management strategies.

Create an account | Stellar Docs (2024)
Top Articles
Difference between 32-bit and 64-bit operating systems - GeeksforGeeks
Did 'She-Hulk' just reveal the existence of two more mutants?
Combat level
Le Blanc Los Cabos - Los Cabos – Le Blanc Spa Resort Adults-Only All Inclusive
How Much Does Dr Pol Charge To Deliver A Calf
Practical Magic 123Movies
Tv Guide Bay Area No Cable
Craigslist Parsippany Nj Rooms For Rent
Www Movieswood Com
Www.paystubportal.com/7-11 Login
Inside California's brutal underground market for puppies: Neglected dogs, deceived owners, big profits
Bros Movie Wiki
Think Up Elar Level 5 Answer Key Pdf
Cashtapp Atm Near Me
Mani Pedi Walk Ins Near Me
Brett Cooper Wikifeet
Rams vs. Lions highlights: Detroit defeats Los Angeles 26-20 in overtime thriller
Paychex Pricing And Fees (2024 Guide)
Spider-Man: Across The Spider-Verse Showtimes Near Marcus Bay Park Cinema
Inter-Tech IM-2 Expander/SAMA IM01 Pro
Lowe's Garden Fence Roll
The best firm mattress 2024, approved by sleep experts
Boscov's Bus Trips
Certain Red Dye Nyt Crossword
Craigslist Roseburg Oregon Free Stuff
Craigslist Alo
Play Tetris Mind Bender
Devotion Showtimes Near Regency Buenaventura 6
Margaret Shelton Jeopardy Age
208000 Yen To Usd
1636 Pokemon Fire Red U Squirrels Download
Tactical Masters Price Guide
Spirited Showtimes Near Marcus Twin Creek Cinema
Calvin Coolidge: Life in Brief | Miller Center
What Is Opm1 Treas 310 Deposit
Pokemmo Level Caps
R&J Travel And Tours Calendar
KITCHENAID Tilt-Head Stand Mixer Set 4.8L (Blue) + Balmuda The Pot (White) 5KSM175PSEIC | 31.33% Off | Central Online
Giantess Feet Deviantart
Academic important dates - University of Victoria
303-615-0055
Tsbarbiespanishxxl
Go Bananas Wareham Ma
Avance Primary Care Morrisville
Cuckold Gonewildaudio
Why Are The French So Google Feud Answers
Unblocked Games 6X Snow Rider
Ark Silica Pearls Gfi
Strange World Showtimes Near Century Federal Way
Inloggen bij AH Sam - E-Overheid
Latest Posts
Article information

Author: Ray Christiansen

Last Updated:

Views: 6478

Rating: 4.9 / 5 (49 voted)

Reviews: 80% of readers found this page helpful

Author information

Name: Ray Christiansen

Birthday: 1998-05-04

Address: Apt. 814 34339 Sauer Islands, Hirtheville, GA 02446-8771

Phone: +337636892828

Job: Lead Hospitality Designer

Hobby: Urban exploration, Tai chi, Lockpicking, Fashion, Gunsmithing, Pottery, Geocaching

Introduction: My name is Ray Christiansen, I am a fair, good, cute, gentle, vast, glamorous, excited person who loves writing and wants to share my knowledge and understanding with you.