Skip to content

Waste management supply chain transparency platform PoC based on the Ethereum blockchain.

License

Notifications You must be signed in to change notification settings

MVPWorkshop/greenchain

 
 

Repository files navigation

logo

Greenchain

Technology that makes Circular Economy our safe future.

GREENCHAIN’s goal is to mitigate environmental threats and to foster economic growth by enabling implementation of the pragmatic circular economy modules through tight and transparent monitoring of the waste supply chain, considering it a valuable resource and providing all the concerned parties to interact in ways they could never before by opening the door to an exciting future.

Greenchain is technology that can provide accountability to waste supply chain, both from the waste generation side as well as from the waste treatment end. The design principle behind solution is to enable free flow of waste and waste management information, aiming at removing current barriers to data interoperability, enabling transparency and access to respective information in real time, supporting such implementation of the circular economy concept.

Greenchain

Greenchain PoC is a decentralized application based on the Ethereum, based on the work on Trace project. It currently allows stakeholders to add waste management details to the app, as well as create certifications that can be added to data. A mobile companion app allows scanning Greenchain QR codes placed on the actual products to see the data on-premise (e.g. at the recycling factory).

Keep in mind that this is not production ready by any means.

Made using the Truffle toolkit, React.js, Redux, and Webpack.

Screenshot

scrot scrot

Installing / Getting started

  1. Clone the repo:

    git clone https://github.com/MVPWorkshop/greenchain.git
    cd greenchain
  2. Install the Truffle toolkit globally and install project dependencies:

    npm install -g truffle && npm install
  3. In a new shell, start the Truffle development console:

    truffle develop
  4. In the Truffle console, compile and deploy the smart contracts:

    This will effectively reset your local blockchain, meaning that all existing transactions will be deleted.

    migrate --reset
  5. Back in a regular shell, start the Webpack server:

    npm run start

    A browser window should then open automatically at http://localhost:3000 (or whatever port you set manually). If you see the Greenchain home page, you're ready to go. Otherwise, if the page is stuck on "Waiting for Web3...", proceed to steps 5 and 6.

  6. Install the MetaMask browser extension. Once installed, click on the MetaMask icon, then use the "Import Account" feature to create an account from a private key. Copy the first private key from the first few lines of output of truffle develop and paste it into the "Private Key" field in Metamask.

  7. Connect to your private network. Click the network chooser (it will likely say "Main Ethereum Network" at the top), and choose "Custom RPC". In there, enter the URL that matches the configuration in the truffle.js file (which should be http://localhost:9545 by default), then click "Save".

  8. Refresh the page in your browser, and you should be good to go!

Developing

To change something in the "smart contracts" side of things, you need to compile your contracts every time you change them using the following command in the Truffle console:

migrate --reset

As for the React front-end, the Webpack server should refresh the page in your browser automatically when a change is detected.

Building

Once you're ready to bundle the front-end app, use the build script to bundle everything together.

npm run build

Deploying

You're free to deploy the generated front-end bundle wherever you see fit. As for the smart contract, you can deploy it through Ganache/Truffle by adding a new network configuration. See this guide for more information.

Features

  • Add a waste data to the platform
  • Search for a particular waste
  • Add certifications to data (e.g. "pet", etc.)
  • Browse a product's version history
  • See the product's previous positions on a map
  • Combine products into one
  • Split a product into many (WIP)

Licensing

The code in this project is licensed under MIT license. See the LICENSE.

About

Waste management supply chain transparency platform PoC based on the Ethereum blockchain.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 98.8%
  • Other 1.2%