Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/codeamt/ethico

A web3 client built with webpack.js to demo purchasing an asset from an ICO smart contract. Powered by Metamask, Truffle, and Ganache
https://github.com/codeamt/ethico

Last synced: 2 months ago
JSON representation

A web3 client built with webpack.js to demo purchasing an asset from an ICO smart contract. Powered by Metamask, Truffle, and Ganache

Awesome Lists containing this project

README

        

ethICO


This is a simple decentralized app (dApp) to help launch/manage an Initial Coin Offering (ICO) backed by Ether and the Ethereum blockchain. The dApp utilizes Truffle, Metamask and Ganache to deploy and test contracts:




## Demo on Ropsten Network
This demo is hosted on Heroku and works if you have the Metamask extension for your browser installed. More details on installation below.



- Live Demo: [https://ico-launcher.herokuapp.com/](https://ico-launcher.herokuapp.com/)

This dAPP implements three solidity contracts deployed to the Ropsten Testnet -- Fundraiser.sol, Fund.sol, and FundCoin.sol (the pretend asset of the fundraiser).

## Iterating on Repo Locally

To run the app in your own development environment, you need Node.js / NPM, Webpack, Truffle, and Optionally Ganache. To get these build essentials, do the following...

1. Install Homebrew:

In the terminal:

```
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
brew update
brew doctor
brew prune
brew -v
```

2. Install Node, NPM, Weback and Truffle

Now, install build essentials (if you don't have these already:

```
brew install node #installs both node and npm
npm install -g truffle
npm install -g webpack #for the cli
node -v
npm -v
truffle -v
webpack -v
```

3. Clone this repo

Then, clone a copy of this repo:

```
git clone https://github.com/codeamt/ethICO.git
```

4. Install/Setup Metamask

Metamask has a few extensions available, depending upon your preferred browser (Chrome, Firefox, or Opera), but also
offers their own web3 browser [Brave](https://brave.com/).

To get the right extension, download [here](https://metamask.io/).

Once you've completed the Metamask onboarding process, switch the network from the MainNet to Ropsten Testnet.

Steps:

- Go back to the Metamask extension, click on the drop down menu where it says MainNet and select the "Ropsten Test Network" option:




Metamask will automagically generate your first eth account on the Testnet for you.

5. Run the Project and Launch an ICO Campaign!

In the terminal:

```
cd ethICO && npm run dev
```


Now go to http://localhost:7545 in the browser, and the dApp should be running out of the box! You can launch the ICO and purchase FundCoin (FDC) to contribute! Since this app is only for demonstrative purposes, the Withdrawal functionality is intentially left out.

To iterate on this project, delete index.html and app.js in the build directory, make changes, save and run:

```
npm run build
```


The build folder should be populated with browser-friendly versions of your updated index.html and app.js.


6. Download/Install Truffle's Ganache (Optional)

Ganache sets up a local rpc server and blockchain for testing purposes. It also comes with 5 Ethereum test accounts, preloaded with ether.

Download here: [Ganache Download for Mac OS](https://github.com/trufflesuite/ganache/releases/download/v1.1.0/Ganache-1.1.0.dmg)

Once downloaded and launched, your dashboard should look like this:





Localhost will use Ganache now. To import Ganache addresses into Metamask:

Steps:
- In Ganache, copy the RPC server url up at the top (which should be http://127.0.0.1:7545)
- Go back to the Metamask extension, click on the drop down menu where it says MainNet and select the "Custom RPC" option:





- Then paste the Ganache RPC url where it says "New RPC url" and save:




Again, Metamask will automagically import your first eth address listed in Ganache. To import more than one Ganache account:

- In Ganache, under accounts, click on the key icon by one of the other accounts you'd like to sync with Metamask and copy its private key.
- Back in Metamask, click on the user profile icon and select "import address"




- Paste the private key you copied into the input: