Moonstream is a product which helps anyone participate in decentralized finance.
 
 
 
 
 
Go to file
kompotkot 184c19c927 Removed geth and bor status check to prevent script fall 2022-01-21 13:42:37 +00:00
.github/workflows
backend Add fixes. 2022-01-17 15:16:31 +02:00
clients/python
crawlers Sync crawlers restart automaticly with systemd 2022-01-21 13:13:48 +00:00
datasets/nfts
db
docs
frontend Merge pull request #533 from bugout-dev/fix-dashboards-crashing 2022-01-20 21:58:37 +00:00
nodes Removed geth and bor status check to prevent script fall 2022-01-21 13:42:37 +00:00
.gitignore
LICENSE
README.md
docker-compose.yml

README.md

moonstream

[Live at https://moonstream.to/](https://moonstream.to)

What is Moonstream?

Moonstream is a product which helps anyone participate in decentralized finance. From the most sophisticated flash arbitrageurs to people looking for yield from currency that would otherwise lie dormant in their exchange accounts.

Moonstream users can subscribe to events from any blockchain - from the activity of specific accounts or smart contracts to updates about general market movements. This information comes from the blockchains themselves, from their mempools/transaction pools, and from centralized exchanges, social media, and the news. This forms a stream of information tailored to their specific needs.

They can use this information to execute transactions directly from the Moonstream frontend or they can set up programs which execute (on- or off-chain) when their stream meets certain conditions.

Who uses Moonstream?

  1. Development teams deploying decentralized applications. They use Moonstream to analyze how users are calling their dapps, and set up alerts for suspicious activity.
  2. Algorithmic funds. They use Moonstream to execute transactions directly on-chain under prespecified conditions.
  3. Crypto traders. They use Moonstream to evaluate trading strategies based on data from centralized exchanges, the blockchain, and the transaction pool.

Free software

Proprietary technologies are not inclusive technologies, and we believe in inclusion.

All of our technology is open source. This repository contains all the code that powers https://moonstream.to. The code is licensed with the Apache License, Version 2.0.

You are and will always be free to host your own instance of Moonstream.

Architecture

This monorepo contains the following components:

  1. frontend: A web frontend for Moonstream. Allows users to perform API operations through a visual interface. The frontend also offers charting and analysis functionality. Built in React.
  2. backend': The Moonstream API. This portion of the code base implements a REST API through which users can manage the events that show up in their stream and actually consume their stream data. Built in Python using Fast API.
  3. crawlers: This part of the code base contains workers which extract data from blockchains, transaction pools, and other sources. Currently contains a single Python package but we will soon be addding crawlers implemented in other languages: Go, Rust), and Javascript.
  4. db: Moonstream stores blockchain data in Postgres. This directory contains the code we use to manage the schema in our Postgres database. For sources that send higher volumes of data, we use a separate Postgres database and interface with it using Bugout. For more information on how that data is processed, check how the API inserts events from those sources into a stream.

Installation and setup

Run server with Docker Compose

If you want to deploy Moonstream in isolation against live services, then docker compose is your choice!

  • Run script backend/configs/docker_generate_env.bash which prepare for you:
    • backend/configs/docker.moonstreamapi.env with environment variables
  • Run script db/configs/docker_generate_env.bash which prepare for you:
    • db/configs/alembic.moonstreamdb.ini with postgresql uri
./backend/configs/docker_generate_env.bash
./db/configs/docker_generate_env.bash
  • Run local setup
docker-compose up --build

Contributing

If you would like to contribute to Moonstream, please reach out to @zomglings on the Moonstream Discord.