# chainlink **Repository Path**: Yang007GG_com/chainlink ## Basic Information - **Project Name**: chainlink - **Description**: No description available - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: develop - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 1 - **Created**: 2021-10-11 - **Last Updated**: 2024-05-15 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README

Chainlink logo


![GitHub tag (latest SemVer)](https://img.shields.io/github/v/tag/smartcontractkit/chainlink?style=flat-square) [![GitHub license](https://img.shields.io/github/license/smartcontractkit/chainlink?style=flat-square)](https://github.com/smartcontractkit/chainlink/blob/master/LICENSE) [![GitHub workflow changelog](https://img.shields.io/github/workflow/status/smartcontractkit/chainlink/Changelog?style=flat-square&label=github-actions)](https://github.com/smartcontractkit/chainlink/actions?query=workflow%3AChangelog) [![CircleCI build](https://img.shields.io/circleci/build/github/smartcontractkit/chainlink/master?style=flat-square&label=circleci&logo=circleci)](https://circleci.com/gh/smartcontractkit/chainlink/tree/master) [![GitHub contributors](https://img.shields.io/github/contributors-anon/smartcontractkit/chainlink?style=flat-square)](https://github.com/smartcontractkit/chainlink/graphs/contributors) [![GitHub commit activity](https://img.shields.io/github/commit-activity/y/smartcontractkit/chainlink?style=flat-square)](https://github.com/smartcontractkit/chainlink/commits/master) [Chainlink](https://chain.link/) 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](https://link.smartcontract.com/whitepaper). Further development of the Chainlink Node and Chainlink Network will happen here, if you are interested in contributing please see our [contribution guidelines](./docs/CONTRIBUTING.md). ## Features - 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 [Chainlink Truffle Box](https://github.com/smartcontractkit/box). ## Community Chainlink has an active and ever growing community. [Discord](https://discordapp.com/invite/aSK4zew) is the primary communication channel used for day to day communication, answering development questions, and aggregating Chainlink related content. Take a look at the [community docs](./docs/COMMUNITY.md) for more information regarding Chainlink social accounts, news, and networking. ## Install 1. [Install Go 1.17](https://golang.org/doc/install), and add your GOPATH's [bin directory to your PATH](https://golang.org/doc/code.html#GOPATH) - Example Path for macOS `export PATH=$GOPATH/bin:$PATH` & `export GOPATH=/Users/$USER/go` 2. Install [NodeJS 12.18](https://nodejs.org/en/download/package-manager/) & [Yarn](https://yarnpkg.com/lang/en/docs/install/) - It might be easier long term to use [nvm](https://nodejs.org/en/download/package-manager/#nvm) to switch between node versions for different projects: `nvm install 12.18 && nvm use 12.18` 3. Install [Postgres (>= 11.x)](https://wiki.postgresql.org/wiki/Detailed_installation_guides). - You should [configure Postgres](https://www.postgresql.org/docs/12/ssl-tcp.html) to use SSL connection 4. Download Chainlink: `git clone https://github.com/smartcontractkit/chainlink && cd chainlink` 5. Build and install Chainlink: `make install` - If you got any errors regarding locked yarn package, try running `yarn install` before this step - If `yarn install` throws a network connection error, try increasing the network timeout by running `yarn install --network-timeout 150000` before this step 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](https://github.com/smartcontractkit/chainlink#configure) the chain ID. Ethereum node versions currently tested and supported: - [Parity 1.11+](https://github.com/paritytech/parity-ethereum/releases) (due to a [fix with pubsub](https://github.com/paritytech/parity/issues/6590).) - [Geth 1.8+](https://github.com/ethereum/go-ethereum/releases) ## 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 `tools/bin/self-signed-certs` or [manually](https://github.com/smartcontractkit/chainlink/wiki/Creating-Self-Signed-Certificates). To start your Chainlink node, simply run: ```bash chainlink node start ``` By default this will start on port 6688, where it exposes a [REST API](https://github.com/smartcontractkit/chainlink/wiki/REST-API). Once your node has started, you can view your current jobs with: ```bash chainlink jobs list ``` View details of a specific job with: ```bash chainlink job show [$JOB_ID] ``` To find out more about the Chainlink CLI, you can always run `chainlink help`. Check out the [doc](https://docs.chain.link/) pages on [Jobs](https://docs.chain.link/docs/jobs/) to learn more about how to create Jobs. ## Configure You can configure your node's behavior by setting environment variables. All the environment variables can be found in the `ConfigSchema` struct of `schema.go`. You can also read the [official documentation](https://docs.chain.link/docs/configuration-variables) to learn the most up to date information on each of them. For every variable, default values get used if no corresponding environment variable is found. ## Project Structure Chainlink is a monorepo containing several logically separatable and relatable projects. - [core](./core) - the core Chainlink node - [@chainlink/contracts](./contracts) - smart contracts - [integration/forks](./integration/forks) - integration test for [ommers](https://ethereum.stackexchange.com/a/46/19503) and [re-orgs](https://en.bitcoin.it/wiki/Chain_Reorganization) - [tools](./tools) - Chainlink tools ## 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](https://docs.chain.link/docs/external-adapters). ## Development Setup For the latest information on setting up a development environment, see the [guide here](https://github.com/smartcontractkit/chainlink/wiki/Development-Setup-Guide). ### Build your current version ```bash go build -o chainlink ./core/ ``` - Run the binary: ```bash ./chainlink ``` ### Test Core 1. [Install Yarn](https://yarnpkg.com/lang/en/docs/install) 2. Install [gencodec](https://github.com/fjl/gencodec) and [jq](https://stedolan.github.io/jq/download/) to be able to run `go generate ./...` and `make abigen` 3. Install mockery `make mockery` Using the `make` command will install the correct version. 4. Build contracts: ```bash yarn yarn setup:contracts ``` 4. Generate and compile static assets: ```bash go generate ./... go run ./packr/main.go ./core/services/eth/ ``` 5. Prepare your development environment: ```bash export DATABASE_URL=postgresql://127.0.0.1:5432/chainlink_test?sslmode=disable export CHAINLINK_DEV=true # I prefer to use direnv and skip this ``` 6. Drop/Create test database and run migrations: ``` go run ./core/main.go local db preparetest ``` If you do end up modifying the migrations for the database, you will need to rerun 7. Run tests: ```bash go test -parallel=1 ./... ``` ### Solidity Development Inside the `contracts/` directory: 1. Install dependencies: ```bash yarn ``` 2. Run tests: ```bash yarn test ``` ### Use of Go Generate Go generate is used to generate mocks in this project. Mocks are generated with [mockery](https://github.com/vektra/mockery) and live in core/internal/mocks. ### Nix Flake A [flake](https://nixos.wiki/wiki/Flakes) is provided for use with the [Nix package manager](https://nixos.org/). It defines a declarative, reproducible development environment. To use it: 1. [Nix has to be installed with flake support](https://nixos.wiki/wiki/Flakes#Installing_flakes). 2. Run `nix develop`. You will be put in shell containing all the dependencies. Alternatively, a `direnv` integration exists to automatically change the environment when `cd`-ing into the folder. 3. Create a local postgres database: ``` cd $PGDATA/ initdb pg_ctl -l $PGDATA/postgres.log -o "--unix_socket_directories='$PWD'" start createdb chainlink_test -h localhost createuser --superuser --no-password chainlink -h localhost ``` 4. Start postgres, `pg_ctl -l $PGDATA/postgres.log -o "--unix_socket_directories='$PWD'" start` Now you can run tests or compile code as usual. ### Development Tips For more tips on how to build and test Chainlink, see our [development tips page](https://github.com/smartcontractkit/chainlink/wiki/Development-Tips). ## Contributing Chainlink's source code is [licensed under the MIT License](./LICENSE), and contributions are welcome. Please check out our [contributing guidelines](./docs/CONTRIBUTING.md) for more details. Thank you! ## License [MIT](https://choosealicense.com/licenses/mit/)