Go to file
Jae Kwon 561d77cae0 remove errors module 2017-10-31 17:58:12 -05:00
_attic Move postponed functionality to _attic so we can focus 2017-10-25 19:56:48 +02:00
app eyes example compiles - but doesnt work 2017-10-25 19:56:48 +02:00
benchmarks Clean up genesis, add godoc to genesis and app 2017-10-20 13:42:03 +02:00
client eyes example compiles - but doesnt work 2017-10-25 19:56:48 +02:00
docs Update ibc test script for new commands 2017-10-25 19:35:36 +02:00
examples Updated tx handling for eyes server 2017-10-25 19:56:48 +02:00
genesis Clean up genesis parse per Anton 2017-10-25 19:14:28 +02:00
publish Rename all packages and imports to cosmos-sdk 2017-08-21 22:15:15 +01:00
server/commands eyes example compiles - but doesnt work 2017-10-25 19:56:48 +02:00
store Remove most of state/* 2017-10-31 15:45:57 -05:00
tests Fix cli tests to explicitly pass height when querying results of tx 2017-10-25 19:14:28 +02:00
util One step for module eyes commands compiling 2017-10-25 19:56:48 +02:00
version modules -> x 2017-10-31 17:51:44 -05:00
x remove errors module 2017-10-31 17:58:12 -05:00
.gitignore Move keys command from go-crypto here 2017-09-08 20:47:46 +02:00
CHANGELOG.md changelog and version 2017-10-11 23:30:50 -04:00
Dockerfile Dockerfile and Dockerfile.dev for development 2017-03-14 16:15:03 +04:00
Dockerfile.dev add jq to Dockerfile.dev [ci skip] 2017-06-23 12:13:29 +04:00
LICENSE
Makefile Start working to compile eyes app 2017-10-25 19:56:48 +02:00
README.md Note that go 1.8+ is required 2017-10-19 15:57:57 +02:00
RELEASE.md Update RELEASE from learning from 0.6.0 2017-06-23 11:10:32 +02:00
ROADMAP.md Add thoughts on a release process 2017-06-22 13:04:47 +02:00
TODO Remove most of state/* 2017-10-31 15:45:57 -05:00
Vagrantfile Add vagrantfile so i can build dist on osx (docker) 2017-06-29 14:44:34 +02:00
_gen.go Start tx holder with gen 2017-06-30 18:37:47 +02:00
circle.yml circle fix, minor IBC tutorial 2017-06-29 05:52:07 -04:00
context.go Rename all packages and imports to cosmos-sdk 2017-08-21 22:15:15 +01:00
db.go Move db interfaces to top level 2017-10-25 19:56:48 +02:00
decorators.go Move db interfaces to top level 2017-10-25 19:56:48 +02:00
glide.lock Update after rebase 2017-10-25 19:35:36 +02:00
glide.yaml Update after rebase 2017-10-25 19:35:36 +02:00
handler.go module eyes works 2017-10-25 19:56:48 +02:00
results.go Define Handler and Decorator 2017-10-25 19:56:48 +02:00

README.md

Cosmos SDK

banner

version API Reference Rocket.Chat license LoC Go Report Card

Branch Tests Coverage
develop CircleCI codecov
master CircleCI codecov

!!!!!!!!!!!!!!!!!!!!!

THIS REPOSITORY IS UNDERGOING RAPID DEVELOPMENT AND NONE OF ITS INTERFACES ARE CONSIDERED STABLE.

USE AT YOUR OWN RISK.

!!!!!!!!!!!!!!!!!!!!!

Note: Requires Go 1.8+

The Cosmos SDK is the middleware platform that the Cosmos Hub is constructed from. The Hub is a blockchain (or, internet of blockchains) in which the Atom supply resides. The Atoms supply is defined at genesis and can change based on the rules of the Hub.

Under the hood, the Cosmos SDK is an ABCI application designed to be used with the Tendermint consensus engine to form a Proof-of-Stake cryptocurrency. It also provides a general purpose framework for extending the feature-set of the cryptocurrency by implementing plugins.

This SDK affords you all the tools you need to rapidly develop robust blockchains and blockchain applications which are interoperable with The Cosmos Hub. It is a blockchain development 'starter-pack' of common blockchain modules while not enforcing their use thus giving maximum flexibility for application customization. For example, does your app require fees, how do you want to log messages, do you enable IBC, do you even have a cryptocurrency? In this way, the Cosmos SDK is the Rails of cryptocurrencies.

Within this repository, the basecoin app serves as a reference implementation for how we build ABCI applications in Go, and is the framework in which we implement the Cosmos Hub. It's easy to use, and doesn't require any forking - just implement your plugin, import the libraries, and away you go with a full-stack blockchain and command line tool for transacting.

Prerequisites

Installation

go get -u github.com/cosmos/cosmos-sdk/cmd/basecoin

See the install guide for more details.

Guides

To deploy a testnet, see our repository of deployment tools.

Inspiration

The basic concept for this SDK comes from years of web development. A number of patterns have arisen in that realm of software which enable people to build remote servers with APIs remarkably quickly and with high stability. The ABCI application interface is similar to a web API (DeliverTx is like POST and Query is like GET while SetOption is like the admin playing with the config file). Here are some patterns that might be useful:

  • MVC - separate data model (storage) from business logic (controllers)
  • Routers - easily direct each request to the appropriate controller
  • Middleware - a series of wrappers that provide global functionality (like authentication) to all controllers
  • Modules (gems, package, etc) - developers can write a self-contained package with a given set of functionality, which can be imported and reused in other apps

Also at play is the concept of different tables/schemas in databases, thus you can keep the different modules safely separated and avoid any accidental (or malicious) overwriting of data.

Not all of these can be compare one-to-one in the blockchain world, but they do provide inspiration for building orthogonal pieces that can easily be combined into various applications.