To make your ÐApp work with on Ethereum, you'll need to know about the Ethereum Javascript bindings, or, if you like, magic Javascript objects. These bindings may be used with AlethZero, Mist and external browser. These bindings can be found at ethereum.js repository.
There is, at the global scope, one objects; the web3
object, containing data handling functions (commonly used for all other APIs). This object also contains other subprotocol objects including the eth
object - web3.eth
(for specifically Ethereum interaction) and the shh
object - web3.shh
(for Whisper interaction). Over time we'll introduce other objects for each of the other web3 protocols.
- web3
- sha3 (_s1)
- toAscii (_s)
- fromAscii (_s, [_padding])
- toDecimal (_s)
- fromDecimal (_s)
- toFixed (_s)
- fromFixed (_s)
- offset (_s, _o)
- eth
- coinbase
- listening
- mining
- gasPrice
- accounts
- peerCount
- defaultBlock
- number
- balanceAt (_address)
- stateAt (_address, _storage)
- storageAt (_address)
- countAt (_address)
- codeAt (_address)
- transact (_object)
- block (_hash/_number)
- transaction (_object, _number)
- uncle (_hash/number)
- compilers ()
- lll (_string)
- solidity (_object)
- serpent (_object)
- logs (_object/_string)
- watch (_object/_string)
- db
- shh
- post (_object)
- newIdentity ()
- haveIdentity (_string)
- newGroup (_id, _who)
- addToGroup (_group, _who)
- watch (_object/_string)
Parameters are always data represented as hex, prefixed with an 0x
. There's automatic conversion from decimal strings to the hex representation (interpreted as a big-endian as is standard for Ethereum). So, the following two forms are identically interpreted:
"0x414243"
"4276803"
In each case, they are interpreted as the number 4276803. To convert to or from other datatypes, there are a number of conversion functions, detailed later.
The web3
object can be used for general data handling.
var web3 = require('web3')
Returns the SHA3 of the given data.
var str = web3.fromAscii("Some ASCII string to be hashed");
web3.sha3(str).then(function(hash){ console.log(hash + " is the hash."); });
Returns an ASCII string made from the data _s
.
var str = web3.toAscii("0x657468657265756d000000000000000000000000000000000000000000000000");
console.log(str); // ethereum
Returns data of the ASCII string _s
, auto-padded to _padding
bytes (default to 32) and left-aligned.
var str = web3.fromAscii('ethereum');
var str2 = web3.fromAscii('ethereum', 32);
console.log(str); // "0x657468657265756d000000000000000000000000000000000000000000000000"
console.log(str2); // "0x657468657265756d000000000000000000000000000000000000000000000000"
Returns the decimal string representing the data _s
(when interpreted as a big-endian integer).
var value = web3.toDecimal('0x15');
console.log(value === "21"); // true
Returns the hex data string representing (in big-endian format) the decimal integer _s
.
var value = web3.fromDecimal('21');
console.log(value === "0x15"); // true
Returns the floating-point number representing the data _s
(when interpreted as a fixed-point value divided by 2^128).
// TODO (_s)
Returns data representing the floating-point number _s
(when interpreted as a fixed-point value divided by 2^128).
// TODO (_s)
Returns data representing the data _s
when its numerical value is offset by the integer _o
. e.g. dev.offset("0x10", 10)
evaluates to "0x1a"
.
// TODO (_s, _o)
var eth = web3.eth;
#####web3.eth.coinbase Returns the coinbase address of the client.
web3.eth.coinbase.then(function (result) {
var coinbase = result;
console.log(coinbase); // "0x407d73d8a49eeb85d32cf465507dd71d507100c1"
});
#####web3.eth.listening Returns true if and only if the client is actively listening for network connections.
web3.eth.listening.then(function (result) {
var listening = result;
console.log(listening); // true of false
});
#####web3.eth.mining Returns true if and only if the client is actively mining new blocks.
web3.eth.mining.then(function (result) {
var mining = result;
console.log(mining); // true or false
});
#####web3.eth.gasPrice Returns the special 256-bit number equal to the hard-coded testnet price of gas.
web3.eth.gasPrice.then(function (result) {
var gasPrice = result;
console.log(gasPrice); // "0x09184e72a000"
});
#####web3.eth.accounts Returns the special key-pair list object corresponding to the address of each of the accounts owned by the client that this ÐApp has access to.
web3.eth.accounts.then(function (result) {
var accounts = result;
console.log(accounts); // ["0x407d73d8a49eeb85d32cf465507dd71d507100c1"]
});
#####web3.eth.peerCount Returns the number of peers currently connected to the client.
web3.eth.peerCount.then(function (result) {
var peerCount = result;
console.log(peerCount); // 4
});
#####web3.eth.defaultBlock The default block number/age to use when querying state. When positive this is a block number, when 0 or negative it is a block age. -1 therefore means the most recently mined block, 0 means the block being currently mined (i.e. to include pending transactions). Defaults to -1.
web3.eth.peerCount.then(function (result) {
var peerCount = result;
console.log(peerCount); // 4
});
#####web3.eth.number Returns the number of the most recent block.
web3.eth.number.then(function (result) {
var number = result;
console.log(number); // 2744
});
#####web3.eth.balanceAt
Returns the balance of the account of address given by the address _a
web3.eth.balanceAt("0x407d73d8a49eeb85d32cf465507dd71d507100c1").then(function (result) {
var balance = result;
console.log(balance); // "0x32884442997a37a000"
});
#####web3.eth.stateAt
Returns the value in storage at position given by the string _s
of the account of address given by the address _a
.
web3.eth.stateAt("0x407d73d8a49eeb85d32cf465507dd71d507100c1", 0).then(function (result) {
var state = result;
console.log(state); // "0x03"
});
#####web3.eth.storageAt Dumps storage as json object.
web3.eth.storageAt("0x407d73d8a49eeb85d32cf465507dd71d507100c1").then(function (result) {
var storage = result;
console.log(storage); // { "0x" : "0x03" }
});
#####web3.eth.countAt
Returns the number of transactions send from the account of address given by _a
.
web3.eth.countAt("0x407d73d8a49eeb85d32cf465507dd71d507100c1").then(function (result) {
var number = result;
console.log(number); // 1
});
#####web3.eth.codeAt
Returns true if the account of address given by _a
is a contract-account.
web3.eth.codeAt("0xd5677cf67b5aa051bb40496e68ad359eb97cfbf8").then(function (result) {
var code = result;
console.log(code); // "0x600160008035811a818181146012578301005b601b6001356025565b8060005260206000f25b600060078202905091905056"
});
#####web3.eth.block
Returns the block with number _number
. Return value is an object with the following keys:
hash
: The block hash (i.e. the SHA3 of the RLP-encoded dump of the block's header). A 32-byte hash.parentHash
: The parent block's hash (i.e. the SHA3 of the RLP-encoded dump of the parent block's header). A 32-byte hash.sha3Uncles
: The SHA3 of the RLP-encoded dump of the uncles portion of the block (a 32-byte hash).miner
: The address of the account that was rewarded for mining this block (né the coinbase address). A 20-byte address.stateRoot
: The root of the state trie (a 32-byte hash).transactionsRoot
: The root of the block's transactions trie (a 32-byte hash).difficulty
: The PoW difficulty of this block (a big int).number
: The number of this block (an integer).minGasPrice
: The minimum price, in Wei, of one GAS, that the miner accepted for any transactions in this block (a big int).gasLimit
: The gas limit of this block (an integer).gasUsed
: The amount of gas used in this block (an integer).timestamp
: The timestamp of this block (an integer).extraData
: Any extra data this block contains (a byte array).nonce
: The block's PoW nonce (a 32-byte hash).children
: The hashes of any children this block has (an array of 32-byte hashes)totalDifficulty
: The total difficulty of the entire chain up and including this block (a bigint).bloom
: The bloom filter of this block (a 32-byte hash).
web3.eth.block(3150).then(function (result) {
var info = result;
console.log(info);
/*{
"difficulty": "0x02a88f",
"extraData": "0x0000000000000000000000000000000000000000000000000000000000000000",
"gasLimit": 125000,
"hash": "80452e84d0d0599d779a4e466d0b70d50ca316499a8489604d5b9df436ccfeee",
"minGasPrice": "0x09184e72a000",
"miner": "0x407d73d8a49eeb85d32cf465507dd71d507100c1",
"nonce": "0xed0c6a53777b15880fb359dfd9368d002c959243a19c35ca1ae2e97f9bf78a53",
"number": 3150,
"parentHash": "0xf9de6948d835ed5257229b5103f9421a7f70c3ccc65fd31c0db85324e05702f5",
"sha3Uncles": "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347",
"stateRoot": "0xd878fcee309af964e8e70c66ec25b1e7de9eca9c4f49e90efddeea8f77a37e43",
"timestamp": 1416585210,
"transactionsRoot": "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421"
} */
});
#####web3.eth.transaction
Returns the transaction number _i
from block with number _number
. Return value is an object with the following keys:
hash
: The hash of the transaction. A 32-byte hash.input
: The binary data that formed the input to the transaction, either the input data if it was a message call or the contract initialisation if it was a contract creation. A byte array.to
: The address to which the transaction was sent. This may be the null address (address 0) if it was a contract-creation transaction (a 20-byte address).from
: The cryptographically verified address from which the transaction was sent (a 20-byte address).gas
: The amount of GAS supplied for this transaction to happen (an integer).gasPrice
: The price offered to the miner to purchase this amount of GAS, in Wei/GAS (a big int).nonce
: The transaction nonce (an integer).value
: The amount of ETH to be transferred to the recipient with the transaction (a big int).
// TODO (_number, _i), (_hash, _i)
#####web3.eth.uncle
Returns the uncle number _i
from block with number _number
. Return value is an object with the following keys:
hash
: The block hash (i.e. the SHA3 of the RLP-encoded dump of the block's header). A 32-byte hash.parentHash
: The parent block's hash (i.e. the SHA3 of the RLP-encoded dump of the parent block's header). A 32-byte hash.sha3Uncles
: The SHA3 of the RLP-encoded dump of the uncles portion of the block (a 32-byte hash).miner
: The address of the account that was rewarded for mining this block (né the coinbase address). A 20-byte address.stateRoot
: The root of the state trie (a 32-byte hash).transactionsRoot
: The root of the block's transactions trie (a 32-byte hash).difficulty
: The PoW difficulty of this block (a big int).number
: The number of this block (an integer).minGasPrice
: The minimum price, in Wei, of one GAS, that the miner accepted for any transactions in this block (a big int).gasLimit
: The gas limit of this block (an integer).gasUsed
: The amount of gas used in this block (an integer).timestamp
: The timestamp of this block (an integer).extraData
: Any extra data this block contains (a byte array).nonce
: The block's PoW nonce (a 32-byte hash).
// TODO (_number, _i), (_hash, _i)
#####web3.eth.transact Creates a new message-call transaction.
_params
, an anonymous object specifying the parameters of the transaction.from
, the address for the sending account;value
, the value transferred for the transaction (in Wei), also the endowment if it's a contract-creation transaction;endowment
, synonym forvalue
;to
, the destination address of the message, left undefined for a contract-creation transaction;data
, either a byte string containing the associated data of the message, or in the case of a contract-creation transaction, the initialisation code;code
, a synonym fordata
;gas
, the amount of gas to purchase for the transaction (unused gas is refunded), defaults to the most gas your ether balance allows; andgasPrice
, the price of gas for this transaction, defaults to the mean network gasPrice.
_fn
, the callback function, called on completion of the transaction. If the transaction was a contract-creation transaction, it is passed with a single argument; the address of the new account.
// TODO
#####web3.eth.call Executes a new message-call immediately without creating a transaction on the block chain.
_params
, an anonymous object specifying the parameters of the transaction, similar to that above._fn
, the callback function, called on completion of the message call. A single argument is passed equal to the output data of the message call.
// TODO
#####web3.eth.logs
Past messages may be filtered and their attributes inspected, and future messages (and the changes they implicitly bring) may be notified of. Returns the list of log entries in Ethereum matching the given _filter
. The filter is an object including fields:
earliest
: The number of the earliest block (-1 may be given to mean the most recent, currently mining, block).latest
: The number of the latest block (-1 may be given to mean the most recent, currently mining, block).max
: The maximum number of messages to return.skip
: The number of messages to skip before the list is constructed. May be used withmax
to paginate messages into multiple calls.address
: An address or a list of addresses to restrict log entries by requiring them to be made from a particular account.topic
: A set of values which must each appear in the log entries.- Returns a list of log entries; each includes the following fields:
address
: The address of the account whose execution of the message resulted in the log entry being made.topics
: The topic(s) of the message.data
: The associated data of the message.
#####web3.eth.watch
web3.eth.watch(_filter)
: Creates a watch object to notify when the state changes in a particular way, given by _filter
. Filter may be a log filter object, as defined above. It may also be either 'chain'
or 'pending'
to watch for changes in the chain or pending transactions respectively. Returns a watch object with the following methods:
changed(_f)
: Installs a handler,_f
, which is called when the state changes due to messages that fit_filter
.logs()
: Returns the log entries that fit_filter
.uninstall()
: Uninstalls the watch. Should always be called once it is done with.
// TODO (_filter)
#####web3.eth.compilers Returns an array of available compilers
web3.eth.compilers().then(function (result) {
var number = result;
console.log(number); // ["lll", "solidity", "serpent"]
});
#####web3.eth.solidity
Compiles the solidity source code _s
and returns the output data.
// TODO (_code)
web3.eth.solidity("").then(function (result) {
var number = result;
});
#####web3.eth.lll
Compiles the LLL source code _s
and returns the output data.
// TODO (_code)
#####web3.eth.serpent
Compiles the serpent source code _s
and returns the output data.
// TODO (_code)
A simple HTML snippet that will display the user's primary account balance of Ether:
<html><body>
<div>You have <span id="ether">?</span> Weis</div>
<script>
web3.eth.watch({altered: web3.eth.coinbase}).changed(function() {
web3.eth.balanceAt(web3.eth.coinbase).then(function (balance) {
document.getElementById("ether").innerText = web3.toDecimal(balance);
});
});
</script>
</body></html>
To test it, just put it in file and save. Load it in AlethZero and point the URL to file:///WHEREVER_YOU_SAVED_IT
Job done. Now go create.
more examples can be found here
- Moved "Misc" into web3.* object.
- Removed all secret keys from the JS API.
- Altered naming to web3.
- Added web3.db and web3.ssh objects
- Added usage examples to JavaScript-Api wiki page.
- Proscribe particular bigint objects for numerical manipulation.
- Integrate Paperscript-style preprocessing to allow for operator overloading.
- Add more examples to ethereum.js