Skip to content

First Steps

Ryan edited this page Feb 17, 2019 · 33 revisions

First Steps Tutorial

The XAYA blockchain itself is essentially a decentralised data-store.

For minimal fees, people can create unique names (we also call accounts) in the XAYA blockchain and update them with additional data (called values). The main attribute is that only the person who created a name has its private key to update this additional data. They cannot be stolen, forged or censored.

The values of this name could be anything. For example, I could create a name called Rita and attach my email address to it. Anyone who knows I own that name can lookup my name on the xaya blockchain and they can trust the value that has been set. In this case that that is my email address.

On XAYA these names are also known as Accounts and the values (the attached data to the name) are moves in a game. Only the owner of the account can make moves from that account as he is the owner of the private key.

By just the above it's possible to build decentralised games on XAYA.

as an example:

Rita and Sue both have their own names (accounts) stored in the blockchain. They want to play a game of chess and they decide that Rita is white (to start first).

Rita can then update the value of her account with the first move

"e2 to e4"

After 30 seconds or so this will enter the blockchain.

Sue (or anyone in the world) can then read this move in the xaya blockchain and know it came from Rita. Sue could then update the value of her account with her own move. and so on.

This allows for a fully decentralised game of chess that anyone can verify and see who the winner is or if they tried an invalid move (tried to cheat).

Of course that is a very simple example but is the fundamental to how games on XAYA work.

In this first steps tutorial we'll explain the steps to create your own unique secure name on the xaya blockchain and update it's value.

Get a Wallet

To interact with the XAYA blockchain you will need to run a Xaya wallet. There are multiple wallets but in this guide we will use xayad which is the headless daemon with an rpc interface.

If you haven't already, download one of the Zips then extract the ZIP file.

Run the Daemon (xayad)

Open a command prompt or terminal and navigate to the unzipped folder.

Execute the following command in order to run the xaya daemon, set it's rpc port and username and password.

xayad -rpcport=8396 -rpcuser=user -rpcpassword=password

The blockchain will begin synchronising (downloading) the blockchain. This can take some time and largely depends on your computer and network connection.

When Xayad first runs it will download all the blocks from all the other peers until it catches up to the current block that everyone is on. If you stop the daemon and restart it say the day after, it will catch back up from where it left off. This could take some time dependent on the speed of your computer, your internet and your hard disk.

While it is syncing or after, lets check some things with the xaya rpc.

xaya-cli and curl

There are numerous ways to interact with the rpc interface - but in this example we will be using xaya-cli which is a simple to use tool that formats all commands simply and easily. We’ll also show some examples in curl as well. Xaya-cli is included in the binary downloads as linked above or if you built from source it is in the src directory.

Check the Network

Your first task is to check the network by confirming you are connected to other p2p xaya nodes. Here are the xaya-cli and curl commands:

xaya-cli -rpcuser=user -rpcpassword=password getnetworkinfo

Or with curl:

curl --user user:password --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "getnetworkinfo", "params": [] }' -H 'content-type: text/plain;' http://127.0.0.1:8396/

NOTE: With both xaya-cli and curl you will need to ensure that you've properly escaped anything that requires it. Also, mind which quotes you use (' vs "), depending on your platform.

Those commands will return something similar to this:

{
	"version": 1019900,
	"subversion": "/Xaya:1.1.99/",
	"protocolversion": 110015,
	"localservices": "000000000000040d",
	"localrelay": true,
	"timeoffset": 1,
	"networkactive": true,
	"connections": 8,
	"networks": [
		{
		"name": "ipv4",
		"limited": false,
		"reachable": true,
		"proxy": "",
		"proxy_randomize_credentials": false
		},
		{
		"name": "ipv6",
		"limited": false,
		"reachable": true,
		"proxy": "",
		"proxy_randomize_credentials": false
		},
		{
		"name": "onion",
		"limited": true,
		"reachable": false,
		"proxy": "",
		"proxy_randomize_credentials": false
		}
	],
	"relayfee": 0.00100000,
	"incrementalfee": 0.00001000,
	"localaddresses": [
	],
}

From here we can see that we are connected to 8 nodes. Which is the set maximum number of outgoing connections in the client. It's possible to open ports on your system to receive incoming connections, but this is not required. You can ignore the other information in there for this tutorial.

If you don't have any connections then you may need to wait a few minutes or you may have some networking issues on your computer, so you should sort that out before continuing.

Check Synchronisation

Next, lets check how far we are with syncing. Type in the following command.

xaya-cli -rpcuser=user -rpcpassword=password getblockchaininfo

Or with curl:

curl --user user:password --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "getblockchaininfo", "params": [] }' -H 'content-type: text/plain;' http://127.0.0.1:8396/

