-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
5878646
commit 11996c0
Showing
173 changed files
with
35,468 additions
and
2,445 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1,18 @@ | ||
.vscode/launch.json | ||
# Project specific | ||
config.json | ||
|
||
# Binaries for programs and plugins | ||
*.exe | ||
*.exe~ | ||
*.dll | ||
*.so | ||
*.dylib | ||
|
||
# Test binary, built with `go test -c` | ||
*.test | ||
|
||
# Output of the go coverage tool, specifically when used with LiteIDE | ||
*.out | ||
|
||
# Dependency directories (remove the comment below to include it) | ||
# vendor/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
The MIT License (MIT) | ||
|
||
Copyright (c) 2021 ShapeShift | ||
|
||
Permission is hereby granted, free of charge, to any person obtaining a copy | ||
of this software and associated documentation files (the "Software"), to deal | ||
in the Software without restriction, including without limitation the rights | ||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
copies of the Software, and to permit persons to whom the Software is | ||
furnished to do so, subject to the following conditions: | ||
|
||
The above copyright notice and this permission notice shall be included in | ||
all copies or substantial portions of the Software. | ||
|
||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||
THE SOFTWARE. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,16 +1,100 @@ | ||
# Cosmos SDK chain support in Unchained | ||
Add support for cosmos and cosmos-sdk chains | ||
# Introduction | ||
|
||
## Tech | ||
- golang v1.17 | ||
[![ShapeShift](https://img.shields.io/badge/ShapeShift%20DAO-Unchained-386ff9?logo=)](https://github.com/shapeshift/go-unchained) [![ShapeShift](https://img.shields.io/badge/License-MIT-brightgreen)](https://github.com/shapeshift/go-unchained/blob/main/LICENSE) [![ShapeShift](https://img.shields.io/badge/PRs-welcome-brightgreen)](https://github.com/shapeshift/go-unchained/pulls) | ||
|
||
## Running | ||
- Install golang | ||
- Copy sample.launch.json to .vscode and update with any keys etc | ||
- cmd/cosmos is main for Cosmos | ||
- cmd/osmosis is main for Osmosis | ||
Unchained is a multi-blockchain backend interface with three main goals: | ||
1. Provide a common interface to multiple blockchains | ||
2. Provide additional information not always accessible from the node directly | ||
3. Provide realtime updates about blockchain transactions (pending and confirmed) | ||
|
||
## Design | ||
- The core functionality of chains like Osmosis and Thorchain is identical to Cosmos | ||
- We can write the Cosmos SDK implementation once, and provide mechanisms to inject chain specific behavior (additional protos, support for custom messages and event logs, custom API routes etc) | ||
## Table Of Contents | ||
|
||
- [Helpful Docs](#helpful-docs) | ||
- [Project Structure](#project-structure) | ||
- [Coin Stack Components](#coin-stack-components) | ||
- [Dependencies](#dependencies) | ||
- [Notes](#notes) | ||
- [Initial Setup](#initial-setup) | ||
- [Ports](#ports) | ||
- [Docker-Compose Local Dev Instructions](#docker-compose-local-dev-instructions) | ||
- [Prerequisites](#prerequisites) | ||
- [Running](#running) | ||
- [Kubernetes Local Dev Instructions](#kubernetes-local-dev-instructions) | ||
- [Docker Desktop (macOS)](docs/docker-desktop.md) | ||
- [Minikube (Linux)](docs/minikube.md) | ||
|
||
## Helpful Docs | ||
|
||
- [Pulumi](https://www.pulumi.com/docs/) | ||
- [Kubernetes](https://kubernetes.io/docs/home/) | ||
- [OpenAPI](https://github.com/OAI/OpenAPI-Specification) | ||
|
||
## Project Structure | ||
|
||
- `internal` - internal utility packages | ||
- `pkg` - shared common packages across coinstacks | ||
- `coinstacks/{coin}` - coin specific logic | ||
|
||
## Coin Stack Components | ||
|
||
- **Blockchain Full Node** - coin specific daemon providing historical blockchain data (ie. bitcoind, geth, etc) | ||
- **Indexer** - indexes transaction and balance history by address (if not provided by the node directly) | ||
- **Common API** - a [REST API](https://api.cosmos.shapeshift.com/docs/) that provides necessary data to a client in a common format across all blockchains | ||
|
||
![Coin Stack Architecture](docs/coinstack.png) | ||
|
||
## Dependencies | ||
|
||
- [Golang](https://go.dev/doc/install) | ||
- [Docker](https://docs.docker.com/get-docker/) | ||
|
||
## Notes | ||
|
||
- The cosmos coinstack is used in all examples. If you wish to run a different coinstack, just replace `cosmos` with the coinstack name you wish to run | ||
- All paths are relative to the root unchained directory (ex. `go-unchained/{path}`) | ||
|
||
## Initial Setup | ||
|
||
- Install [Node.js LTS](https://nodejs.org/en/) | ||
- (Optional) use nvm to automatically install the node version specified in `.nvmrc` | ||
```sh | ||
nvm use | ||
``` | ||
|
||
## Local Networking | ||
|
||
We use traefik as a reverse-proxy to expose all of our docker containers. Traefik is exposed at port `80`. Traefik Dashboard is exposed at port `8080` | ||
|
||
Traefik routes requests based on host name. which includes the coinstack name. For Example: | ||
- `api.bitcoin.localhost` | ||
- `mongo.bitcoin.localhost` | ||
- `rabbit-admin.bitcoin.localhost` | ||
|
||
## Docker-Compose Local Dev Instructions | ||
|
||
#### _Lightweight local development environment_ | ||
|
||
#### **Prerequisites** | ||
|
||
- Install [docker-compose](https://docs.docker.com/compose/install/) | ||
- Copy sample config file: | ||
```sh | ||
cp cmd/cosmos/sample.config.json cmd/cosmos/config.json | ||
``` | ||
- Fill out any missing config variables | ||
|
||
#### **Running** | ||
|
||
- To start up the reverse proxy and hot reloading for files run from the root of the project | ||
```sh | ||
docker-compose up | ||
``` | ||
|
||
- To spin up a coinstack: | ||
```sh | ||
cd coinstacks/cosmos && docker-compose up | ||
``` | ||
- To completely tear down the coinstack (including docker volumes): | ||
```sh | ||
cd coinstacks/cosmos && docker-compose down -v | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
FROM golang:1.17.5 | ||
|
||
RUN go install github.com/cespare/reflex@latest | ||
|
||
ENTRYPOINT ["reflex", "-s"] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,50 +1,71 @@ | ||
package main | ||
|
||
import ( | ||
// "net/http" | ||
// _ "net/http/pprof" | ||
"flag" | ||
"os" | ||
"os/signal" | ||
"syscall" | ||
|
||
codectypes "github.com/cosmos/cosmos-sdk/codec/types" | ||
"github.com/shapeshift/unchained-cosmos/server/rest" | ||
"github.com/shapeshift/unchained-cosmos/service" | ||
log "github.com/sirupsen/logrus" | ||
"github.com/shapeshift/go-unchained/coinstacks/cosmos/api" | ||
"github.com/shapeshift/go-unchained/internal/config" | ||
"github.com/shapeshift/go-unchained/internal/log" | ||
"github.com/shapeshift/go-unchained/pkg/cosmos" | ||
) | ||
|
||
func main() { | ||
log.Debug("") | ||
start() | ||
var logger = log.WithoutFields() | ||
|
||
var confPath = flag.String("config", "cmd/cosmos/config.json", "path to configuration file") | ||
|
||
// Config for running application | ||
type Config struct { | ||
APIKey string `mapstructure:"apiKey"` | ||
GRPCURL string `mapstructure:"grpcUrl"` | ||
LCDURL string `mapstructure:"lcdUrl"` | ||
RPCURL string `mapstructure:"rpcUrl"` | ||
} | ||
|
||
func start() { | ||
// where to listen | ||
restListenAddr := os.Getenv("REST_LISTEN_ADDR") | ||
if restListenAddr == "" { | ||
restListenAddr = "localhost:1660" | ||
func main() { | ||
flag.Parse() | ||
|
||
errChan := make(chan error, 1) | ||
sigChan := make(chan os.Signal, 1) | ||
signal.Notify(sigChan, syscall.SIGHUP, syscall.SIGINT, syscall.SIGTERM, syscall.SIGQUIT) | ||
|
||
conf := &Config{} | ||
if err := config.Load(*confPath, conf); err != nil { | ||
logger.Panic(err) | ||
} | ||
|
||
config := service.ChainConfig{ | ||
CosmosBase: os.Getenv("COSMOS_BASE"), | ||
TendermintBase: os.Getenv("TENDERMINT_BASE"), | ||
ApiKey: os.Getenv("DATAHUB_API_KEY"), | ||
GRPCBase: os.Getenv("GRPC_BASE"), | ||
RestListenAddr: restListenAddr, | ||
Bech32PrefixAccAddr: "cosmos", | ||
Bech32PrefixAccPub: "cosmospub", | ||
RegisterTypes: func(registry codectypes.InterfaceRegistry) { | ||
// cosmos so all stock protos | ||
}, | ||
encoding := cosmos.NewEncoding() | ||
|
||
cfg := cosmos.Config{ | ||
APIKey: conf.APIKey, | ||
Bech32AddrPrefix: "cosmos", | ||
Bech32PkPrefix: "cosmospub", | ||
Encoding: encoding, | ||
GRPCURL: conf.GRPCURL, | ||
LCDURL: conf.LCDURL, | ||
RPCURL: conf.RPCURL, | ||
} | ||
|
||
service, err := service.NewCosmosService(config) | ||
httpClient, err := cosmos.NewHTTPClient(cfg) | ||
if err != nil { | ||
log.Errorf("dumping config: %#v", config) | ||
log.Fatalf("error creating CosmosService: %s", err) | ||
logger.Panic(err) | ||
} | ||
|
||
srv, err := rest.New(service, config) | ||
grpcClient, err := cosmos.NewGRPCClient(cfg) | ||
if err != nil { | ||
log.Fatal("error starting http server: %s", err) | ||
logger.Panic(err) | ||
} | ||
defer grpcClient.Shutdown() | ||
|
||
go api.Start(httpClient, grpcClient, errChan) | ||
|
||
select { | ||
case err := <-errChan: | ||
logger.Panic(err) | ||
case <-sigChan: | ||
grpcClient.Shutdown() | ||
os.Exit(0) | ||
} | ||
log.Infof("got srv: %#v", srv) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
{ | ||
"lcdUrl": "https://cosmoshub-4--lcd--archive.datahub.figment.io", | ||
"grpcUrl": "cosmoshub-4--grpc--archive.grpc.datahub.figment.io:443", | ||
"rpcUrl": "https://cosmoshub-4--rpc--archive.datahub.figment.io", | ||
"apiKey": "" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,44 +1,75 @@ | ||
package main | ||
|
||
import ( | ||
// "net/http" | ||
// _ "net/http/pprof" | ||
"flag" | ||
"os" | ||
"os/signal" | ||
"syscall" | ||
|
||
"github.com/shapeshift/unchained-cosmos/osmosis" | ||
"github.com/shapeshift/unchained-cosmos/server/rest" | ||
"github.com/shapeshift/unchained-cosmos/service" | ||
log "github.com/sirupsen/logrus" | ||
gammtypes "github.com/osmosis-labs/osmosis/x/gamm/types" | ||
lockuptypes "github.com/osmosis-labs/osmosis/x/lockup/types" | ||
"github.com/shapeshift/go-unchained/coinstacks/osmosis/api" | ||
"github.com/shapeshift/go-unchained/internal/config" | ||
"github.com/shapeshift/go-unchained/internal/log" | ||
"github.com/shapeshift/go-unchained/pkg/cosmos" | ||
) | ||
|
||
func main() { | ||
start() | ||
var logger = log.WithoutFields() | ||
|
||
var confPath = flag.String("config", "cmd/osmosis/config.json", "path to configuration file") | ||
|
||
type Config struct { | ||
APIKey string `mapstructure:"apiKey"` | ||
GRPCURL string `mapstructure:"grpcUrl"` | ||
LCDURL string `mapstructure:"lcdUrl"` | ||
RPCURL string `mapstructure:"rpcUrl"` | ||
} | ||
|
||
func start() { | ||
// where to listen | ||
restListenAddr := os.Getenv("REST_LISTEN_ADDR") | ||
|
||
config := service.ChainConfig{ | ||
CosmosBase: os.Getenv("COSMOS_BASE"), | ||
TendermintBase: os.Getenv("TENDERMINT_BASE"), | ||
ApiKey: os.Getenv("DATAHUB_OSMO_API_KEY"), | ||
GRPCBase: os.Getenv("GRPC_BASE"), | ||
RestListenAddr: restListenAddr, | ||
Bech32PrefixAccAddr: "osmo", | ||
Bech32PrefixAccPub: "osmopub", | ||
RegisterTypes: osmosis.RegisterTypes, | ||
EventHandler: osmosis.OsmosisEventHandler, | ||
func main() { | ||
flag.Parse() | ||
|
||
errChan := make(chan error, 1) | ||
sigChan := make(chan os.Signal, 1) | ||
signal.Notify(sigChan, syscall.SIGHUP, syscall.SIGINT, syscall.SIGTERM, syscall.SIGQUIT) | ||
|
||
conf := &Config{} | ||
if err := config.Load(*confPath, conf); err != nil { | ||
logger.Panic(err) | ||
} | ||
|
||
service, err := service.NewCosmosService(config) | ||
encoding := cosmos.NewEncoding( | ||
gammtypes.RegisterInterfaces, | ||
lockuptypes.RegisterInterfaces, | ||
) | ||
|
||
cfg := cosmos.Config{ | ||
APIKey: conf.APIKey, | ||
Bech32AddrPrefix: "osmo", | ||
Bech32PkPrefix: "osmopub", | ||
Encoding: encoding, | ||
GRPCURL: conf.GRPCURL, | ||
LCDURL: conf.LCDURL, | ||
RPCURL: conf.RPCURL, | ||
} | ||
|
||
httpClient, err := cosmos.NewHTTPClient(cfg) | ||
if err != nil { | ||
log.Errorf("dumping config: %#v", config) | ||
log.Fatalf("error creating CosmosService: %s", err) | ||
logger.Panic(err) | ||
} | ||
srv, err := rest.New(service, config) | ||
|
||
grpcClient, err := cosmos.NewGRPCClient(cfg) | ||
if err != nil { | ||
log.Fatal("error starting http server: %s", err) | ||
logger.Panic(err) | ||
} | ||
defer grpcClient.Shutdown() | ||
|
||
go api.Start(httpClient, grpcClient, errChan) | ||
|
||
select { | ||
case err := <-errChan: | ||
logger.Panic(err) | ||
case <-sigChan: | ||
grpcClient.Shutdown() | ||
os.Exit(0) | ||
} | ||
log.Infof("got srv: %#v", srv) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
{ | ||
"lcdUrl": "https://osmosis-1--lcd--archive.datahub.figment.io", | ||
"grpcUrl": "osmosis-1--grpc--archive.grpc.datahub.figment.io:443", | ||
"rpcUrl": "https://osmosis-1--rpc--archive.datahub.figment.io", | ||
"apiKey": "" | ||
} |
Oops, something went wrong.