Skip to content

Latest commit

 

History

History
103 lines (67 loc) · 6.53 KB

File metadata and controls

103 lines (67 loc) · 6.53 KB

CryptoGive

CryptoGive is a platform for donating to your choice of charity programs with cryptocurrency.

Home View Donations View
Screen Shot 2021-12-01 at 8 16 50 PM Screen Shot 2021-12-01 at 8 18 52 PM

How does a blockchain help?

Donation platforms already exist – how is one based on a public blockchain an improvement?

  • Ease of use: Anyone with a wallet can donate, regardless of banking or credit access, in amounts that are not always possible with traditional currency.
  • Trust: Public blockchains can remove the need for trust between parties, as all transfers and wallet balances can be confirmed and scrutinized.
  • Transparency: Charitable activity is easily verified in the open, and donors can more easily track and confirm their own activity across multiple charities.
  • Speed and efficiency: Donations land in charities' wallets immediately, with no intermediaries taking a cut. Minimal infrastructure or technical needs are required by the charity.

How does CryptoGive work?

The platform owner can register charities, who in turn register programs/campaigns. Potential donors select from the active programs available and donate an amount in ether (which is then transferred to the address of the charity).

Owners

The owner is the address that deployed the contract. The owner can:

  • Register new charities.
  • Remove existing charities.

Charities

A charity must first be registered by the owner. A registered charity can:

  • Register a new program.
  • Cancel an active program.
  • Declare an active program completed.
  • Remove themselves from the platform (not available in the UI).

Donors

Anyone can be a donor to any active program, and see their own past donations.


Project implementation

CryptoGive is a standard-configured Truffle project with few dependencies. The client app is stateless and written in vanilla JavaScript, with each page loading only the scripts it needs. Other than the contract migrations, the project does not require a build process.

It uses ethers.js and MetaMask as providers and the wallet.

The project UI is publicly available at https://blockchain-bootcamp-project.web.app/, which uses the deployed contract on the Ropsten network.

To develop the project locally, you will need Truffle v5.4.15 or higher (Truffle's own requirements are Node v8.9.4 or later, and Linux, MacOS, or Windows).

Directory structure

  • contracts/: Solidity contracts – the project's only contract is Fundraisers.sol.
  • notes/: Initial exploration.
  • src/: Client app.
  • test/: Unit tests for the contract in JS.

Installation

  • Use node -v to verify your Node version is at least v8.9.4. If not, follow Node's instructions for installation or updating.
  • Use truffle --version to verify your Truffle installation is at least v5.4.15. If not, follow their instructions to update or install it (try npm install -g truffle for the latest version).
  • Clone this repository to your local machine with git clone [email protected]:kwight/blockchain-developer-bootcamp-final-project.git (assumes you have SSH keys set up – HTTPS will work fine too).
  • cd into the root of your cloned repo.
  • Run npm install to fetch the package dependencies.
  • Run truffle develop. This will start up a local blockchain and give you a console.
  • Make note of the URL and port; if you're not using the defaults, or are using another blockchain such as Ganache, this line will need to be updated, as well as the development network in truffle-config.js.
  • In that console, deploy the contract with migrate --reset.
  • Create an instance of the contract with f = await Fundraisers.deployed().
  • Enter f.address to get the contract's local address, and enter it on this line.
  • The client UI is served as static files from /src. In that directory in a different terminal window (keep the development console running), run npx serve and open the given URL in your browser. Any local webserver service run from that directory will also work.
  • Back in the console, run test to verify the contract unit tests all pass.

You're all set – you've got a console with access to the deployed contract on the local blockchain, and a front-end in your browser that's using the local blockchain as its data source.

Development

Here are some commands you can use to interact with the contract from the console. These assume you've set the f variable from the installation notes above. Remember that on the local blockchain, the contract owner is the accounts[0] account (which is the default from: value when one isn't specified). If the client UI is open while running commands on the console, it will update automatically.

  • Register a charity: f.registerCharity(accounts[1], 'SPCA')
  • Register a program: f.registerProgram('Cat Adoption', {from: accounts[1]})
  • Register another program: f.registerProgram('Dog Rescue', {from: accounts[1]})
  • View the registered programs: f.getPrograms()
  • Mark the first program as complete: f.completeProgram(0, {from: accounts[1]})
  • Donate to the dog rescue from that account: f.donate(1, {from: accounts[9], value:55555555555555})

Deployment

The project uses dotenv for managing keys when deploying to public networks. Create a local .env file (which is gitignored) with the following constants. Ropsten is already configured (other networks would need to be added to truffle-config.js).

  • PRIVATE_KEY: Private key of the account that should be owner on deployment.
  • INFURA_URL: Infura URL with the project ID.

Address for certification: kwight.eth (0x0808832994E697C9c1A3e76a60A7e0c75e52348a)