- Title
- Getting Started
- Install
- Usage
- Creating a smart contract
- dApploy an ABI to IPFS
- dApploy to public testnet or mainnet
- Use S3 to host your ABI
- License
- Credits
Finally, you can deploy dApps in less than 5 seconds flat WITHOUT even lifting a finger... Guaranteed!
OK, you may have to lift a finger.
But here's the deal.
We've gone through the hoops of deploying dApps on the Ethereum Network and have nuked out all of the annoying parts to make dapployment a breeze.
-
Install from source to get access to the sample projects. Remember, 'YARN ALL THE THINGS' from the main project dir by running this:
yarn && cd samples/sample-datavault-react/ && yarn && cd ../sample-datavault-solidity && yarn && cd ../..
-
OR globally install Dapploy using:
yarn global add @xyo-network/tool-dapploy-nodejs
OR
npm install -g @xyo-network/tool-dapploy-nodejs
-
Run
dapploy -h
to see the options:$> dapploy -h Usage: dapploy [options] [command]
Options:
-V, --version output the version number -t, --projectDir
Truffle Project Directory -n, --network [network] Deploy to network (default: development) -c, --config Config file (default: .dapploy) -o, --contractOutput Contract Output Directory -x, --excludeContracts [Contract1,Contract2] Exclude contracts from the web3 interface (files are still copied) -a, --includeContracts [Contract1,Contract2] Include contracts from the web3 interface (files are still copied) -l, --clean Clean contracts before migrating -r, --remoteOnly Only copy contracts remote -p, --pinToIpfs Pin contracts to IPFS for remote -P, --postSaveToIpfs Save contracts to IPFS for remoteaccess after migrating -k, --bucketName Do remote copy of ABI to aws bucket (make sure to setup ~/.aws) -y, --copyOnly Only do folder copy and S3 copy -i, --init Add default config file to current directory -h, --help output usage information$> dapploy init -h Usage: init [options] [dir]
Configure a new truffle project from scratch
Options:
-g, --configOnly Create dapploy config file in current directory -s, --specifyContract [contract] Which type of project to create. Supporting: [ERC20, ERC721] (default: ERC20) -h, --help output usage information
-
If you did not add dapploy globally with '-g', Add dapploy alias to run from any project in your bash_profile:
echo "alias dapploy="/<path_to_project>/tool-dapploy-nodejs/dapploy""| cat >> .bash_profile
dapploy init
- create a new smart contract project
-
Create a new ERC20 project using dapploy:
dapploy init my-first-coin -s ERC20 cd my-first-coin
-
Make sure Ganache is downloaded, installed and open: Download and install Ganache from their site
- Click the Gear Icon thingy ( ⚙️ ) to open
Preferences...
Make sure that port is set to 8545.
- Dapploy from root directory
-
if you have alias setup for dapploy, just run
dapploy
-
otherwise run
</path/to>/dapploy
Congrats, you just built your first ERC-20 Token! Head on over to Dapper to play with it in a web-ui
dapploy -p
$ Contracts stored to IPFS QmZ2Ezv4nsQ5tqGoHz4pUxa9GW88TWKMSzdxdMfxsHerWT
$ View contracts at https://ipfs.xyo.network/ipfs/QmZ2Ezv4nsQ5tqGoHz4pUxa9GW88TWKMSzdxdMfxsHerWT
- Sign into Metamask and change Network on Metamask to kovan/ropsten/mainnet
-
Add your metamask wallet and infura data to
env.template
file:WALLET=// wallet used to deploy contracts INFURA_API_KEY=// API key you get from infura MNENOMIC=// 12 word pass key from derived from your wallet private key
-
Move
env.template
to.env
(this file is already in your .gitignore)mv env.template .env
-
Using kovan, run
dapploy -n kovan
Ropsten:
dapploy -n ropsten
NOTE You don't need to specify -n network
if you change .dapploy
configuration file in your project from network=development
to network=kovan
etc.
vi .dapploy
If you are feeling adventurous run a local testnet node:
Ropsten testnet node setup (Geth)
Kovan testnet node setup (Parity)
-
Setup account with portis.io
-
Add Portis and Infura key to .dapploy
vi .dapploy
Uncomment:
# [Portis]
# portisApiKey=<API_KEY>
# infuraApiKey=<INFURA_API_KEY>
-
Confugure your AWS credentials in terminal by creating credentials file. S3 credential instructions here:
vi ~/.aws/credentials [default] aws_access_key_id = AKIAIFYQ4UEUUJ6GDH6A aws_secret_access_key = FAKEasdfas=aqewrasdfa/sdfasdfasdfasdfFAKE
-
Configure dapploy
vi .dapploy
Uncomment:
#[AWS]
#bucketName=layerone.smart-contracts
#remotePath=ABI
See the LICENSE file for license details.
Made with 🔥and ❄️ by XYO