🐳 Ocean aquarius.
Project description
Aquarius
🐋 Provide an off-chain database store for data assets metadata. oceanprotocol.com
"Aquarius is a constellation of the zodiac, situated between Capricornus and Pisces. Its name is Latin for "water-carrier" or "cup-carrier", and its symbol is Aquarius.svg , a representation of water. Aquarius is one of the oldest of the recognized constellations along the zodiac (the Sun's apparent path)."
🐲🦑 THERE BE DRAGONS AND SQUIDS. This is in alpha state and you can expect running into problems. If you run into them, please open up a new issue. 🦑🐲
Table of Contents
- Features
- Prerequisites
- Quick Start
- API documentation
- Configuration
- Code style
- Testing
- New Version
- License
Features
Aquarius handles all non-blockchain related core functionality, including compute and storage interfaces, and connections to Ocean Keepers. Additionally, the Aquarius implements Ocean's Service Integrity and Orchestration capabilities, allowing for services to be requested, ordered, scheduled, verfied, and curated.
Running Locally, for Dev and Test
If you want to contribute to the development of the Aquarius, then you could do the following. (If you want to run a Aquarius in production, then you will have to do something else.)
First, clone this repository:
git clone git@github.com:oceanprotocol/aquarius.git
cd aquarius/
Then run some things that the Aquarius expects to be running:
cd docker
docker-compose up
You can see what that runs by reading docker/docker-compose.yml. Note that it runs MongoDB but the Aquarius can also work with BigchainDB or Elasticsearch. It also runs Ganache with all Ocean Protocol Keeper Contracts and Ganache CLI.
The most simple way to start is:
pip install -r requirements_dev.txt # or requirements_conda.txt if using Conda
export FLASK_APP=aquarius/run.py
export CONFIG_FILE=config.ini
./scripts/deploy
flask run
That will use HTTP (i.e. not SSL/TLS).
The proper way to run the Flask application is using an application server such as Gunicorn. This allow you to run using SSL/TLS. You can generate some certificates for testing by doing:
openssl req -x509 -newkey rsa:4096 -nodes -out cert.pem -keyout key.pem -days 365
and when it asks for the Common Name (CN), answer localhost
Then edit the config file config.ini
so that:
aquarius
Then execute this command:
gunicorn --certfile cert.pem --keyfile key.pem -b 0.0.0.0:5000 -w 1 aquarius.run:app
API documentation
Once you have your application running you can get access to the documentation at:
https://127.0.0.1:5000/api/v1/docs
(or http
if you're using HTTP.)
Tip: if your browser shows the swagger header across the top but says "Failed to load spec." then we found that, in Chrome, if we went to chrome://flags/#allow-insecure-localhost and toggled it to Enabled, then relaunched Chrome, it worked.
If you want to know more about the ontology of the metadata, you can find all the information in OEP-8.
Configuration
You can pass the configuration using the CONFIG_FILE environment variable (recommended) or locating your configuration in config.ini file.
In the configuration there are now two sections:
-
oceandb: Contains different values to connect with oceandb. You can find more information about how to use OceanDB here.
-
resources: In this section we are showing the url in wich the aquarius is going to be deployed.
[resources] aquarius.url = http://localhost:5000
Code style
The information about code style in python is documented in this two links python-developer-guide and python-style-guide.
Testing
Automatic tests are setup via Travis, executing tox
.
Our test use pytest framework.
New Version
The bumpversion.sh
script helps to bump the project version. You can execute the script using as first argument {major|minor|patch} to bump accordingly the version.
License
Copyright 2018 Ocean Protocol Foundation Ltd.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for ocean_aquarius-0.0.2-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 517821346555d4c453f0c392ba5eb7be34d7bbe48c3f1febc0a0c813d26d0f27 |
|
MD5 | c0a7f55af646a40cad9ad788aed64aec |
|
BLAKE2b-256 | b4c60f91ef8ba04ed1d4bd90d9fe4cce9c56460e83bc752b02cff125540fc0f1 |