2015-10-12 18:33:00 -04:00
This Readme applies to Embark 1.0.0 Beta which is currently under development. For the old version please check the old [readme ](https://github.com/iurimatias/embark-framework/blob/0.9.3/README.md )
2015-05-25 08:21:53 -04:00
What is embark
======
2015-05-26 14:35:07 +00:00
[![Join the chat at https://gitter.im/iurimatias/embark-framework ](https://badges.gitter.im/Join%20Chat.svg )](https://gitter.im/iurimatias/embark-framework?utm_source=badge& utm_medium=badge& utm_campaign=pr-badge& utm_content=badge)
2015-06-21 22:14:22 -04:00
Embark is a framework that allows you to easily develop and deploy DApps.
With Embark you can:
* Automatically deploy contracts and make them available in your JS code. Embark watches for changes, and if you update a contract, Embark will automatically redeploy the contracts (if needed) and the dapp.
2015-08-31 08:33:15 -04:00
* Use any build pipeline or tool you wish, including grunt and meteor.
2015-06-21 22:14:22 -04:00
* Do Test Driven Development with Contracts using Javascript.
* Easily deploy to & use decentralized systems such as IPFS.
2015-08-31 08:33:15 -04:00
* Keep track of deployed contracts, deploy only when truly needed.
2015-10-12 18:33:00 -04:00
* Manage different chains (e.g testnet, private net, livenet)
2015-06-21 22:14:22 -04:00
* Quickly create advanced DApps using multiple contracts.
2015-05-25 08:21:53 -04:00
2015-06-22 06:07:46 -04:00
See the [Wiki ](https://github.com/iurimatias/embark-framework/wiki ) for more details.
2015-05-25 08:21:53 -04:00
Installation
======
2015-10-12 18:54:30 -04:00
Requirements: geth (1.1.3 or higher), node (0.12.2) and npm
2015-10-12 18:33:00 -04:00
Optional: serpent (develop) if using contracts with Serpent
2015-05-25 08:21:53 -04:00
```Bash
2015-10-13 16:15:51 -04:00
$ npm -g install embark-framework
2015-05-25 08:21:53 -04:00
```
2015-06-22 06:07:46 -04:00
See [Complete Installation Instructions ](https://github.com/iurimatias/embark-framework/wiki/Installation ).
2015-05-25 08:21:53 -04:00
Usage - Demo
======
You can easily create a sample working DApp with the following:
```Bash
$ embark demo
$ cd embark_demo
```
2015-10-12 18:33:00 -04:00
To run a ethereum rpc simulator simply run:
```Bash
$ embark simulator
```
Or Alternatively, you can run a REAL ethereum node for development purposes:
2015-05-25 08:21:53 -04:00
```Bash
$ embark blockchain
```
2015-10-12 18:33:00 -04:00
2015-05-25 08:21:53 -04:00
By default embark blockchain will mine a minimum amount of ether and will only mine when new transactions come in. This is quite usefull to keep a low CPU. The option can be configured at config/blockchain.yml
Then, in another command line:
```Bash
$ embark run
```
This will automatically deploy the contracts, update their JS bindings and deploy your DApp to a local server at http://localhost:8000
Note that if you update your code it will automatically be re-deployed, contracts included. There is no need to restart embark, refreshing the page on the browser will do.
2015-08-31 22:00:07 -04:00
note: for a demo using meteor do ```embark meteor_demo` `` followed by ` ``embark deploy` `` then ` ``meteor` ``
2015-05-25 08:21:53 -04:00
Creating a new DApp
======
```Bash
$ embark new AppName
$ cd AppName
```
DApp Structure
======
```Bash
app/
2015-08-31 08:33:15 -04:00
|___ contracts/ #solidity or serpent contracts
2015-06-21 22:14:22 -04:00
|___ html/
|___ css/
|___ js/
2015-05-25 08:21:53 -04:00
config/
|___ blockchain.yml #environments configuration
2015-06-21 22:14:22 -04:00
|___ contracts.yml #contracts configuration
2015-05-25 08:21:53 -04:00
|___ server.yml #server configuration
2015-06-21 22:14:22 -04:00
spec/
|___ contracts/ #contracts tests
```
2015-05-25 08:21:53 -04:00
2015-08-31 08:33:15 -04:00
Solidity/Serpent files in the contracts directory will automatically be deployed with embark run. Changes in any files will automatically be reflected in app, changes to contracts will result in a redeployment and update of their JS Bindings
2015-05-25 08:21:53 -04:00
Using Contracts
======
Embark will automatically take care of deployment for you and set all needed JS bindings. For example, the contract below:
```Javascript
# app/contracts/simple_storage.sol
contract SimpleStorage {
2015-06-22 07:54:22 -04:00
uint public storedData;
function SimpleStorage(uint initialValue) {
storedData = initialValue;
}
2015-05-25 08:21:53 -04:00
function set(uint x) {
storedData = x;
}
function get() constant returns (uint retVal) {
return storedData;
}
}
```
Will automatically be available in Javascript as:
```Javascript
# app/js/index.js
SimpleStorage.set(100);
SimpleStorage.get();
2015-06-22 07:54:22 -04:00
SimpleStorage.storedData();
2015-05-25 08:21:53 -04:00
```
2015-06-21 22:14:22 -04:00
You can specify for each contract and environment its gas costs and arguments:
```Yaml
# config/contracts.yml
development:
SimpleStorage:
gas_limit: 500000
gas_price: 10000000000000
args:
- 100
...
```
If you are using multiple contracts, you can pass a reference to another contract as ```$ContractName` ``, Embark will automatically replace this with the correct address for the contract.
```Yaml
# config/contracts.yml
development:
SimpleStorage:
args:
- 100
- $MyStorage
MyStorage:
args:
- "initial string"
MyMainContract:
args:
- $SimpleStorage
...
```
2015-07-15 08:06:40 -04:00
You can now deploy many instances of the same contract. e.g
```Yaml
# config/contracts.yml
development:
Currency:
2015-08-31 21:02:21 -04:00
deploy: false
2015-07-15 08:06:40 -04:00
args:
- 100
Usd:
instanceOf: Currency
args:
- "initial string"
MyCoin:
instanceOf: Currency
args:
- $SimpleStorage
...
```
Contracts addresses can be defined, If an address is defined the contract wouldn't be deployed but its defined address will be used instead.
```Yaml
development:
UserStorage:
address: 0x123456
UserManagement:
args:
- $UserStorage
...
```
2015-08-31 08:33:15 -04:00
You can also define contract interfaces (Stubs) and actions to do on deployment
```Yaml
development:
DataSource:
args:
MyDataSource:
args:
instanceOf: DataSource
Manager:
stubs:
- DataSource
args:
- $MyDataSource
onDeploy:
- Manager.updateStorage($MyDataSource)
- MyDataSource.set(5)
...
```
2015-06-21 22:14:22 -04:00
Tests
======
2015-10-12 18:33:00 -04:00
You can run specs with ```embark spec` ``, it will run any test files under ` ``test/` ``.
2015-06-21 22:14:22 -04:00
2015-09-04 11:18:54 +02:00
Embark includes a testing lib to fastly run & test your contracts in a EVM.
2015-06-21 22:14:22 -04:00
```Javascript
2015-10-12 18:33:00 -04:00
# test/simple_storage_spec.js
var assert = require('assert');
var Embark = require('embark-framework');
var EmbarkSpec = Embark.initTests();
describe("SimpleStorage", function(done) {
before(function(done) {
EmbarkSpec.deployAll(done);
2015-06-21 22:14:22 -04:00
});
2015-10-12 18:33:00 -04:00
it("should set constructor value", function(done) {
SimpleStorage.storedData(function(err, result) {
assert.equal(result.toNumber(), 100);
done();
});
2015-06-21 22:14:22 -04:00
});
2015-10-12 18:33:00 -04:00
it("set storage value", function(done) {
SimpleStorage.set(150, function() {
SimpleStorage.get(function(err, result) {
assert.equal(result.toNumber(), 150);
done();
});
});
2015-06-21 22:14:22 -04:00
});
})
```
2015-10-12 18:33:00 -04:00
Embark uses [Mocha ](http://mochajs.org/ ) by default, but you can use any testing framework you want.
2015-06-21 22:14:22 -04:00
2015-05-25 08:21:53 -04:00
Working with different chains
======
2015-06-22 06:13:04 -04:00
You can specify which environment to deploy to:
2015-05-25 08:21:53 -04:00
2015-06-22 06:13:04 -04:00
```$ embark blockchain staging` ``
```$ embark run staging` ``
The environment is a specific blockchain configuration that can be managed at config/blockchain.yml
2015-05-25 08:21:53 -04:00
```Yaml
# config/blockchain.yml
...
staging:
rpc_host: localhost
rpc_port: 8101
rpc_whitelist: "*"
datadir: default
2015-09-04 11:18:54 +02:00
chains: chains_staging.json
2015-05-25 08:21:53 -04:00
network_id: 0
console: true
2015-09-25 08:47:51 +01:00
geth_extra_opts: --vmdebug
2015-05-25 08:21:53 -04:00
account:
init: false
address: 0x123
```
2015-06-22 06:18:11 -04:00
See [Configuration ](https://github.com/iurimatias/embark-framework/wiki/Configuration ).
2015-05-25 08:21:53 -04:00
Deploying only contracts
======
Although embark run will automatically deploy contracts, you can choose to only deploy the contracts to a specific environment
```Bash
$ embark deploy privatenet
```
embark deploy will deploy all contracts at app/contracts and return the resulting addresses
2015-08-31 22:03:02 -04:00
Structuring Application
======
Embark is quite flexible and you can configure you're own directory structure using ```embark.yml` ``
```Yaml
# embark.yml
type: "manual" #other options: meteor, grunt
contracts: ["app/contracts/**/*.sol", "app/contracts/**/*.se"] # contracts files
output: "src/embark.js" # resulting javascript interface
blockchainConfig: "config/blockchain.yml" # blockchain config
contractsConfig: "config/contracts.yml" # contracts config
```
2015-08-31 22:06:30 -04:00
Deploying to IPFS
======
To deploy a dapp to IPFS, all you need to do is run a local IPFS node and then run ```embark ipfs` ``.
If you want to deploy to the live net then after configuring you account on ```config/blockchain.yml` `` on the ` ``production` `` environment then you can deploy to that chain by specifying the environment ` ``embark ipfs production` ``.
2015-05-25 08:21:53 -04:00
LiveReload Plugin
======
Embark works quite well with the LiveReload Plugin
2015-07-09 08:55:45 +02:00
Debugging embark
======
2015-07-09 11:03:06 +02:00
Because embark is internally using grunt tasks, debugging is not straightforward. Example
2015-07-09 08:55:45 +02:00
- you want to debug `embark deploy`
- normally you would write something like `node-debug -p 7000 embark -- deploy`
- This gives you nothing with embark. If you look at `deploy` command in [`./bin/embark` ](https://github.com/iurimatias/embark-framework/blob/develop/bin/embark#L32-L35 ) you will notice that it internally runs grunt task `grunt deploy_contracts:[env]`
2015-07-09 11:03:06 +02:00
- with this knowledge we can prepare proper command to start debugging
2015-08-31 21:39:47 -04:00
- ```node-debug -p 7000 grunt -- deploy_contracts:development` ``
2015-08-31 20:19:07 -04:00
2015-08-31 21:39:47 -04:00
[here ](https://github.com/iurimatias/embark-framework/blob/develop/tasks/tasks.coffee ) is list of all debuggable grunt tasks
2015-08-31 20:19:07 -04:00
EACCESS Error
======
If you get EACCES (access denied) errors, don't use sudo, try this:
```Bash
$ mkdir ~/npm-global
$ npm config set prefix ~/npm-global
$ echo 'export PATH="$PATH:$HOME/npm-global/bin"' >>~/.bashrc
$ source ~/.bashrc
$ npm install -g embark-framework grunt-cli
```