Go to file
Jae Kwon b9455e9620 Make basecoin a root project 2018-01-20 22:28:43 -08:00
_attic Initial commit for permissioning... 2018-01-12 19:17:17 -08:00
baseapp cosmos-sdk/app.App -> cosmos-sdk/baseapp.BaseApp 2018-01-20 20:13:46 -08:00
docs WIP: Add docs 2018-01-20 22:10:41 -08:00
examples Make basecoin a root project 2018-01-20 22:28:43 -08:00
publish Rename all packages and imports to cosmos-sdk 2017-08-21 22:15:15 +01:00
store Refactor basecoin example (#332) 2018-01-17 16:59:40 -08:00
tests Fix cli tests to explicitly pass height when querying results of tx 2017-10-25 19:14:28 +02:00
tools Vendor tools into tools/* (#331) 2018-01-16 11:24:20 -08:00
types auth.AccountStore assumes go-wire; Remove GetTxBytes() from Tx 2018-01-20 18:11:38 -08:00
version modules -> x 2017-10-31 17:51:44 -05:00
x x/auth/Account -> x/auth/BaseAccount; RegisterWireBaseAccount() 2018-01-20 22:10:41 -08:00
.codecov.yml codecov: closes #334 2018-01-17 20:00:54 -05:00
.gitignore Vagrantfile 2018-01-18 18:08:08 -05:00
CHANGELOG.md changelog and version 2017-10-11 23:30:50 -04:00
CODEOWNERS Add CODEOWNERS 2018-01-20 18:18:16 -08: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 Add Apache2.0 license 2016-09-10 15:53:15 -07:00
Makefile godoc tweak 2018-01-20 15:03:57 -08:00
README.md README makeover 2018-01-17 19:15:07 -05:00
RELEASE.md Update RELEASE from learning from 0.6.0 2017-06-23 11:10:32 +02:00
TODO WIP: refactor 2018-01-12 19:17:17 -08:00
Vagrantfile Vagrantfile 2018-01-18 18:08:08 -05:00
circle.yml codecov: closes #334 2018-01-17 20:00:54 -05:00
glide.lock Vendor tools into tools/* (#331) 2018-01-16 11:24:20 -08:00
glide.yaml basecoin compiles 2018-01-14 22:49:57 -05:00
test_cover.sh codecov: closes #334 2018-01-17 20:00:54 -05: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

WARNING: the libraries are still undergoing breaking changes as we get better ideas and start building out the Apps.

Note: Requires Go 1.9+

The Cosmos SDK is a platform for building multi-asset Proof-of-Stake cryptocurrencies, like the Cosmos Hub. It is both a library for building applications and a set of tools for securely interacting with them.

The goals of the SDK are to abstract away the complexities of building a Tendermint ABCI application in Golang and to provide a framework for building interoperable blockchain applications in the Cosmos Network.

It is inspired by the routing and middleware model of many web application frameworks, and informed by years of wrestling with blockchain state machines.

The SDK is fast, safe, easy-to-use, and easy-to-reason-about. It is generic enough to be used to implement the state machines of other existing blockchains, like Bitcoin and Ethereum, allowing seamless integration with them and their data structures. It comes with batteries included, is easily extensible, and does not require developers to fork it to access any of its current or extended functionality. It provides both REST and command line interfaces for secure user interactions.

Applications in the Cosmos-SDK are defined in terms of a chain of handlers that process messages and read and write to a store. Handlers are given restricted capabilities that determine which parts of the store they can access. The SDK provides common data structures for Accounts, multi-asset Coins, checking signatures, preventing replay, and so on.

For more details on the design goals, see the Design Document

Prerequisites

Getting Started

The main application built with the Cosmos-SDK is the Cosmos Hub. Setup a local Cosmos Hub blockchain by following this guide. Connect to a testnet by following this guide. Learn how to build your own SDK application here.