/blockchain-supply-chain

DApp for Coffe Suply Chain

Primary LanguageJavaScript

Blockchain Supply Chain Solution - Coffee

Rinkeby Trainsaction and Contract Address

   Deploying 'SupplyChain'
   -----------------------
   > transaction hash:    0xa95e68a29fa3e7deb91317f346e0449e2a36cd7f3fe912e72d234a212971d74b
   > Blocks: 1            Seconds: 12
   > contract address:    0x95dABfBd2D67D8E11e28e9e7728f75BaE159a334
   > block number:        5683764
   > block timestamp:     1577395787
   > account:             0x4ACF5e91813f31aDF278FF22921a210972aBcCc3
   > balance:             4.95651555
   > gas used:            3785474
   > gas price:           10 gwei
   > value sent:          0 ETH
   > total cost:          0.03785474 ETH

Link to the Contract: https://rinkeby.etherscan.io/address/0x95dabfbd2d67d8e11e28e9e7728f75bae159a334

Description

This project aims to solve the problem of tracking the full supply chain from the production of the coffee beans to the consumer hands.

This document uses UML to describre the general structure and functions that this Smart Contract offers to the actors:

  • Farmers
  • Distributors
  • Retailers
  • Consumers

Activity Diagram

This diagram shows the different actors and the interactions with the system.

Activity Diagram

Sequence Diagram

This diagram shows the communication between the different objects and their life cycle.

Sequence Diagram

State Diagram

This diagram shows the different states of each object and the events or conditions that change those states.

State Diagram

Data Modeling Diagram

This diagram shows the different Smart Contracts and the relation between them

Data Modeling Diagram

Getting Started

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes. See deployment for notes on how to deploy the project on a live system.

Prerequisites

Please make sure you've already installed ganache-cli, Truffle and enabled MetaMask extension in your browser.

Give examples (to be clarified)

Installing

A step by step series of examples that tell you have to get a development env running

Clone this repository:

git clone https://github.com/axelgalicia/blockchain-supply-chain/tree/master/project-6

Change directory to project-6 folder and install all requisite npm packages (as listed in package.json):

cd project-6
npm install

Launch Ganache:

ganache-cli -m "siege disagree message lake agree between walk confirm engage survey chicken become"

Your terminal should look something like this:

truffle test

In a separate terminal window, Compile smart contracts:

truffle compile

Your terminal should look something like this:

truffle test

This will create the smart contract artifacts in folder build\contracts.

Migrate smart contracts to the locally running blockchain, ganache-cli:

truffle migrate

Your terminal should look something like this:

truffle test

Test smart contracts:

truffle test

All 10 tests should pass.

truffle test

In a separate terminal window, launch the DApp:

npm run dev

Built With

  • Ethereum - Ethereum is a decentralized platform that runs smart contracts
  • Truffle Framework - Truffle is the most popular development framework for Ethereum with a mission to make your life a whole lot easier.
  • Infura - The Infura API suite provides instant access over HTTPS and WebSockets to the Ethereum and IPFS networks

Authors

Axel Galicia

See also the list of contributors who participated in this project.

Acknowledgments

  • Solidity
  • Ganache-cli
  • Truffle
  • Infura