Simple PoC that shows you how to use IPFS and Ethereum blockchain to store files and their information.
You can check out the live application 👉 here 👈.
This sample project was prepared as a response to the need of durable medium required by some Polish acts. It helps in persistent storage of files in distributed file system with information saved in immutable and distributed ledger.
The application can be run either through Docker or by running all of the necessary services manually.
In order to run the application, please follow the steps:
-
Ensure that you have Docker installed and that
docker compose
is available in the command line. -
Clone the repository and navigate to the root directory.
-
Run
docker compose up
in a console window. This may take a while. Once you see the text:application_1 | Compiled successfully! application_1 | application_1 | You can now view docuhash in the browser. application_1 | application_1 | Local: http://localhost:3000 application_1 | On Your Network: http://172.22.0.4:3000 application_1 | application_1 | Note that the development build is not optimized. application_1 | To create a production build, use yarn build.
you should be able to open the application in the browser by navigating to
localhost:3000
. Keep the console window open.
In order to run the application, please follow the steps:
- Install the following tools and ensure that they are available from the command line:
- Node.js (latest LTS version is recommended),
- Truffle (version 5.*),
- IPFS Desktop.
- Clone the repository and navigate to the
eth
directory. - In the console run
truffle develop
. - In the interactive Truffle console, run
compile
, followed bymigrate --reset
. Keep the console window open. - In a new console window, navigate to the directory containing the IPFS executable.
- Run in sequence:
Keep the console window open.
> ipfs config --json API.HTTPHeaders.Access-Control-Allow-Origin '[\"*\"]' > ipfs bootstram rm --all > ipfs daemon
- In a new console window, navigate to the root directory.
- Run
yarn
followed byyarn start
. Keep the console window open. A new browser window/tab should automatically open and the application should shortly load within it.
DocuHash has been deployed to the MS Azure cloud. The following steps can be followed in order to deploy another instance of the PoC:
-
Clone the repository.
-
Install Azure CLI and Docker. Ensure that az and docker commands are available from the command line.
> az -v azure-cli 2.25.0 > docker -v Docker version 20.10.6, build 370c289
-
Open PowerShell terminal.
-
Log in to your Azure account by running
az login
. Optionally set a subscription you want the application to be deployed to by runningaz account set -s <name or id of the subscription>
. -
Modify values inside deploy/parameters.json file, in parameters section:
location
- location to which services will be deployed. You can view the full list of available locations by runningaz account list-locations -o table
.resource_group_name
- name of the resource group to which services will be deployed. Needs to be unique in scope of the subscription.service_plan_name
- name of the app service plan on which the applications will run. Needs to be unique in scope of the resource group.container_registry_name
- name of the container registry used for storing Docker images. Needs to be globally unique.client_app_repo_name
- name of the repository/image of the client application. Needs to be unique in scope of the container registry.ipfs_app_repo_name
- name of the repository/image of the IPFS application. Needs to be unique in scope of the container registry.client_app_name
- name of the client application. Needs to be globally unique.ipfs_app_name
- name of the IPFS application. Needs to be globally unique.eth_app_name
- name of the ETH application. Needs to be globally unique.
-
Modify the
dockerEntrypoint.sh
file located in the repo's root directory. In the third line, change--network demo
to--network production
. -
Navigate to the
deploy
directory and run.\deploy.ps1
. Deployment may take up to several minutes, depending on your Internet connection speed and the processing power of your machine. -
Once deployment is finished, navigate in your browser to
https://<client_app_name>.azurewebsites.net
. Wait for a few minutes and refresh the page once in a while while waiting for the containers to spin up. Do not worry about potential errors initially showing in the browser window. Eventually the application should appear in the browser. If the application doesn't start after several minutes, consider checking logs for each of the app services created during deployment in order to pinpoint the issue.
The first version of this PoC was fully described in this article. You may refer to it for more verbose description of the project, though some technical aspects may have become obsolete.
This Proof of Concept is licensed under MIT License, we will be more than happy if you consider it as valuable. Feel free to contact us at [email protected]