You'll get a result similar to this:

{
	"chain": "main",
	"blocks": 598466,
	"headers": 598466,
	"bestblockhash": "4ff74462ecde7624ed069687954da31cec2c3fc3328a669b7a62511a5ad7753d",
	"mediantime": 1550319823,
	"verificationprogress": 0.9999955845690718,
	"initialblockdownload": false,
	"chainwork": "0000000000000000000000000000000000000000001a29ea874e394c2041f282",
	"size_on_disk": 567360856,
	"pruned": false,
	"softforks": [
		{
		"id": "bip34",
		"version": 2,
		"reject": {
			"status": true
			}
		},
		{
		"id": "bip66",
		"version": 3,
		"reject": {
			"status": true
			}
		},
		{
		"id": "bip65",
		"version": 4,
		"reject": {
			"status": true
			}
		}
	],
	"bip9_softforks": {
	},
}

The value for blocks is the current block your client is synced with. The headers value is the current block number of the headers downloaded. Generally if you are still syncing, headers is greater than blocks. Once you are fully synced, blocks = headers.

You can check if you are fully synced by checking the block explorer, which should be on the latest block.

On Linux you can use the following command to see the blocks come in in real time.

watch xaya-cli -rpcuser=user -rpcpassword=password getblockchaininfo

What is CHI?

CHI is the native cryptocurrency for the XAYA blockchain. It powers transactions. Operations such as updating a name (see below) require tiny amounts of CHI. That small amount of CHI is a fee charged by miners who secure the blockchain.

Get a CHI Address

You'll need some CHI for some commands, but you'll need a CHI address first. CHI addresses are used to send and receive coins. Let's get you a CHI address. Issue the following command. You can change the label for the address, "This is my new address!", to anything you like.

xaya-cli -rpcuser=user -rpcpassword=password getnewaddress "This is my new address!"

Or with curl:

curl --user user:password --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "getnewaddress", "params": [] }' -H 'content-type: text/plain;' http://127.0.0.1:8396/

The daemon will return a single CHI address. It will look similar to the following.

CSdTuozaJbMsEjha54AbN6AFHSn4uT9nMX

Copy and save the address that the daemon returned. You can use it to receive CHI now. (Do not use the example address above.)

Get Some CHI

Our examples use mainnet which requires real CHI. For these tutorials, you'll need less than 0.1 CHI. Developers can ask for that CHI in our Forums, Telegram, or other channels. You need only provide a valid CHI address.

However, you can also do this on testnet or regtestnet for free. See here for more information about that.

Get Balance

Now that you have some CHI, let's check your balance. Try out the following command.

xaya-cli -rpcuser=user -rpcpassword=password getbalance

Your balance will be returned similar to this:

1.23456789

Create a XAYA Name

Names are the core of XAYA. Only YOU can control your name and do moves in games. Creating names is very easy.

In your command prompt, issue a command like this where "<my name>" is your chosen name:

xaya-cli -rpcuser=user -rpcpassword=password name_register "p/<my name>" "{}"

Or with curl:

curl --user user:password --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "name_register", "params": [{"p/<my name>"}] }' -H 'content-type: text/plain;' http://127.0.0.1:8396/

You should receive a response as a transaction ID, which is a long hexadecimal value, e.g.:

28d489d22ec3908978ce678746ad270a60254d8edd4a978d286d1251ebfb8043

If it fails, most likely you've tried to get a name that is already reserved. Check the error message and try again.

Congratulations! You've immortalised yourself on the XAYA blockchain!

Update the Value for Your Name

Now that you have a name, it's time to say hello! by updating it's value (aka submitting a move)

Try running the following command with the name you registered above.

xaya-cli -rpcuser=user -rpcpassword=password name_update "p/<my name>" "{\"g\":{\"helloworld\":{\"m\":\"Hello everybody!\"}}}"

Or with curl:

curl --user user:password --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "name_update", "params": ["p/<my name>", "new-value"] }' -H 'content-type: text/plain;' http://127.0.0.1:8396/

Congratulations! You just made a move in the "Hello World!" game! In a later tutorial you'll be able to see your move along with everyone else's moves and we'll explain the json object that is required for values on the chain.

Note how the value is escaped with back slashes.

View your name in the Blockchain

Now you or anyone in the world can lookup your name on the xaya blockchain. Try running the following command with your name.

xaya-cli -rpcuser=user -rpcpassword=password name_show "p/<my name>"

Or with curl:

curl --user user:password --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "name_show", "params": ["p/<my name>"] }' -H 'content-type: text/plain;' http://127.0.0.1:8396/

you should see some information about your name along with the value you set for it.

Congratulations! You've completed your first steps.

Clone this wiki locally