This API is running on https://api.openfuture.io.
Documentation is available at https://docs.openfuture.io.
Running the application
The OPEN Platform API uses several environment variables. All variables are required.
These environment variables are required for your app to utilize OAuth 2.0. To get started using the Gmail API, you need to first use the setup tool, to register your application for the Gmail API in the Google API Console. The setup tool will guide you through creating a project in the Google API Console, enabling the API, and creating authentication credentials. The setup process is easy and consists of the following three basic steps:
- On the Credentials page, click My Project and select the project you want to use.
- If you plan to create an OAuth client ID, click on the OAuth consent screen tab at the top of the Credentials page and fill out the form. You will need it in step 5.
- Click on the Credentials tab at the top of the Credentials page.
- Click the Create credentials button. From the drop-down list, select OAuth client ID if you want to create OAuth 2.0 credentials or select Service account key to create a service account.
- If you chose to create an OAuth client ID, select your application type (e.g. Web application, iOS app, etc.). Otherwise, go to step 6.
- Fill out the form and click the Create button.
Configure the POSTGRES_HOST environment variable to point to the host where you are running your PostgresSQL server. This is required to connect your application to the database.
Add the name of your PostgreSQL database to the POSTGRES_DB environment variable. This lets the application know which database to connect to.
Set the POSTGRES_USER environment variable with the username you want to use to connect to the database. Set the POSTGRES_PASSWORD environment variable that user's password. Using environment variables to configure user authentication to your database is more secure than placing this configuration in your code. NOTE: The user you specify in these two environment variables should be a superuser, otherwise you will run into problems.
Ethereum client service
- Written in Rust.
- Includes a pruning algorithm to prevent hard drive usage from growing exponentially.
- Includes an easy-to-use browser-based GUI.
- Implements passive-mode, which reduces the load on your CPU and network.
- Warp sync allows you to sync your node from scratch in a matter of hours, as opposed to days.
- Uses the Kovan test network to help you test your application.
- More feature-complete than Geth.
- Written in Go.
- Considered to be the reference implementation of Ethereum.
- Uses the Rinkeby test network to help you test your application.
NOTE: Both Parity and Geth can be installed on macOS via Homebrew. Ubuntu users can install Parity via apt. Please check to see if binary packages are available for your OS.
The INFURA_URL environment variable should be set to the IP address of your local machine and should include the port the service is running on. For example,
In order to use the Ethereum blockchain you need to create a wallet. A private key will be created as part of the wallet-creation process. You will need to include your private key in the ETHEREUM_PRIVATE_KEY environment variable in order for the system to be able to communicate with your wallet.
Before working in the app you need to create a smart contract within Ethereum. After creating a smart contract, you will receive an OPEN_TOKEN_ADDRESS. You will need to set the OPEN_TOKEN_ADDRESS to include this token in order for the system to check client transfers.