chainlink

package module
v0.0.0-...-5cb58b4 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 20, 2018 License: MIT Imports: 7 Imported by: 0

README

Chainlink is middleware to simplify communication with blockchains. Here you'll find the Chainlink Golang node, currently in alpha. This initial implementation is intended for use and review by developers, and will go on to form the basis for Chainlink's decentralized oracle network. Further development of the Chainlink Node and Chainlink Network will happen here, if you are interested in contributing please see our contribution guidelines. The current node supports:

  • easy connectivity of on-chain contracts to any off-chain computation or API
  • multiple methods for scheduling both on-chain and off-chain computation for a user's smart contract
  • automatic gas price bumping to prevent stuck transactions, assuring your data is delivered in a timely manner
  • push notification of smart contract state changes to off-chain systems, by tracking Ethereum logs
  • translation of various off-chain data types into EVM consumable types and transactions
  • easy to implement smart contract libraries for connecting smart contracts directly to their preferred oracles
  • easy to install node, which runs natively across operating systems, blazingly fast, and with a low memory footprint

Examples of how to utilize and integrate Chainlinks can be found in the examples directory.

Install

  1. Install Go 1.10+, and add your GOPATH's bin directory to your PATH
  2. Install dep: go get -u github.com/golang/dep/cmd/dep
  3. Install NodeJS & Yarn
  4. Download Chainlink: go get -d github.com/smartcontractkit/chainlink && cd $GOPATH/src/github.com/smartcontractkit/chainlink
  5. Install: make install
  6. Run the node: chainlink help
Ethereum Node Requirements

In order to run the Chainlink node you must have access to a running Ethereum node with an open websocket connection. Any Ethereum based network will work once you've configured the chain ID. Ethereum node versions currently tested and supported:

Run

NOTE: By default, chainlink will run in TLS mode. For local development you can either disable this by setting CHAINLINK_DEV to true, or generate self signed certificates using internal/bin/self-signed-certs or manually.

To start your Chainlink node, simply run:

$ chainlink node

By default this will start on port 6688, where it exposes a REST API.

Once your node has started, you can view your current jobs with:

$ chainlink jobspecs

View details of a specific job with:

$ chainlink show $JOB_ID

To find out more about the Chainlink CLI, you can always run chainlink help.

Check out the wiki's pages on Adapters and Initiators to learn more about how to create Jobs and Runs.

Configure

You can configure your node's behavior by setting environment variables which can be, along with default values that get used if no corresponding environment variable is found. The latest information on configuration variables are available in the wiki.

External Adapters

External adapters are what make Chainlink easily extensible, providing simple integration of custom computations and specialized APIs. A Chainlink node communicates with external adapters via a simple REST API.

For more information on creating and using external adapters, please see our external adapters page.

Development Setup

For the latest information on setting up a development environment, see the guide here.

Build your current version
$ go build -o chainlink
  • Run the binary:
$ ./chainlink
Test
$ cd $GOPATH/src/github.com/smartcontractkit/chainlink
$ go test ./...
Solidity Development
  1. Install Yarn
  2. Install the dependencies:
$ cd $GOPATH/src/github.com/smartcontractkit/chainlink/solidity
$ yarn install
  1. Run tests:
$ truffle test
Development Tips

For more tips on how to build and test Chainlink, see our development tips page.

Contributing

Chainlink's source code is licensed under the MIT License, and contributions are welcome.

Please check out our contributing guidelines for more details.

Thank you!

Documentation

Index

Examples

Constants

This section is empty.

Variables

This section is empty.

Functions

func NewProductionClient

func NewProductionClient() *cmd.Client

NewProductionClient configures an instance of the CLI to be used in production.

func Run

func Run(client *cmd.Client, args ...string)

Run runs the CLI, providing further command instructions by default.

Example
tc, cleanup := cltest.NewConfig()
defer cleanup()
testClient := &cmd.Client{
	Renderer:               cmd.RendererTable{Writer: ioutil.Discard},
	Config:                 tc.Config,
	AppFactory:             cmd.ChainlinkAppFactory{},
	KeyStoreAuthenticator:  cmd.TerminalKeyStoreAuthenticator{Prompter: &cltest.MockCountingPrompter{}},
	FallbackAPIInitializer: &cltest.MockAPIInitializer{},
	Runner:                 cmd.ChainlinkRunner{},
	HTTP:                   cltest.NewMockAuthenticatedHTTPClient(tc.Config),
}

Run(testClient, "chainlink.test", "--help")
Output:

NAME:
   chainlink.test - CLI for Chainlink

USAGE:
   chainlink.test [global options] command [command options] [arguments...]

VERSION:
   unset@unset

COMMANDS:
     node, n                   Run the chainlink node
     deleteuser                Erase the *local node's* user and corresponding session to force recreation on next node launch. Does not work remotely over API.
     login                     Login to remote client by creating a session cookie
     account, a                Display the account address with its ETH & LINK balances
     jobspecs, jobs, j, specs  Get all jobs
     show, s                   Show a specific job
     create, c                 Create job spec from JSON
     run, r                    Begin job run for specid
     backup                    Backup the database of the running node
     import, i                 Import a key file to use with the node
     bridge                    Add a new bridge to the node
     getbridges                List all bridges added to the node
     showbridge                Show a specific bridge
     removebridge              Removes a specific bridge
     agree, createsa           Creates a service agreement
     withdraw, w               Withdraw LINK to an authorized address
     help, h                   Shows a list of commands or help for one command

GLOBAL OPTIONS:
   --json, -j     json output as opposed to table
   --help, -h     show help
   --version, -v  print the version

func Start

func Start(pwdfile, apicredentials string)

Types

This section is empty.

Directories

Path Synopsis
Package adapters contain the core adapters used by the Chainlink node.
Package adapters contain the core adapters used by the Chainlink node.
Package cmd is the front-end interface for the application as a command-line utility.
Package cmd is the front-end interface for the application as a command-line utility.
internal
Package logger is used to store details of events in the node.
Package logger is used to store details of events in the node.
Package services contain the key components of the Chainlink node.
Package services contain the key components of the Chainlink node.
Package store is used to keep application events in sync between the database on the node and the blockchain.
Package store is used to keep application events in sync between the database on the node and the blockchain.
models
Package models contain the key job components used by the Chainlink application.
Package models contain the key job components used by the Chainlink application.
orm
presenters
Package presenters allow for the specification and result of a Job, its associated TaskSpecs, and every JobRun and TaskRun to be returned in a user friendly human readable format.
Package presenters allow for the specification and result of a Job, its associated TaskSpecs, and every JobRun and TaskRun to be returned in a user friendly human readable format.
Package utils is used for the common functions for dealing with conversion to and from hex, bytes, and strings, formatting time.
Package utils is used for the common functions for dealing with conversion to and from hex, bytes, and strings, formatting time.
Package web handles receiving and supplying information within the node.
Package web handles receiving and supplying information within the node.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL