From fc15a236dddbd2c2e6bfa973a9e030b9dda6deb8 Mon Sep 17 00:00:00 2001 From: aelmanaa Date: Tue, 20 Sep 2022 19:07:05 +0200 Subject: [PATCH 1/5] automate generation of cl node env files --- .gitignore | 1 + docs/chainlink-nodes/config/index.md | 14 + docs/chainlink-nodes/config/v1_6_0.md | 4268 +++++++++++++++++++++++ docs/chainlink-nodes/config/v1_7_0.md | 4378 ++++++++++++++++++++++++ docs/chainlink-nodes/config/v1_7_1.md | 4378 ++++++++++++++++++++++++ docs/chainlink-nodes/config/v1_8_0.md | 4560 +++++++++++++++++++++++++ package.json | 10 +- public/nodes-config.ts | 203 ++ public/reference/nodesConf.json | 6 + 9 files changed, 17816 insertions(+), 2 deletions(-) create mode 100644 docs/chainlink-nodes/config/index.md create mode 100644 docs/chainlink-nodes/config/v1_6_0.md create mode 100644 docs/chainlink-nodes/config/v1_7_0.md create mode 100644 docs/chainlink-nodes/config/v1_7_1.md create mode 100644 docs/chainlink-nodes/config/v1_8_0.md create mode 100644 public/nodes-config.ts create mode 100644 public/reference/nodesConf.json diff --git a/.gitignore b/.gitignore index 6e3752f267c..6c2c1e68476 100644 --- a/.gitignore +++ b/.gitignore @@ -34,3 +34,4 @@ typechain-types/ .tmp .cache +.env diff --git a/docs/chainlink-nodes/config/index.md b/docs/chainlink-nodes/config/index.md new file mode 100644 index 00000000000..1da33a35c5a --- /dev/null +++ b/docs/chainlink-nodes/config/index.md @@ -0,0 +1,14 @@ +--- +layout: nodes.liquid +section: nodeOperator +date: Last Modified +title: 'Configuring Chainlink Nodes' +permalink: 'docs/chainlink-nodes/config/index/' +--- + +**Topics** + +- [v1.8.0](/docs/chainlink-nodes/config/v1_8_0/) +- [v1.7.1](/docs/chainlink-nodes/config/v1_7_1/) +- [v1.7.0](/docs/chainlink-nodes/config/v1_7_0/) +- [v1.6.0](/docs/chainlink-nodes/config/v1_6_0/) diff --git a/docs/chainlink-nodes/config/v1_6_0.md b/docs/chainlink-nodes/config/v1_6_0.md new file mode 100644 index 00000000000..42cde591382 --- /dev/null +++ b/docs/chainlink-nodes/config/v1_6_0.md @@ -0,0 +1,4268 @@ +--- +layout: nodes.liquid +section: nodeOperator +date: Last Modified +title: 'Configuring Chainlink Nodes' +permalink: 'docs/chainlink-nodes/config/v1_6_0/' +--- + +[//]: # 'Documentation generated from docs.toml - DO NOT EDIT.' + +## Table of contents + +- [Global](#Global) +- [Feature](#Feature) +- [Database](#Database) + - [Backup](#Database-Backup) + - [Listener](#Database-Listener) + - [Lock](#Database-Lock) +- [TelemetryIngress](#TelemetryIngress) +- [Log](#Log) +- [WebServer](#WebServer) + - [RateLimit](#WebServer-RateLimit) + - [MFA](#WebServer-MFA) + - [TLS](#WebServer-TLS) +- [JobPipeline](#JobPipeline) +- [FluxMonitor](#FluxMonitor) +- [OCR2](#OCR2) +- [OCR](#OCR) +- [P2P](#P2P) + - [V1](#P2P-V1) + - [V2](#P2P-V2) +- [Keeper](#Keeper) +- [AutoPprof](#AutoPprof) +- [Sentry](#Sentry) +- [EVM](#EVM) + - [BalanceMonitor](#EVM-BalanceMonitor) + - [GasEstimator](#EVM-GasEstimator) + - [BlockHistory](#EVM-GasEstimator-BlockHistory) + - [HeadTracker](#EVM-HeadTracker) + - [KeySpecific](#EVM-KeySpecific) + - [NodePool](#EVM-NodePool) + - [OCR](#EVM-OCR) + - [Nodes](#EVM-Nodes) +- [Solana](#Solana) + - [Nodes](#Solana-Nodes) +- [Terra](#Terra) + - [Nodes](#Terra-Nodes) + +## Global + +```toml +Dev = false # Default +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +ReaperExpiration = '240h' # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### Dev + +```toml +Dev = false # Default +``` + +Dev enables development mode. This setting is not recommended for production deployments. It can be useful for enabling experimental features and collecting debug information. + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL for the node to push stats to. + +### InsecureFastScrypt + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### ReaperExpiration + +```toml +ReaperExpiration = '240h' # Default +``` + +ReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = false # Default +LogPoller = false # Default +OffchainReporting2 = false # Default +OffchainReporting = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = false # Default +``` + +FeedsManager enables the experimental feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### OffchainReporting2 + +```toml +OffchainReporting2 = false # Default +``` + +OffchainReporting2 enables OCR2 jobs. + +### OffchainReporting + +```toml +OffchainReporting = false # Default +``` + +OffchainReporting enables OCR jobs. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +MigrateOnStartup = true # Default +ORMMaxIdleConns = 10 # Default +ORMMaxOpenConns = 20 # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for queries to idle in transaction before timing out. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed for a query stuck waiting to take a lock before timing out. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +### ORMMaxIdleConns + +```toml +ORMMaxIdleConns = 10 # Default +``` + +ORMMaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### ORMMaxOpenConns + +```toml +ORMMaxOpenConns = 20 # Default +``` + +ORMMaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +URL = 'http://test.back.up/fake' # Example +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `$ROOT/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### URL + +```toml +URL = 'http://test.back.up/fake' # Example +``` + +URL, if specified, is an alternative for the automatic database backup to use instead of the main database url. + +It is recommended to set this value to a _read replica_ if you have one to avoid excessive load on the main database. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + +⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + +⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + +```toml +[Database.Lock] +Mode = 'dual' # Default +AdvisoryCheckInterval = '1s' # Default +AdvisoryID = 1027321974924625846 # Default +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +By default, Chainlink nodes use the `dual` setting to provide both advisory locks and lease locks for backward and forward compatibility. Using advisory locks alone presents the following problems: + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. +- Advisory locks can silently disappear when you upgrade Postgres, so a new Chainlink node instance can take over even while the old node is still running. +- Advisory locks do not work well with pooling tools such as [pgbouncer](https://www.pgbouncer.org/). +- If the Chainlink node crashes, an advisory lock can hang around for up to several hours, which might require you to manually remove it so another instance of the Chainlink node will allow itself to boot. + +Because of the complications with advisory locks, Chainlink nodes with v1.1.0 and later support a new `lease` locking mode. This mode might become the default in future. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### Mode + +```toml +Mode = 'dual' # Default +``` + +Mode variable can be set to 'dual', 'advisorylock', 'lease', or 'none'. It controls which mode to use to enforce that only one Chainlink node can use the database. It is recommended to set this to `lease`. + +- `dual` - The default: Uses both advisory locks and lease locks for backward and forward compatibility +- `advisorylock` - Advisory lock only +- `lease` - Lease lock only +- _none_ - No locking at all: This option useful for advanced deployment environments when you are sure that only one instance of a Chainlink node will ever be running. + +### AdvisoryCheckInterval + +```toml +AdvisoryCheckInterval = '1s' # Default +``` + +AdvisoryCheckInterval controls how often the Chainlink node checks to make sure it still holds the advisory lock when advisory locking is enabled. If a node no longer holds the lock, it will try to re-acquire it. If the node cannot re-acquire the lock, the application will exit. + +This setting applies only if `Mode` is set to enable advisory locking. + +### AdvisoryID + +```toml +AdvisoryID = 1027321974924625846 # Default +``` + +AdvisoryID must match all other Chainlink nodes that might access this database. It is unlikely you will ever need to change this from the default. + +This setting applies only if `Mode` is set to enable advisory locking. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +This setting applies only if `Mode` is set to enable lease locking. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +This setting applies only if Mode is set to enable lease locking. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Default +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Default +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## Log + +```toml +[Log] +DatabaseQueries = false # Default +JSONConsole = false # Default +FileDir = '/my/log/directory' # Example +FileMaxSize = '5120mb' # Default +FileMaxAgeDays = 0 # Default +FileMaxBackups = 1 # Default +UnixTS = false # Default +``` + +### DatabaseQueries + +```toml +DatabaseQueries = false # Default +``` + +DatabaseQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### FileDir + +```toml +FileDir = '/my/log/directory' # Example +``` + +FileDir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### FileMaxSize + +```toml +FileMaxSize = '5120mb' # Default +``` + +FileMaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### FileMaxAgeDays + +```toml +FileMaxAgeDays = 0 # Default +``` + +FileMaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### FileMaxBackups + +```toml +FileMaxBackups = 1 # Default +``` + +FileMaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `FileMaxAgeDays` variable can still cause them to get deleted. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 42 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 42 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '/home/$USER/.chainlink/tls/server.crt' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '/home/$USER/.chainlink/tls/server.crt' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +## JobPipeline + +```toml +[JobPipeline] +HTTPRequestMaxSize = '32768' # Default +DefaultHTTPRequestTimeout = '15s' # Default +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### HTTPRequestMaxSize + +```toml +HTTPRequestMaxSize = '32768' # Default +``` + +HTTPRequestMaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +### DefaultHTTPRequestTimeout + +```toml +DefaultHTTPRequestTimeout = '15s' # Default +``` + +DefaultHTTPRequestTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +## OCR + +```toml +[OCR] +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +This section applies only if you are running off-chain reporting jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +PeerstoreWriteInterval = '5m' # Default +``` + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivityBootstrapCheckInterval = '20s' # Default +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively# DefaultBootstrapPeers is the default set of bootstrap peers. +cheap. We set this to 1 minute during our test.DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### PeerstoreWriteInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in host:port form as accepted by net.Dial. The addresses should be reachable by peers of interest. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaximumGracePeriod = 100 # Default +RegistryCheckGasOverhead = '200000' # Default +RegistryPerformGasOverhead = '150000' # Default +RegistrySyncInterval = '30m' # Default +RegistrySyncUpkeepQueueSize = 10 # Default +TurnLookBack = 1000 # Default +TurnFlagEnabled = false # Default +UpkeepCheckGasPriceEnabled = false # Default +``` + +### DefaultTransactionQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaximumGracePeriod + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +MaximumGracePeriod = 100 # Default +``` + +MaximumGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### RegistryCheckGasOverhead + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistryCheckGasOverhead = '200000' # Default +``` + +RegistryCheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### RegistryPerformGasOverhead + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistryPerformGasOverhead = '150000' # Default +``` + +RegistryPerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### RegistrySyncInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistrySyncInterval = '30m' # Default +``` + +RegistrySyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### RegistrySyncUpkeepQueueSize + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistrySyncUpkeepQueueSize = 10 # Default +``` + +RegistrySyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +### TurnLookBack + +```toml +TurnLookBack = 1000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +### TurnFlagEnabled + +```toml +TurnFlagEnabled = false # Default +``` + +TurnFlagEnabled enables a new algorithm for how keepers take turns. + +### UpkeepCheckGasPriceEnabled + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +UpkeepCheckGasPriceEnabled = false # Default +``` + +UpkeepCheckGasPriceEnabled includes gas price in calls to `checkUpkeep()` when set to `true`. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'prod' # Default +Release = 'v1.2.3' # Example +``` + +### Debug + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'prod' # Default +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## EVM + +EVM defaults depend on ChainID: + +
Ethereum Mainnet (1)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Ropsten (3)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Rinkeby (4)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Goerli (5)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Optimism Mainnet (10)

+ +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
RSK Mainnet (30)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
RSK Testnet (31)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Kovan (42)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
BSC Mainnet (56)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' +``` + +

+ +
OKX Testnet (65)

+ +```toml +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
OKX Mainnet (66)

+ +```toml +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Optimism Kovan (69)

+ +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '30m0s' +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
xDai Mainnet (100)

+ +```toml +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 100 +LogPollInterval = '5s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Heco Mainnet (128)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' +``` + +

+ +
Polygon Mainnet (137)

+ +```toml +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 5000 +MinIncomingConfirmations = 5 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 13 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '200 micro' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 10 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Fantom Mainnet (250)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Metis Rinkeby (588)

+ +```toml +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Metis Mainnet (1088)

+ +```toml +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Fantom Testnet (4002)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Arbitrum Mainnet (42161)

+ +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '1 micro' +PriceMax = '1 micro' +PriceMin = '1 micro' +LimitDefault = 7000000 +LimitMultiplier = '1' +LimitTransfer = 800000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Avalanche Fuji (43113)

+ +```toml +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '1 micro' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Avalanche Mainnet (43114)

+ +```toml +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '1 micro' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Polygon Mumbai (80001)

+ +```toml +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 5000 +MinIncomingConfirmations = 5 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 13 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 10 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Arbitrum Rinkeby (421611)

+ +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '1 micro' +PriceMax = '1 micro' +PriceMin = '1 micro' +LimitDefault = 7000000 +LimitMultiplier = '1' +LimitTransfer = 800000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Harmony Mainnet (1666600000)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Harmony Testnet (1666700000)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockBackfillDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'Optimism' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +LogBackfillBatchSize = 100 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### MaxInFlightTransactions + +```toml +MaxInFlightTransactions = 16 # Default +``` + +MaxInFlightTransactions controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueuedTransactions + +```toml +MaxQueuedTransactions = 250 # Default +``` + +MaxQueuedTransactions is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### MinimumContractPayment + +```toml +MinimumContractPayment = '10000000000000 juels' # Default +``` + +MinimumContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 100 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### TxReaperInterval + +```toml +TxReaperInterval = '1h' # Default +``` + +TxReaperInterval controls how often the EthTx reaper will run. + +### TxReaperThreshold + +```toml +TxReaperThreshold = '168h' # Default +``` + +TxReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### TxResendAfterThreshold + +```toml +TxResendAfterThreshold = '1m' # Default +``` + +TxResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +### UseForwarders + +```toml +UseForwarders = false # Default +``` + +UseForwarders enables or disables sending transactions through forwarder contracts. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +BlockDelay = 1 # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +### BlockDelay + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +BlockDelay = 1 # Default +``` + +BlockDelay is the number of blocks that the balance monitor trails behind head. This is required when load balancing +across multiple nodes announce a new head, then route a request to a different node which does not have this head yet. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '100 micro' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 10 # Default +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMinimum = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `L2Suggested` + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '100 micro' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes Optimism L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 10 # Default +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=MaxGasPriceWei` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=MaxGasPriceWei` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap=current block base fee * (1.125 ^ N)` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMinWei` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMaxWei` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMinimum + +```toml +TipCapMinimum = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 4 # Default +BlockDelay = 1 # Default +BlockHistorySize = 8 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 4 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockDelay + +```toml +BlockDelay = 1 # Default +``` + +BlockDelay controls the number of blocks that the block history estimator trails behind head. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### EIP1559FeeCapBufferBlocks + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +BlockEmissionIdleWarningThreshold = '1m' # Default +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +### BlockEmissionIdleWarningThreshold + +```toml +BlockEmissionIdleWarningThreshold = '1m' # Default +``` + +BlockEmissionIdleWarningThreshold will cause Chainlink to log warnings if this duration is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMaxWei. + +## EVM.NodePool + +```toml +[EVM.NodePool] +NoNewHeadsThreshold = '3m' # Default +PollFailureThreshold = 3 # Default +PollInterval = '10s' # Default +``` + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +Set to zero to disable out-of-sync checking. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 3 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +ObservationTimeout = '1m' # Example +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +### ObservationTimeout + +```toml +ObservationTimeout = '1m' # Example +``` + +ObservationTimeout sets `OCR.ObservationTimeout` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Recommended for primary nodes. Required for `SendOnly`. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1h' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1h' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Terra + +```toml +[[Terra]] +ChainID = 'Bombay-12' # Example +Enabled = true # Default +BlockRate = '6s' # Default +BlocksUntilTxTimeout = 30 # Default +ConfirmPollPeriod = '1s' # Default +FallbackGasPriceULuna = '0.015' # Default +FCDURL = 'http://terra.com' # Example +GasLimitMultiplier = '1.5' # Default +MaxMsgsPerBatch = 100 # Default +OCR2CachePollPeriod = '4s' # Default +OCR2CacheTTL = '1m' # Default +TxMsgTimeout = '10m' # Default +``` + +### ChainID + +```toml +ChainID = 'Bombay-12' # Example +``` + +ChainID is the Terra chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockRate + +```toml +BlockRate = '6s' # Default +``` + +BlockRate is the average time between blocks. + +### BlocksUntilTxTimeout + +```toml +BlocksUntilTxTimeout = 30 # Default +``` + +BlocksUntilTxTimeout is the number of blocks to wait before giving up on the tx getting confirmed. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '1s' # Default +``` + +ConfirmPollPeriod sets how often check for tx confirmation. + +### FallbackGasPriceULuna + +```toml +FallbackGasPriceULuna = '0.015' # Default +``` + +FallbackGasPriceULuna sets a fallback gas price to use when the estimator is not available. + +### FCDURL + +```toml +FCDURL = 'http://terra.com' # Example +``` + +FCDURL sets the FCD URL. + +### GasLimitMultiplier + +```toml +GasLimitMultiplier = '1.5' # Default +``` + +GasLimitMultiplier scales the estimated gas limit. + +### MaxMsgsPerBatch + +```toml +MaxMsgsPerBatch = 100 # Default +``` + +MaxMsgsPerBatch limits the numbers of mesages per transaction batch. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '4s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxMsgTimeout + +```toml +TxMsgTimeout = '10m' # Default +``` + +TxMsgTimeout is the maximum age for resending transaction before they expire. + +## Terra.Nodes + +```toml +[[Terra.Nodes]] +Name = 'primary' # Example +TendermintURL = 'http://tender.mint' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### TendermintURL + +```toml +TendermintURL = 'http://tender.mint' # Example +``` + +TendermintURL is the HTTP(S) tendermint endpoint for this node. diff --git a/docs/chainlink-nodes/config/v1_7_0.md b/docs/chainlink-nodes/config/v1_7_0.md new file mode 100644 index 00000000000..9dc0b46bd17 --- /dev/null +++ b/docs/chainlink-nodes/config/v1_7_0.md @@ -0,0 +1,4378 @@ +--- +layout: nodes.liquid +section: nodeOperator +date: Last Modified +title: 'Configuring Chainlink Nodes' +permalink: 'docs/chainlink-nodes/config/v1_7_0/' +--- + +[//]: # 'Documentation generated from docs.toml - DO NOT EDIT.' + +## Table of contents + +- [Global](#Global) +- [Feature](#Feature) +- [Database](#Database) + - [Backup](#Database-Backup) + - [Listener](#Database-Listener) + - [Lock](#Database-Lock) +- [TelemetryIngress](#TelemetryIngress) +- [Log](#Log) +- [WebServer](#WebServer) + - [RateLimit](#WebServer-RateLimit) + - [MFA](#WebServer-MFA) + - [TLS](#WebServer-TLS) +- [JobPipeline](#JobPipeline) +- [FluxMonitor](#FluxMonitor) +- [OCR2](#OCR2) +- [OCR](#OCR) +- [P2P](#P2P) + - [V1](#P2P-V1) + - [V2](#P2P-V2) +- [Keeper](#Keeper) +- [AutoPprof](#AutoPprof) +- [Sentry](#Sentry) +- [EVM](#EVM) + - [BalanceMonitor](#EVM-BalanceMonitor) + - [GasEstimator](#EVM-GasEstimator) + - [BlockHistory](#EVM-GasEstimator-BlockHistory) + - [HeadTracker](#EVM-HeadTracker) + - [KeySpecific](#EVM-KeySpecific) + - [NodePool](#EVM-NodePool) + - [OCR](#EVM-OCR) + - [Nodes](#EVM-Nodes) +- [Solana](#Solana) + - [Nodes](#Solana-Nodes) +- [Terra](#Terra) + - [Nodes](#Terra-Nodes) + +## Global + +```toml +Dev = false # Default +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +ReaperExpiration = '240h' # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### Dev + +```toml +Dev = false # Default +``` + +Dev enables development mode. This setting is not recommended for production deployments. It can be useful for enabling experimental features and collecting debug information. + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL for the node to push stats to. + +### InsecureFastScrypt + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### ReaperExpiration + +```toml +ReaperExpiration = '240h' # Default +``` + +ReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = false # Default +LogPoller = false # Default +OffchainReporting2 = false # Default +OffchainReporting = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = false # Default +``` + +FeedsManager enables the experimental feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### OffchainReporting2 + +```toml +OffchainReporting2 = false # Default +``` + +OffchainReporting2 enables OCR2 jobs. + +### OffchainReporting + +```toml +OffchainReporting = false # Default +``` + +OffchainReporting enables OCR jobs. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +MigrateOnStartup = true # Default +ORMMaxIdleConns = 10 # Default +ORMMaxOpenConns = 20 # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for queries to idle in transaction before timing out. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed for a query stuck waiting to take a lock before timing out. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +### ORMMaxIdleConns + +```toml +ORMMaxIdleConns = 10 # Default +``` + +ORMMaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### ORMMaxOpenConns + +```toml +ORMMaxOpenConns = 20 # Default +``` + +ORMMaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +URL = 'http://test.back.up/fake' # Example +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `$ROOT/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### URL + +```toml +URL = 'http://test.back.up/fake' # Example +``` + +URL, if specified, is an alternative for the automatic database backup to use instead of the main database url. + +It is recommended to set this value to a _read replica_ if you have one to avoid excessive load on the main database. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + +⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + +⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + +```toml +[Database.Lock] +Mode = 'dual' # Default +AdvisoryCheckInterval = '1s' # Default +AdvisoryID = 1027321974924625846 # Default +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +By default, Chainlink nodes use the `dual` setting to provide both advisory locks and lease locks for backward and forward compatibility. Using advisory locks alone presents the following problems: + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. +- Advisory locks can silently disappear when you upgrade Postgres, so a new Chainlink node instance can take over even while the old node is still running. +- Advisory locks do not work well with pooling tools such as [pgbouncer](https://www.pgbouncer.org/). +- If the Chainlink node crashes, an advisory lock can hang around for up to several hours, which might require you to manually remove it so another instance of the Chainlink node will allow itself to boot. + +Because of the complications with advisory locks, Chainlink nodes with v1.1.0 and later support a new `lease` locking mode. This mode might become the default in future. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### Mode + +```toml +Mode = 'dual' # Default +``` + +Mode variable can be set to 'dual', 'advisorylock', 'lease', or 'none'. It controls which mode to use to enforce that only one Chainlink node can use the database. It is recommended to set this to `lease`. + +- `dual` - The default: Uses both advisory locks and lease locks for backward and forward compatibility +- `advisorylock` - Advisory lock only +- `lease` - Lease lock only +- _none_ - No locking at all: This option useful for advanced deployment environments when you are sure that only one instance of a Chainlink node will ever be running. + +### AdvisoryCheckInterval + +```toml +AdvisoryCheckInterval = '1s' # Default +``` + +AdvisoryCheckInterval controls how often the Chainlink node checks to make sure it still holds the advisory lock when advisory locking is enabled. If a node no longer holds the lock, it will try to re-acquire it. If the node cannot re-acquire the lock, the application will exit. + +This setting applies only if `Mode` is set to enable advisory locking. + +### AdvisoryID + +```toml +AdvisoryID = 1027321974924625846 # Default +``` + +AdvisoryID must match all other Chainlink nodes that might access this database. It is unlikely you will ever need to change this from the default. + +This setting applies only if `Mode` is set to enable advisory locking. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +This setting applies only if `Mode` is set to enable lease locking. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +This setting applies only if Mode is set to enable lease locking. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Default +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Default +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## Log + +```toml +[Log] +DatabaseQueries = false # Default +JSONConsole = false # Default +FileDir = '/my/log/directory' # Example +FileMaxSize = '5120mb' # Default +FileMaxAgeDays = 0 # Default +FileMaxBackups = 1 # Default +UnixTS = false # Default +``` + +### DatabaseQueries + +```toml +DatabaseQueries = false # Default +``` + +DatabaseQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### FileDir + +```toml +FileDir = '/my/log/directory' # Example +``` + +FileDir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### FileMaxSize + +```toml +FileMaxSize = '5120mb' # Default +``` + +FileMaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### FileMaxAgeDays + +```toml +FileMaxAgeDays = 0 # Default +``` + +FileMaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### FileMaxBackups + +```toml +FileMaxBackups = 1 # Default +``` + +FileMaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `FileMaxAgeDays` variable can still cause them to get deleted. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 42 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 42 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '/home/$USER/.chainlink/tls/server.crt' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '/home/$USER/.chainlink/tls/server.crt' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +## JobPipeline + +```toml +[JobPipeline] +HTTPRequestMaxSize = '32768' # Default +DefaultHTTPRequestTimeout = '15s' # Default +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### HTTPRequestMaxSize + +```toml +HTTPRequestMaxSize = '32768' # Default +``` + +HTTPRequestMaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +### DefaultHTTPRequestTimeout + +```toml +DefaultHTTPRequestTimeout = '15s' # Default +``` + +DefaultHTTPRequestTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +## OCR + +```toml +[OCR] +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +This section applies only if you are running off-chain reporting jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +PeerstoreWriteInterval = '5m' # Default +``` + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivityBootstrapCheckInterval = '20s' # Default +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively# DefaultBootstrapPeers is the default set of bootstrap peers. +cheap. We set this to 1 minute during our test.DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### PeerstoreWriteInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in host:port form as accepted by net.Dial. The addresses should be reachable by peers of interest. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaximumGracePeriod = 100 # Default +RegistryCheckGasOverhead = '200000' # Default +RegistryPerformGasOverhead = '150000' # Default +RegistrySyncInterval = '30m' # Default +RegistrySyncUpkeepQueueSize = 10 # Default +TurnLookBack = 1000 # Default +TurnFlagEnabled = false # Default +UpkeepCheckGasPriceEnabled = false # Default +``` + +### DefaultTransactionQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaximumGracePeriod + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +MaximumGracePeriod = 100 # Default +``` + +MaximumGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### RegistryCheckGasOverhead + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistryCheckGasOverhead = '200000' # Default +``` + +RegistryCheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### RegistryPerformGasOverhead + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistryPerformGasOverhead = '150000' # Default +``` + +RegistryPerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### RegistrySyncInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistrySyncInterval = '30m' # Default +``` + +RegistrySyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### RegistrySyncUpkeepQueueSize + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistrySyncUpkeepQueueSize = 10 # Default +``` + +RegistrySyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +### TurnLookBack + +```toml +TurnLookBack = 1000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +### TurnFlagEnabled + +```toml +TurnFlagEnabled = false # Default +``` + +TurnFlagEnabled enables a new algorithm for how keepers take turns. + +### UpkeepCheckGasPriceEnabled + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +UpkeepCheckGasPriceEnabled = false # Default +``` + +UpkeepCheckGasPriceEnabled includes gas price in calls to `checkUpkeep()` when set to `true`. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'prod' # Default +Release = 'v1.2.3' # Example +``` + +### Debug + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'prod' # Default +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## EVM + +EVM defaults depend on ChainID: + +
Ethereum Mainnet (1)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Ropsten (3)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Rinkeby (4)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Goerli (5)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Optimism Mainnet (10)

+ +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
RSK Mainnet (30)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
RSK Testnet (31)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Kovan (42)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
BSC Mainnet (56)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' +``` + +

+ +
OKX Testnet (65)

+ +```toml +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
OKX Mainnet (66)

+ +```toml +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Optimism Kovan (69)

+ +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '30m0s' +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
xDai Mainnet (100)

+ +```toml +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 100 +LogPollInterval = '5s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Heco Mainnet (128)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' +``` + +

+ +
Polygon Mainnet (137)

+ +```toml +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 5000 +MinIncomingConfirmations = 5 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 13 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '200 micro' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 10 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Fantom Mainnet (250)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Metis Rinkeby (588)

+ +```toml +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Metis Mainnet (1088)

+ +```toml +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Fantom Testnet (4002)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Arbitrum Mainnet (42161)

+ +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '1 micro' +PriceMax = '1 micro' +PriceMin = '1 micro' +LimitDefault = 7000000 +LimitMultiplier = '1' +LimitTransfer = 800000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Avalanche Fuji (43113)

+ +```toml +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '1 micro' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Avalanche Mainnet (43114)

+ +```toml +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '1 micro' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Polygon Mumbai (80001)

+ +```toml +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 5000 +MinIncomingConfirmations = 5 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 13 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 10 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Arbitrum Rinkeby (421611)

+ +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '1 micro' +PriceMax = '1 micro' +PriceMin = '1 micro' +LimitDefault = 7000000 +LimitMultiplier = '1' +LimitTransfer = 800000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Sepolia (11155111)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0xb227f007804c16546Bd054dfED2E7A1fD5437678' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Harmony Mainnet (1666600000)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Harmony Testnet (1666700000)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockBackfillDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'Optimism' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +LogBackfillBatchSize = 100 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### MaxInFlightTransactions + +```toml +MaxInFlightTransactions = 16 # Default +``` + +MaxInFlightTransactions controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueuedTransactions + +```toml +MaxQueuedTransactions = 250 # Default +``` + +MaxQueuedTransactions is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### MinimumContractPayment + +```toml +MinimumContractPayment = '10000000000000 juels' # Default +``` + +MinimumContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 100 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### TxReaperInterval + +```toml +TxReaperInterval = '1h' # Default +``` + +TxReaperInterval controls how often the EthTx reaper will run. + +### TxReaperThreshold + +```toml +TxReaperThreshold = '168h' # Default +``` + +TxReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### TxResendAfterThreshold + +```toml +TxResendAfterThreshold = '1m' # Default +``` + +TxResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +### UseForwarders + +```toml +UseForwarders = false # Default +``` + +UseForwarders enables or disables sending transactions through forwarder contracts. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +BlockDelay = 1 # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +### BlockDelay + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +BlockDelay = 1 # Default +``` + +BlockDelay is the number of blocks that the balance monitor trails behind head. This is required when load balancing +across multiple nodes announce a new head, then route a request to a different node which does not have this head yet. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '100 micro' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitOCRJobType = 100_000 # Example +LimitDRJobType = 100_000 # Example +LimitVRFJobType = 100_000 # Example +LimitFMJobType = 100_000 # Example +LimitKeeperJobType = 100_000 # Example +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 10 # Default +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMinimum = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `L2Suggested` + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '100 micro' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitOCRJobType + +```toml +LimitOCRJobType = 100_000 # Example +``` + +LimitOCRJobType overrides LimitDefault for OCR jobs. + +### LimitDRJobType + +```toml +LimitDRJobType = 100_000 # Example +``` + +LimitDRJobType overrides LimitDefault for Direct Request jobs. + +### LimitVRFJobType + +```toml +LimitVRFJobType = 100_000 # Example +``` + +LimitVRFJobType overrides LimitDefault for VRF jobs. + +### LimitFMJobType + +```toml +LimitFMJobType = 100_000 # Example +``` + +LimitFMJobType overrides LimitDefault for Flux Monitor jobs. + +### LimitKeeperJobType + +```toml +LimitKeeperJobType = 100_000 # Example +``` + +LimitKeeperJobType overrides LimitDefault for Keeper jobs. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes Optimism L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 10 # Default +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=MaxGasPriceWei` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=MaxGasPriceWei` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap=current block base fee * (1.125 ^ N)` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMinWei` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMaxWei` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMinimum + +```toml +TipCapMinimum = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 4 # Default +BlockDelay = 1 # Default +BlockHistorySize = 8 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 4 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockDelay + +```toml +BlockDelay = 1 # Default +``` + +BlockDelay controls the number of blocks that the block history estimator trails behind head. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### EIP1559FeeCapBufferBlocks + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +BlockEmissionIdleWarningThreshold = '1m' # Default +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +### BlockEmissionIdleWarningThreshold + +```toml +BlockEmissionIdleWarningThreshold = '1m' # Default +``` + +BlockEmissionIdleWarningThreshold will cause Chainlink to log warnings if this duration is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMaxWei. + +## EVM.NodePool + +```toml +[EVM.NodePool] +NoNewHeadsThreshold = '3m' # Default +PollFailureThreshold = 3 # Default +PollInterval = '10s' # Default +``` + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +Set to zero to disable out-of-sync checking. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 3 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +ObservationTimeout = '1m' # Example +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +### ObservationTimeout + +```toml +ObservationTimeout = '1m' # Example +``` + +ObservationTimeout sets `OCR.ObservationTimeout` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Recommended for primary nodes. Required for `SendOnly`. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1h' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1h' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Terra + +```toml +[[Terra]] +ChainID = 'Bombay-12' # Example +Enabled = true # Default +BlockRate = '6s' # Default +BlocksUntilTxTimeout = 30 # Default +ConfirmPollPeriod = '1s' # Default +FallbackGasPriceULuna = '0.015' # Default +FCDURL = 'http://terra.com' # Example +GasLimitMultiplier = '1.5' # Default +MaxMsgsPerBatch = 100 # Default +OCR2CachePollPeriod = '4s' # Default +OCR2CacheTTL = '1m' # Default +TxMsgTimeout = '10m' # Default +``` + +### ChainID + +```toml +ChainID = 'Bombay-12' # Example +``` + +ChainID is the Terra chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockRate + +```toml +BlockRate = '6s' # Default +``` + +BlockRate is the average time between blocks. + +### BlocksUntilTxTimeout + +```toml +BlocksUntilTxTimeout = 30 # Default +``` + +BlocksUntilTxTimeout is the number of blocks to wait before giving up on the tx getting confirmed. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '1s' # Default +``` + +ConfirmPollPeriod sets how often check for tx confirmation. + +### FallbackGasPriceULuna + +```toml +FallbackGasPriceULuna = '0.015' # Default +``` + +FallbackGasPriceULuna sets a fallback gas price to use when the estimator is not available. + +### FCDURL + +```toml +FCDURL = 'http://terra.com' # Example +``` + +FCDURL sets the FCD URL. + +### GasLimitMultiplier + +```toml +GasLimitMultiplier = '1.5' # Default +``` + +GasLimitMultiplier scales the estimated gas limit. + +### MaxMsgsPerBatch + +```toml +MaxMsgsPerBatch = 100 # Default +``` + +MaxMsgsPerBatch limits the numbers of mesages per transaction batch. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '4s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxMsgTimeout + +```toml +TxMsgTimeout = '10m' # Default +``` + +TxMsgTimeout is the maximum age for resending transaction before they expire. + +## Terra.Nodes + +```toml +[[Terra.Nodes]] +Name = 'primary' # Example +TendermintURL = 'http://tender.mint' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### TendermintURL + +```toml +TendermintURL = 'http://tender.mint' # Example +``` + +TendermintURL is the HTTP(S) tendermint endpoint for this node. diff --git a/docs/chainlink-nodes/config/v1_7_1.md b/docs/chainlink-nodes/config/v1_7_1.md new file mode 100644 index 00000000000..6c50229f928 --- /dev/null +++ b/docs/chainlink-nodes/config/v1_7_1.md @@ -0,0 +1,4378 @@ +--- +layout: nodes.liquid +section: nodeOperator +date: Last Modified +title: 'Configuring Chainlink Nodes' +permalink: 'docs/chainlink-nodes/config/v1_7_1/' +--- + +[//]: # 'Documentation generated from docs.toml - DO NOT EDIT.' + +## Table of contents + +- [Global](#Global) +- [Feature](#Feature) +- [Database](#Database) + - [Backup](#Database-Backup) + - [Listener](#Database-Listener) + - [Lock](#Database-Lock) +- [TelemetryIngress](#TelemetryIngress) +- [Log](#Log) +- [WebServer](#WebServer) + - [RateLimit](#WebServer-RateLimit) + - [MFA](#WebServer-MFA) + - [TLS](#WebServer-TLS) +- [JobPipeline](#JobPipeline) +- [FluxMonitor](#FluxMonitor) +- [OCR2](#OCR2) +- [OCR](#OCR) +- [P2P](#P2P) + - [V1](#P2P-V1) + - [V2](#P2P-V2) +- [Keeper](#Keeper) +- [AutoPprof](#AutoPprof) +- [Sentry](#Sentry) +- [EVM](#EVM) + - [BalanceMonitor](#EVM-BalanceMonitor) + - [GasEstimator](#EVM-GasEstimator) + - [BlockHistory](#EVM-GasEstimator-BlockHistory) + - [HeadTracker](#EVM-HeadTracker) + - [KeySpecific](#EVM-KeySpecific) + - [NodePool](#EVM-NodePool) + - [OCR](#EVM-OCR) + - [Nodes](#EVM-Nodes) +- [Solana](#Solana) + - [Nodes](#Solana-Nodes) +- [Terra](#Terra) + - [Nodes](#Terra-Nodes) + +## Global + +```toml +Dev = false # Default +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +ReaperExpiration = '240h' # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### Dev + +```toml +Dev = false # Default +``` + +Dev enables development mode. This setting is not recommended for production deployments. It can be useful for enabling experimental features and collecting debug information. + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL for the node to push stats to. + +### InsecureFastScrypt + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### ReaperExpiration + +```toml +ReaperExpiration = '240h' # Default +``` + +ReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = false # Default +LogPoller = false # Default +OffchainReporting2 = false # Default +OffchainReporting = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = false # Default +``` + +FeedsManager enables the experimental feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### OffchainReporting2 + +```toml +OffchainReporting2 = false # Default +``` + +OffchainReporting2 enables OCR2 jobs. + +### OffchainReporting + +```toml +OffchainReporting = false # Default +``` + +OffchainReporting enables OCR jobs. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +MigrateOnStartup = true # Default +ORMMaxIdleConns = 10 # Default +ORMMaxOpenConns = 20 # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for queries to idle in transaction before timing out. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed for a query stuck waiting to take a lock before timing out. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +### ORMMaxIdleConns + +```toml +ORMMaxIdleConns = 10 # Default +``` + +ORMMaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### ORMMaxOpenConns + +```toml +ORMMaxOpenConns = 20 # Default +``` + +ORMMaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +URL = 'http://test.back.up/fake' # Example +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `$ROOT/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### URL + +```toml +URL = 'http://test.back.up/fake' # Example +``` + +URL, if specified, is an alternative for the automatic database backup to use instead of the main database url. + +It is recommended to set this value to a _read replica_ if you have one to avoid excessive load on the main database. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + +⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + +⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + +```toml +[Database.Lock] +Mode = 'dual' # Default +AdvisoryCheckInterval = '1s' # Default +AdvisoryID = 1027321974924625846 # Default +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +By default, Chainlink nodes use the `dual` setting to provide both advisory locks and lease locks for backward and forward compatibility. Using advisory locks alone presents the following problems: + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. +- Advisory locks can silently disappear when you upgrade Postgres, so a new Chainlink node instance can take over even while the old node is still running. +- Advisory locks do not work well with pooling tools such as [pgbouncer](https://www.pgbouncer.org/). +- If the Chainlink node crashes, an advisory lock can hang around for up to several hours, which might require you to manually remove it so another instance of the Chainlink node will allow itself to boot. + +Because of the complications with advisory locks, Chainlink nodes with v1.1.0 and later support a new `lease` locking mode. This mode might become the default in future. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### Mode + +```toml +Mode = 'dual' # Default +``` + +Mode variable can be set to 'dual', 'advisorylock', 'lease', or 'none'. It controls which mode to use to enforce that only one Chainlink node can use the database. It is recommended to set this to `lease`. + +- `dual` - The default: Uses both advisory locks and lease locks for backward and forward compatibility +- `advisorylock` - Advisory lock only +- `lease` - Lease lock only +- _none_ - No locking at all: This option useful for advanced deployment environments when you are sure that only one instance of a Chainlink node will ever be running. + +### AdvisoryCheckInterval + +```toml +AdvisoryCheckInterval = '1s' # Default +``` + +AdvisoryCheckInterval controls how often the Chainlink node checks to make sure it still holds the advisory lock when advisory locking is enabled. If a node no longer holds the lock, it will try to re-acquire it. If the node cannot re-acquire the lock, the application will exit. + +This setting applies only if `Mode` is set to enable advisory locking. + +### AdvisoryID + +```toml +AdvisoryID = 1027321974924625846 # Default +``` + +AdvisoryID must match all other Chainlink nodes that might access this database. It is unlikely you will ever need to change this from the default. + +This setting applies only if `Mode` is set to enable advisory locking. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +This setting applies only if `Mode` is set to enable lease locking. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +This setting applies only if Mode is set to enable lease locking. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Default +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Default +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## Log + +```toml +[Log] +DatabaseQueries = false # Default +JSONConsole = false # Default +FileDir = '/my/log/directory' # Example +FileMaxSize = '5120mb' # Default +FileMaxAgeDays = 0 # Default +FileMaxBackups = 1 # Default +UnixTS = false # Default +``` + +### DatabaseQueries + +```toml +DatabaseQueries = false # Default +``` + +DatabaseQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### FileDir + +```toml +FileDir = '/my/log/directory' # Example +``` + +FileDir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### FileMaxSize + +```toml +FileMaxSize = '5120mb' # Default +``` + +FileMaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### FileMaxAgeDays + +```toml +FileMaxAgeDays = 0 # Default +``` + +FileMaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### FileMaxBackups + +```toml +FileMaxBackups = 1 # Default +``` + +FileMaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `FileMaxAgeDays` variable can still cause them to get deleted. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 42 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 42 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '/home/$USER/.chainlink/tls/server.crt' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '/home/$USER/.chainlink/tls/server.crt' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +## JobPipeline + +```toml +[JobPipeline] +HTTPRequestMaxSize = '32768' # Default +DefaultHTTPRequestTimeout = '15s' # Default +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### HTTPRequestMaxSize + +```toml +HTTPRequestMaxSize = '32768' # Default +``` + +HTTPRequestMaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +### DefaultHTTPRequestTimeout + +```toml +DefaultHTTPRequestTimeout = '15s' # Default +``` + +DefaultHTTPRequestTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +## OCR + +```toml +[OCR] +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +This section applies only if you are running off-chain reporting jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +PeerstoreWriteInterval = '5m' # Default +``` + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivityBootstrapCheckInterval = '20s' # Default +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively# DefaultBootstrapPeers is the default set of bootstrap peers. +cheap. We set this to 1 minute during our test.DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### PeerstoreWriteInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in host:port form as accepted by net.Dial. The addresses should be reachable by peers of interest. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaximumGracePeriod = 100 # Default +RegistryCheckGasOverhead = '200000' # Default +RegistryPerformGasOverhead = '150000' # Default +RegistrySyncInterval = '30m' # Default +RegistrySyncUpkeepQueueSize = 10 # Default +TurnLookBack = 1000 # Default +TurnFlagEnabled = false # Default +UpkeepCheckGasPriceEnabled = false # Default +``` + +### DefaultTransactionQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaximumGracePeriod + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +MaximumGracePeriod = 100 # Default +``` + +MaximumGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### RegistryCheckGasOverhead + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistryCheckGasOverhead = '200000' # Default +``` + +RegistryCheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### RegistryPerformGasOverhead + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistryPerformGasOverhead = '150000' # Default +``` + +RegistryPerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### RegistrySyncInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistrySyncInterval = '30m' # Default +``` + +RegistrySyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### RegistrySyncUpkeepQueueSize + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistrySyncUpkeepQueueSize = 10 # Default +``` + +RegistrySyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +### TurnLookBack + +```toml +TurnLookBack = 1000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +### TurnFlagEnabled + +```toml +TurnFlagEnabled = false # Default +``` + +TurnFlagEnabled enables a new algorithm for how keepers take turns. + +### UpkeepCheckGasPriceEnabled + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +UpkeepCheckGasPriceEnabled = false # Default +``` + +UpkeepCheckGasPriceEnabled includes gas price in calls to `checkUpkeep()` when set to `true`. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'prod' # Default +Release = 'v1.2.3' # Example +``` + +### Debug + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'prod' # Default +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## EVM + +EVM defaults depend on ChainID: + +
Ethereum Mainnet (1)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Ropsten (3)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Rinkeby (4)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Goerli (5)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Optimism Mainnet (10)

+ +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
RSK Mainnet (30)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
RSK Testnet (31)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Kovan (42)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
BSC Mainnet (56)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' +``` + +

+ +
OKX Testnet (65)

+ +```toml +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
OKX Mainnet (66)

+ +```toml +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Optimism Kovan (69)

+ +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '30m0s' +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
xDai Mainnet (100)

+ +```toml +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 100 +LogPollInterval = '5s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Heco Mainnet (128)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' +``` + +

+ +
Polygon Mainnet (137)

+ +```toml +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 5000 +MinIncomingConfirmations = 5 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 13 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '200 micro' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 10 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Fantom Mainnet (250)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Metis Rinkeby (588)

+ +```toml +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Metis Mainnet (1088)

+ +```toml +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Fantom Testnet (4002)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Arbitrum Mainnet (42161)

+ +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '1 micro' +PriceMax = '1 micro' +PriceMin = '1 micro' +LimitDefault = 7000000 +LimitMultiplier = '1' +LimitTransfer = 800000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Avalanche Fuji (43113)

+ +```toml +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '1 micro' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Avalanche Mainnet (43114)

+ +```toml +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '1 micro' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Polygon Mumbai (80001)

+ +```toml +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 5000 +MinIncomingConfirmations = 5 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 13 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 10 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Arbitrum Rinkeby (421611)

+ +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '1 micro' +PriceMax = '1 micro' +PriceMin = '1 micro' +LimitDefault = 7000000 +LimitMultiplier = '1' +LimitTransfer = 800000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Sepolia (11155111)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0xb227f007804c16546Bd054dfED2E7A1fD5437678' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Harmony Mainnet (1666600000)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Harmony Testnet (1666700000)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockBackfillDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'Optimism' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +LogBackfillBatchSize = 100 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### MaxInFlightTransactions + +```toml +MaxInFlightTransactions = 16 # Default +``` + +MaxInFlightTransactions controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueuedTransactions + +```toml +MaxQueuedTransactions = 250 # Default +``` + +MaxQueuedTransactions is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### MinimumContractPayment + +```toml +MinimumContractPayment = '10000000000000 juels' # Default +``` + +MinimumContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 100 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### TxReaperInterval + +```toml +TxReaperInterval = '1h' # Default +``` + +TxReaperInterval controls how often the EthTx reaper will run. + +### TxReaperThreshold + +```toml +TxReaperThreshold = '168h' # Default +``` + +TxReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### TxResendAfterThreshold + +```toml +TxResendAfterThreshold = '1m' # Default +``` + +TxResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +### UseForwarders + +```toml +UseForwarders = false # Default +``` + +UseForwarders enables or disables sending transactions through forwarder contracts. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +BlockDelay = 1 # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +### BlockDelay + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +BlockDelay = 1 # Default +``` + +BlockDelay is the number of blocks that the balance monitor trails behind head. This is required when load balancing +across multiple nodes announce a new head, then route a request to a different node which does not have this head yet. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '100 micro' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitOCRJobType = 100_000 # Example +LimitDRJobType = 100_000 # Example +LimitVRFJobType = 100_000 # Example +LimitFMJobType = 100_000 # Example +LimitKeeperJobType = 100_000 # Example +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 10 # Default +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMinimum = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `L2Suggested` + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '100 micro' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitOCRJobType + +```toml +LimitOCRJobType = 100_000 # Example +``` + +LimitOCRJobType overrides LimitDefault for OCR jobs. + +### LimitDRJobType + +```toml +LimitDRJobType = 100_000 # Example +``` + +LimitDRJobType overrides LimitDefault for Direct Request jobs. + +### LimitVRFJobType + +```toml +LimitVRFJobType = 100_000 # Example +``` + +LimitVRFJobType overrides LimitDefault for VRF jobs. + +### LimitFMJobType + +```toml +LimitFMJobType = 100_000 # Example +``` + +LimitFMJobType overrides LimitDefault for Flux Monitor jobs. + +### LimitKeeperJobType + +```toml +LimitKeeperJobType = 100_000 # Example +``` + +LimitKeeperJobType overrides LimitDefault for Keeper jobs. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes Optimism L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 10 # Default +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=MaxGasPriceWei` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=MaxGasPriceWei` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap=current block base fee * (1.125 ^ N)` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMinWei` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMaxWei` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMinimum + +```toml +TipCapMinimum = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 4 # Default +BlockDelay = 1 # Default +BlockHistorySize = 8 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 4 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockDelay + +```toml +BlockDelay = 1 # Default +``` + +BlockDelay controls the number of blocks that the block history estimator trails behind head. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### EIP1559FeeCapBufferBlocks + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +BlockEmissionIdleWarningThreshold = '1m' # Default +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +### BlockEmissionIdleWarningThreshold + +```toml +BlockEmissionIdleWarningThreshold = '1m' # Default +``` + +BlockEmissionIdleWarningThreshold will cause Chainlink to log warnings if this duration is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMaxWei. + +## EVM.NodePool + +```toml +[EVM.NodePool] +NoNewHeadsThreshold = '3m' # Default +PollFailureThreshold = 3 # Default +PollInterval = '10s' # Default +``` + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +Set to zero to disable out-of-sync checking. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 3 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +ObservationTimeout = '1m' # Example +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +### ObservationTimeout + +```toml +ObservationTimeout = '1m' # Example +``` + +ObservationTimeout sets `OCR.ObservationTimeout` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Recommended for primary nodes. Required for `SendOnly`. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1h' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1h' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Terra + +```toml +[[Terra]] +ChainID = 'Bombay-12' # Example +Enabled = true # Default +BlockRate = '6s' # Default +BlocksUntilTxTimeout = 30 # Default +ConfirmPollPeriod = '1s' # Default +FallbackGasPriceULuna = '0.015' # Default +FCDURL = 'http://terra.com' # Example +GasLimitMultiplier = '1.5' # Default +MaxMsgsPerBatch = 100 # Default +OCR2CachePollPeriod = '4s' # Default +OCR2CacheTTL = '1m' # Default +TxMsgTimeout = '10m' # Default +``` + +### ChainID + +```toml +ChainID = 'Bombay-12' # Example +``` + +ChainID is the Terra chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockRate + +```toml +BlockRate = '6s' # Default +``` + +BlockRate is the average time between blocks. + +### BlocksUntilTxTimeout + +```toml +BlocksUntilTxTimeout = 30 # Default +``` + +BlocksUntilTxTimeout is the number of blocks to wait before giving up on the tx getting confirmed. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '1s' # Default +``` + +ConfirmPollPeriod sets how often check for tx confirmation. + +### FallbackGasPriceULuna + +```toml +FallbackGasPriceULuna = '0.015' # Default +``` + +FallbackGasPriceULuna sets a fallback gas price to use when the estimator is not available. + +### FCDURL + +```toml +FCDURL = 'http://terra.com' # Example +``` + +FCDURL sets the FCD URL. + +### GasLimitMultiplier + +```toml +GasLimitMultiplier = '1.5' # Default +``` + +GasLimitMultiplier scales the estimated gas limit. + +### MaxMsgsPerBatch + +```toml +MaxMsgsPerBatch = 100 # Default +``` + +MaxMsgsPerBatch limits the numbers of mesages per transaction batch. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '4s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxMsgTimeout + +```toml +TxMsgTimeout = '10m' # Default +``` + +TxMsgTimeout is the maximum age for resending transaction before they expire. + +## Terra.Nodes + +```toml +[[Terra.Nodes]] +Name = 'primary' # Example +TendermintURL = 'http://tender.mint' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### TendermintURL + +```toml +TendermintURL = 'http://tender.mint' # Example +``` + +TendermintURL is the HTTP(S) tendermint endpoint for this node. diff --git a/docs/chainlink-nodes/config/v1_8_0.md b/docs/chainlink-nodes/config/v1_8_0.md new file mode 100644 index 00000000000..e2e8784ea5f --- /dev/null +++ b/docs/chainlink-nodes/config/v1_8_0.md @@ -0,0 +1,4560 @@ +--- +layout: nodes.liquid +section: nodeOperator +date: Last Modified +title: 'Configuring Chainlink Nodes' +permalink: 'docs/chainlink-nodes/config/v1_8_0/' +--- + +[//]: # 'Documentation generated from docs.toml - DO NOT EDIT.' + +## Table of contents + +- [Global](#Global) +- [Feature](#Feature) +- [Database](#Database) + - [Backup](#Database-Backup) + - [Listener](#Database-Listener) + - [Lock](#Database-Lock) +- [TelemetryIngress](#TelemetryIngress) +- [Log](#Log) +- [WebServer](#WebServer) + - [RateLimit](#WebServer-RateLimit) + - [MFA](#WebServer-MFA) + - [TLS](#WebServer-TLS) +- [JobPipeline](#JobPipeline) +- [FluxMonitor](#FluxMonitor) +- [OCR2](#OCR2) +- [OCR](#OCR) +- [P2P](#P2P) + - [V1](#P2P-V1) + - [V2](#P2P-V2) +- [Keeper](#Keeper) +- [AutoPprof](#AutoPprof) +- [Sentry](#Sentry) +- [EVM](#EVM) + - [BalanceMonitor](#EVM-BalanceMonitor) + - [GasEstimator](#EVM-GasEstimator) + - [BlockHistory](#EVM-GasEstimator-BlockHistory) + - [HeadTracker](#EVM-HeadTracker) + - [KeySpecific](#EVM-KeySpecific) + - [NodePool](#EVM-NodePool) + - [OCR](#EVM-OCR) + - [Nodes](#EVM-Nodes) +- [Solana](#Solana) + - [Nodes](#Solana-Nodes) +- [Terra](#Terra) + - [Nodes](#Terra-Nodes) + +## Global + +```toml +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL for the node to push stats to. + +### InsecureFastScrypt + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = false # Default +LogPoller = false # Default +UICSAKeys = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = false # Default +``` + +FeedsManager enables the experimental feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### UICSAKeys + +```toml +UICSAKeys = false # Default +``` + +UICSAKeys enables CSA Keys in the UI. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +MigrateOnStartup = true # Default +ORMMaxIdleConns = 10 # Default +ORMMaxOpenConns = 20 # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for queries to idle in transaction before timing out. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed for a query stuck waiting to take a lock before timing out. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +### ORMMaxIdleConns + +```toml +ORMMaxIdleConns = 10 # Default +``` + +ORMMaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### ORMMaxOpenConns + +```toml +ORMMaxOpenConns = 20 # Default +``` + +ORMMaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `$ROOT/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + +⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + +⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + +```toml +[Database.Lock] +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. + +Because of the complications with advisory locks, Chainlink nodes with v2.0 and later only support `lease` locking mode. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +This setting applies only if `Mode` is set to enable lease locking. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +This setting applies only if Mode is set to enable lease locking. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Default +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Default +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## Log + +```toml +[Log] +DatabaseQueries = false # Default +JSONConsole = false # Default +FileDir = '/my/log/directory' # Example +FileMaxSize = '5120mb' # Default +FileMaxAgeDays = 0 # Default +FileMaxBackups = 1 # Default +UnixTS = false # Default +``` + +### DatabaseQueries + +```toml +DatabaseQueries = false # Default +``` + +DatabaseQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### FileDir + +```toml +FileDir = '/my/log/directory' # Example +``` + +FileDir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### FileMaxSize + +```toml +FileMaxSize = '5120mb' # Default +``` + +FileMaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### FileMaxAgeDays + +```toml +FileMaxAgeDays = 0 # Default +``` + +FileMaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### FileMaxBackups + +```toml +FileMaxBackups = 1 # Default +``` + +FileMaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `FileMaxAgeDays` variable can still cause them to get deleted. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +SessionReaperExpiration = '240h' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +### SessionReaperExpiration + +```toml +SessionReaperExpiration = '240h' # Default +``` + +SessionReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 42 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 42 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '/home/$USER/.chainlink/tls/server.crt' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '/home/$USER/.chainlink/tls/server.crt' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +## JobPipeline + +```toml +[JobPipeline] +HTTPRequestMaxSize = '32768' # Default +DefaultHTTPRequestTimeout = '15s' # Default +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### HTTPRequestMaxSize + +```toml +HTTPRequestMaxSize = '32768' # Default +``` + +HTTPRequestMaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +### DefaultHTTPRequestTimeout + +```toml +DefaultHTTPRequestTimeout = '15s' # Default +``` + +DefaultHTTPRequestTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +Enabled = true # Default +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables OCR2 jobs. + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +## OCR + +```toml +[OCR] +Enabled = true # Default +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +This section applies only if you are running off-chain reporting jobs. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables OCR jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +PeerstoreWriteInterval = '5m' # Default +``` + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivityBootstrapCheckInterval = '20s' # Default +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively# DefaultBootstrapPeers is the default set of bootstrap peers. +cheap. We set this to 1 minute during our test.DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### PeerstoreWriteInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in host:port form as accepted by net.Dial. The addresses should be reachable by peers of interest. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaximumGracePeriod = 100 # Default +RegistryCheckGasOverhead = 200_000 # Default +RegistryPerformGasOverhead = 150_000 # Default +RegistrySyncInterval = '30m' # Default +RegistrySyncUpkeepQueueSize = 10 # Default +TurnLookBack = 1000 # Default +TurnFlagEnabled = false # Default +UpkeepCheckGasPriceEnabled = false # Default +``` + +### DefaultTransactionQueueDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaximumGracePeriod + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +MaximumGracePeriod = 100 # Default +``` + +MaximumGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### RegistryCheckGasOverhead + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistryCheckGasOverhead = 200_000 # Default +``` + +RegistryCheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### RegistryPerformGasOverhead + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistryPerformGasOverhead = 150_000 # Default +``` + +RegistryPerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### RegistrySyncInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistrySyncInterval = '30m' # Default +``` + +RegistrySyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### RegistrySyncUpkeepQueueSize + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +RegistrySyncUpkeepQueueSize = 10 # Default +``` + +RegistrySyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +### TurnLookBack + +```toml +TurnLookBack = 1000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +### TurnFlagEnabled + +```toml +TurnFlagEnabled = false # Default +``` + +TurnFlagEnabled enables a new algorithm for how keepers take turns. + +### UpkeepCheckGasPriceEnabled + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +UpkeepCheckGasPriceEnabled = false # Default +``` + +UpkeepCheckGasPriceEnabled includes gas price in calls to `checkUpkeep()` when set to `true`. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'prod' # Default +Release = 'v1.2.3' # Example +``` + +### Debug + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'prod' # Default +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## EVM + +EVM defaults depend on ChainID: + +
Ethereum Mainnet (1)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Ropsten (3)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Rinkeby (4)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Goerli (5)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Optimism Mainnet (10)

+ +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
RSK Mainnet (30)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
RSK Testnet (31)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Kovan (42)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
BSC Mainnet (56)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' +``` + +

+ +
OKX Testnet (65)

+ +```toml +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
OKX Mainnet (66)

+ +```toml +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Optimism Kovan (69)

+ +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '30m0s' +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
xDai Mainnet (100)

+ +```toml +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 100 +LogPollInterval = '5s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Heco Mainnet (128)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' +``` + +

+ +
Polygon Mainnet (137)

+ +```toml +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 5000 +MinIncomingConfirmations = 5 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 13 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '200 micro' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 10 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Fantom Mainnet (250)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Optimism Goerli (420)

+ +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0xdc2CC710e42857672E7907CF474a69B63B93089f' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '30m0s' +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Metis Rinkeby (588)

+ +```toml +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Metis Mainnet (1088)

+ +```toml +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Simulated (1337)

+ +```toml +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '100' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '0s' +TxResendAfterThreshold = '0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 10 +MaxBufferSize = 100 +SamplingInterval = '0s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Fantom Testnet (4002)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Arbitrum Mainnet (42161)

+ +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '1 micro' +PriceMax = '1 micro' +PriceMin = '1 micro' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Avalanche Fuji (43113)

+ +```toml +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '1 micro' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Avalanche Mainnet (43114)

+ +```toml +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '1 micro' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Polygon Mumbai (80001)

+ +```toml +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 5000 +MinIncomingConfirmations = 5 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 13 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 10 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Arbitrum Rinkeby (421611)

+ +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '1 micro' +PriceMax = '1 micro' +PriceMin = '1 micro' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Arbitrum Goerli (421613)

+ +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '1 micro' +PriceMax = '1 micro' +PriceMin = '1 micro' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Ethereum Sepolia (11155111)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0xb227f007804c16546Bd054dfED2E7A1fD5437678' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Harmony Mainnet (1666600000)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +
Harmony Testnet (1666700000)

+ +```toml +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +

+ +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockBackfillDepth + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'Optimism' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +LogBackfillBatchSize = 100 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### MaxInFlightTransactions + +```toml +MaxInFlightTransactions = 16 # Default +``` + +MaxInFlightTransactions controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueuedTransactions + +```toml +MaxQueuedTransactions = 250 # Default +``` + +MaxQueuedTransactions is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### MinimumContractPayment + +```toml +MinimumContractPayment = '10000000000000 juels' # Default +``` + +MinimumContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 100 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### TxReaperInterval + +```toml +TxReaperInterval = '1h' # Default +``` + +TxReaperInterval controls how often the EthTx reaper will run. + +### TxReaperThreshold + +```toml +TxReaperThreshold = '168h' # Default +``` + +TxReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### TxResendAfterThreshold + +```toml +TxResendAfterThreshold = '1m' # Default +``` + +TxResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +### UseForwarders + +```toml +UseForwarders = false # Default +``` + +UseForwarders enables or disables sending transactions through forwarder contracts. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +BlockDelay = 1 # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +### BlockDelay + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +BlockDelay = 1 # Default +``` + +BlockDelay is the number of blocks that the balance monitor trails behind head. This is required when load balancing +across multiple nodes announce a new head, then route a request to a different node which does not have this head yet. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '100 micro' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitOCRJobType = 100_000 # Example +LimitDRJobType = 100_000 # Example +LimitVRFJobType = 100_000 # Example +LimitFMJobType = 100_000 # Example +LimitKeeperJobType = 100_000 # Example +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 10 # Default +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMinimum = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `L2Suggested` + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '100 micro' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitOCRJobType + +```toml +LimitOCRJobType = 100_000 # Example +``` + +LimitOCRJobType overrides LimitDefault for OCR jobs. + +### LimitDRJobType + +```toml +LimitDRJobType = 100_000 # Example +``` + +LimitDRJobType overrides LimitDefault for Direct Request jobs. + +### LimitVRFJobType + +```toml +LimitVRFJobType = 100_000 # Example +``` + +LimitVRFJobType overrides LimitDefault for VRF jobs. + +### LimitFMJobType + +```toml +LimitFMJobType = 100_000 # Example +``` + +LimitFMJobType overrides LimitDefault for Flux Monitor jobs. + +### LimitKeeperJobType + +```toml +LimitKeeperJobType = 100_000 # Example +``` + +LimitKeeperJobType overrides LimitDefault for Keeper jobs. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes Optimism L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 10 # Default +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=MaxGasPriceWei` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=MaxGasPriceWei` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap=current block base fee * (1.125 ^ N)` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMinWei` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMaxWei` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMinimum + +```toml +TipCapMinimum = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 4 # Default +BlockDelay = 1 # Default +BlockHistorySize = 8 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 4 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockDelay + +```toml +BlockDelay = 1 # Default +``` + +BlockDelay controls the number of blocks that the block history estimator trails behind head. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### EIP1559FeeCapBufferBlocks + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +BlockEmissionIdleWarningThreshold = '1m' # Default +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +### BlockEmissionIdleWarningThreshold + +```toml +BlockEmissionIdleWarningThreshold = '1m' # Default +``` + +BlockEmissionIdleWarningThreshold will cause Chainlink to log warnings if this duration is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + +⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMaxWei. + +## EVM.NodePool + +```toml +[EVM.NodePool] +NoNewHeadsThreshold = '3m' # Default +PollFailureThreshold = 3 # Default +PollInterval = '10s' # Default +SelectionMode = 'HighestHead' # Default +``` + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +Set to zero to disable out-of-sync checking. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 3 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +### SelectionMode + +```toml +SelectionMode = 'HighestHead' # Default +``` + +SelectionMode controls node selection strategy: HighestHead or RoundRobin. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +ObservationTimeout = '1m' # Example +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +### ObservationTimeout + +```toml +ObservationTimeout = '1m' # Example +``` + +ObservationTimeout sets `OCR.ObservationTimeout` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Recommended for primary nodes. Required for `SendOnly`. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1h' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1h' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Terra + +```toml +[[Terra]] +ChainID = 'Bombay-12' # Example +Enabled = true # Default +BlockRate = '6s' # Default +BlocksUntilTxTimeout = 30 # Default +ConfirmPollPeriod = '1s' # Default +FallbackGasPriceULuna = '0.015' # Default +FCDURL = 'http://terra.com' # Example +GasLimitMultiplier = '1.5' # Default +MaxMsgsPerBatch = 100 # Default +OCR2CachePollPeriod = '4s' # Default +OCR2CacheTTL = '1m' # Default +TxMsgTimeout = '10m' # Default +``` + +### ChainID + +```toml +ChainID = 'Bombay-12' # Example +``` + +ChainID is the Terra chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockRate + +```toml +BlockRate = '6s' # Default +``` + +BlockRate is the average time between blocks. + +### BlocksUntilTxTimeout + +```toml +BlocksUntilTxTimeout = 30 # Default +``` + +BlocksUntilTxTimeout is the number of blocks to wait before giving up on the tx getting confirmed. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '1s' # Default +``` + +ConfirmPollPeriod sets how often check for tx confirmation. + +### FallbackGasPriceULuna + +```toml +FallbackGasPriceULuna = '0.015' # Default +``` + +FallbackGasPriceULuna sets a fallback gas price to use when the estimator is not available. + +### FCDURL + +```toml +FCDURL = 'http://terra.com' # Example +``` + +FCDURL sets the FCD URL. + +### GasLimitMultiplier + +```toml +GasLimitMultiplier = '1.5' # Default +``` + +GasLimitMultiplier scales the estimated gas limit. + +### MaxMsgsPerBatch + +```toml +MaxMsgsPerBatch = 100 # Default +``` + +MaxMsgsPerBatch limits the numbers of mesages per transaction batch. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '4s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxMsgTimeout + +```toml +TxMsgTimeout = '10m' # Default +``` + +TxMsgTimeout is the maximum age for resending transaction before they expire. + +## Terra.Nodes + +```toml +[[Terra.Nodes]] +Name = 'primary' # Example +TendermintURL = 'http://tender.mint' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### TendermintURL + +```toml +TendermintURL = 'http://tender.mint' # Example +``` + +TendermintURL is the HTTP(S) tendermint endpoint for this node. diff --git a/package.json b/package.json index 888166a9f4e..5ef2f1c139d 100644 --- a/package.json +++ b/package.json @@ -22,7 +22,8 @@ "lint-ts:fix": "eslint --ext ts .", "lint-solc": "solhint 'public/samples/**/*.sol'", "prepare": "husky install", - "test": "jest" + "test": "jest", + "generate-cl-node-env-files": "npx ts-node _src/nodes-config.ts" }, "dependencies": { "@11ty/eleventy-fetch": "^4.0.0", @@ -83,7 +84,11 @@ "solhint-plugin-prettier": "^0.0.5", "ts-jest": "^29.1.1", "tsconfig-paths": "^4.2.0", - "typescript": "^5.1.6" + "typescript": "^5.1.6", + "@octokit/auth-token": "^3.0.1", + "@octokit/auth-unauthenticated": "^3.0.2", + "@types/lodash": "^4.14.182", + "octokit": "^2.0.7" }, "lint-staged": { "*.{css,md,mdx,yml,yaml,astro}": "prettier --write", @@ -108,4 +113,5 @@ "url": "https://github.com/smartcontractkit/documentation/issues" }, "homepage": "https://github.com/smartcontractkit/documentation#readme" + } diff --git a/public/nodes-config.ts b/public/nodes-config.ts new file mode 100644 index 00000000000..065eae96e4b --- /dev/null +++ b/public/nodes-config.ts @@ -0,0 +1,203 @@ +import nodesConfig from './reference/nodesConf.json'; +import { Octokit } from 'octokit'; +import { createTokenAuth } from '@octokit/auth-token'; +import fetch from 'node-fetch'; +import { writeFile, readFile } from 'fs/promises'; +import { normalize } from 'path'; +import { format } from 'prettier'; + +import * as dotenv from 'dotenv'; +dotenv.config(); + +const getTags = async (repo: string) => { + const PAT = process.env.PAT; + if (!PAT) throw new Error('PAT not found in .env'); + const auth = createTokenAuth(PAT); + const authentication = await auth(); + const octokit = new Octokit({ + auth: authentication.token, + }); + interface Node { + tagName: string; + } + + interface Edge { + node: Node; + } + + interface GetTagsResponse { + repository: { + releases: { + edges: Edge[]; + }; + }; + } + + const response = (await octokit.graphql(`{ + repository(name: "${nodesConfig.repo}", owner: "${nodesConfig.owner}") { + releases(last: 100) { + edges { + node { + tagName + } + } + } + } + }`)) as GetTagsResponse; + + return response.repository.releases.edges.map((edge) => edge.node.tagName); +}; + +const filterTags = (tags: string[]) => { + const currentTags = nodesConfig['current-tags'] as string[]; + // Test to follow this pattern: v0.8.1 , v0.8.11 , v0.11.12...Etc + const pattern = new RegExp(/^v\d{1,2}\.\d{1,2}\.\d{1,2}$/); + + return tags.filter((tag) => pattern.test(tag) && currentTags.indexOf(tag) === -1); +}; + +const sortTags = (tags: string[]) => { + return tags.sort((t1, t2) => { + // remove v + const tag1 = t1.slice(1), + tag2 = t2.slice(1); + const version1 = tag1.split('.').map((x) => parseInt(x)); + const version2 = tag2.split('.').map((x) => parseInt(x)); + if (version1.length !== version2.length) throw new Error(`cannot sort tags ${t1},${t2}`); + for (let i = 0; i < version1.length; i++) { + if (version1[i] < version2[i]) { + return -1; + } else if (version1[i] > version2[i]) { + return 1; + } + } + return 0; + }); +}; + +const updateIndex = async (tags: { tagName: string; path: string }[]) => { + if (tags.length === 0) return; + const path = normalize(`./docs/chainlink-nodes/config/index.md`); + let data = (await readFile(path)).toString(); + + for (const tag of tags) { + const entry = `- [${tag.tagName}](${tag.path})`; + data = data.replace('**Topics**', `**Topics**\n${entry}`); + } + + await writeFile( + path, + format(data, { + parser: 'markdown', + semi: true, + trailingComma: 'es5', + singleQuote: true, + printWidth: 120, + }), + { + flag: 'w', + } + ); +}; + +const updateTags = async (tags: { tagName: string; path: string }[]) => { + if (tags.length === 0) return; + for (const tag of tags) { + (nodesConfig['current-tags'] as string[]).push(tag.tagName); + } + + const nodesConfigPath = normalize('./_src/reference/nodesConf.json'); + await writeFile( + nodesConfigPath, + format(JSON.stringify(nodesConfig), { + parser: 'json', + semi: true, + trailingComma: 'es5', + singleQuote: true, + printWidth: 120, + }), + { + flag: 'w', + } + ); +}; + +const writeConfigFile = async (tagName: string) => { + const patternTagInFile = '__TAG__'; + const fileHeader = ` +--- +layout: nodes.liquid +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +permalink: "docs/chainlink-nodes/config/${patternTagInFile}/" +--- +`; + + const tagInPath = tagName.replace(/\./g, '_'); + const clean = [ + { + from: ':warning:', + to: '⚠️', + }, + ]; + const path = normalize(`./docs/chainlink-nodes/config/${tagInPath}.md`); + const url = normalize( + `https://raw.githubusercontent.com/${nodesConfig.owner}/${nodesConfig.repo}/${tagName}/${nodesConfig.path}` + ); + const response = await fetch(url); + if (response.status === 200) { + let data = await (await fetch(url)).text(); + for (const key in clean) { + data = data.replace(new RegExp(clean[key].from, 'g'), clean[key].to); + } + const content = fileHeader.replace(patternTagInFile, tagInPath) + data; + + await writeFile( + path, + format(content, { + parser: 'markdown', + semi: true, + trailingComma: 'es5', + singleQuote: true, + printWidth: 120, + }), + { + flag: 'w', + } + ); + + return { tagName, path: `/docs/chainlink-nodes/config/${tagInPath}/` }; + } else if (response.status !== 404) { + throw new Error(`couldn't fetch ${url}. status ${response.status}`); + } + return { tagName: '', path: '' }; +}; + +const writeConfigFiles = async (tags: string[]) => { + interface Result { + success: { tagName: string; path: string }[]; + error: { + tag: string; + errorMessage: any; + }[]; + } + const result: Result = { success: [], error: [] }; + for (const tag of tags) { + try { + const successTag = await writeConfigFile(tag); + if (successTag.tagName) result.success.push(successTag); + } catch (error) { + result.error.push({ tag, errorMessage: error }); + } + } + return result; +}; +getTags(nodesConfig.repo).then(async (w) => { + const sortedTags = sortTags(filterTags(w)); + const result = await writeConfigFiles(sortedTags); + console.log(`config files generated ${JSON.stringify(result)}`); + await updateIndex(result.success); + await updateTags(result.success); + if (result.error.length > 0) throw new Error(`an error happened ${JSON.stringify(result.error)}`); +}); diff --git a/public/reference/nodesConf.json b/public/reference/nodesConf.json new file mode 100644 index 00000000000..539f68bc957 --- /dev/null +++ b/public/reference/nodesConf.json @@ -0,0 +1,6 @@ +{ + "owner": "smartcontractkit", + "repo": "chainlink", + "path": "docs/CONFIG.md", + "current-tags": ["v1.6.0", "v1.7.0", "v1.7.1", "v1.8.0"] +} From 10f8dff946ed0f6760d0fda347b807cb0418a9d3 Mon Sep 17 00:00:00 2001 From: aelmanaa Date: Thu, 27 Jul 2023 22:14:33 +0200 Subject: [PATCH 2/5] node config automation --- docs/chainlink-nodes/config/index.md | 14 - package-lock.json | 1029 +++++++++++++++++ package.json | 3 +- public/reference/nodesConf.json | 6 - src/pages/chainlink-nodes/v1/config/index.mdx | 13 + .../chainlink-nodes/v1/config/v1_6_0.mdx | 8 +- .../chainlink-nodes/v1/config/v1_7_0.mdx | 8 +- .../chainlink-nodes/v1/config/v1_7_1.mdx | 8 +- .../chainlink-nodes/v1/config/v1_8_0.mdx | 8 +- .../scripts/nodes-config}/nodes-config.ts | 196 ++-- 10 files changed, 1159 insertions(+), 134 deletions(-) delete mode 100644 docs/chainlink-nodes/config/index.md delete mode 100644 public/reference/nodesConf.json create mode 100644 src/pages/chainlink-nodes/v1/config/index.mdx rename docs/chainlink-nodes/config/v1_6_0.md => src/pages/chainlink-nodes/v1/config/v1_6_0.mdx (99%) rename docs/chainlink-nodes/config/v1_7_0.md => src/pages/chainlink-nodes/v1/config/v1_7_0.mdx (99%) rename docs/chainlink-nodes/config/v1_7_1.md => src/pages/chainlink-nodes/v1/config/v1_7_1.mdx (99%) rename docs/chainlink-nodes/config/v1_8_0.md => src/pages/chainlink-nodes/v1/config/v1_8_0.mdx (99%) rename {public => src/scripts/nodes-config}/nodes-config.ts (50%) diff --git a/docs/chainlink-nodes/config/index.md b/docs/chainlink-nodes/config/index.md deleted file mode 100644 index 1da33a35c5a..00000000000 --- a/docs/chainlink-nodes/config/index.md +++ /dev/null @@ -1,14 +0,0 @@ ---- -layout: nodes.liquid -section: nodeOperator -date: Last Modified -title: 'Configuring Chainlink Nodes' -permalink: 'docs/chainlink-nodes/config/index/' ---- - -**Topics** - -- [v1.8.0](/docs/chainlink-nodes/config/v1_8_0/) -- [v1.7.1](/docs/chainlink-nodes/config/v1_7_1/) -- [v1.7.0](/docs/chainlink-nodes/config/v1_7_0/) -- [v1.6.0](/docs/chainlink-nodes/config/v1_6_0/) diff --git a/package-lock.json b/package-lock.json index 8131c4ee8a1..2673e547999 100644 --- a/package-lock.json +++ b/package-lock.json @@ -38,8 +38,11 @@ "@chainlink/solana-sdk": "^0.2.2", "@nomicfoundation/hardhat-toolbox": "^2.0.2", "@nomiclabs/hardhat-ethers": "^2.2.3", + "@octokit/auth-token": "^3.0.1", + "@octokit/auth-unauthenticated": "^3.0.2", "@openzeppelin/contracts": "^4.9.2", "@project-serum/anchor": "^0.26.0", + "@types/lodash": "^4.14.182", "@types/node": "^20.4.5", "@typescript-eslint/eslint-plugin": "^5.62.0", "@typescript-eslint/parser": "^5.62.0", @@ -57,6 +60,7 @@ "husky": "^8.0.3", "lint-staged": "^13.2.3", "lodash": "^4.17.21", + "octokit": "^2.0.7", "prettier": "^2.8.8", "prettier-plugin-astro": "^0.8.1", "prettier-plugin-solidity": "^1.1.3", @@ -4248,6 +4252,370 @@ "hardhat": "^2.0.4" } }, + "node_modules/@octokit/app": { + "version": "13.1.8", + "resolved": "https://registry.npmjs.org/@octokit/app/-/app-13.1.8.tgz", + "integrity": "sha512-bCncePMguVyFpdBbnceFKfmPOuUD94T189GuQ0l00ZcQ+mX4hyPqnaWJlsXE2HSdA71eV7p8GPDZ+ErplTkzow==", + "dev": true, + "dependencies": { + "@octokit/auth-app": "^4.0.13", + "@octokit/auth-unauthenticated": "^3.0.0", + "@octokit/core": "^4.0.0", + "@octokit/oauth-app": "^4.0.7", + "@octokit/plugin-paginate-rest": "^6.0.0", + "@octokit/types": "^9.0.0", + "@octokit/webhooks": "^10.0.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/auth-app": { + "version": "4.0.13", + "resolved": "https://registry.npmjs.org/@octokit/auth-app/-/auth-app-4.0.13.tgz", + "integrity": "sha512-NBQkmR/Zsc+8fWcVIFrwDgNXS7f4XDrkd9LHdi9DPQw1NdGHLviLzRO2ZBwTtepnwHXW5VTrVU9eFGijMUqllg==", + "dev": true, + "dependencies": { + "@octokit/auth-oauth-app": "^5.0.0", + "@octokit/auth-oauth-user": "^2.0.0", + "@octokit/request": "^6.0.0", + "@octokit/request-error": "^3.0.0", + "@octokit/types": "^9.0.0", + "deprecation": "^2.3.1", + "lru-cache": "^9.0.0", + "universal-github-app-jwt": "^1.1.1", + "universal-user-agent": "^6.0.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/auth-app/node_modules/lru-cache": { + "version": "9.1.2", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-9.1.2.tgz", + "integrity": "sha512-ERJq3FOzJTxBbFjZ7iDs+NiK4VI9Wz+RdrrAB8dio1oV+YvdPzUEE4QNiT2VD51DkIbCYRUUzCRkssXCHqSnKQ==", + "dev": true, + "engines": { + "node": "14 || >=16.14" + } + }, + "node_modules/@octokit/auth-oauth-app": { + "version": "5.0.6", + "resolved": "https://registry.npmjs.org/@octokit/auth-oauth-app/-/auth-oauth-app-5.0.6.tgz", + "integrity": "sha512-SxyfIBfeFcWd9Z/m1xa4LENTQ3l1y6Nrg31k2Dcb1jS5ov7pmwMJZ6OGX8q3K9slRgVpeAjNA1ipOAMHkieqyw==", + "dev": true, + "dependencies": { + "@octokit/auth-oauth-device": "^4.0.0", + "@octokit/auth-oauth-user": "^2.0.0", + "@octokit/request": "^6.0.0", + "@octokit/types": "^9.0.0", + "@types/btoa-lite": "^1.0.0", + "btoa-lite": "^1.0.0", + "universal-user-agent": "^6.0.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/auth-oauth-device": { + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/@octokit/auth-oauth-device/-/auth-oauth-device-4.0.5.tgz", + "integrity": "sha512-XyhoWRTzf2ZX0aZ52a6Ew5S5VBAfwwx1QnC2Np6Et3MWQpZjlREIcbcvVZtkNuXp6Z9EeiSLSDUqm3C+aMEHzQ==", + "dev": true, + "dependencies": { + "@octokit/oauth-methods": "^2.0.0", + "@octokit/request": "^6.0.0", + "@octokit/types": "^9.0.0", + "universal-user-agent": "^6.0.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/auth-oauth-user": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/@octokit/auth-oauth-user/-/auth-oauth-user-2.1.2.tgz", + "integrity": "sha512-kkRqNmFe7s5GQcojE3nSlF+AzYPpPv7kvP/xYEnE57584pixaFBH8Vovt+w5Y3E4zWUEOxjdLItmBTFAWECPAg==", + "dev": true, + "dependencies": { + "@octokit/auth-oauth-device": "^4.0.0", + "@octokit/oauth-methods": "^2.0.0", + "@octokit/request": "^6.0.0", + "@octokit/types": "^9.0.0", + "btoa-lite": "^1.0.0", + "universal-user-agent": "^6.0.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/auth-token": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/@octokit/auth-token/-/auth-token-3.0.4.tgz", + "integrity": "sha512-TWFX7cZF2LXoCvdmJWY7XVPi74aSY0+FfBZNSXEXFkMpjcqsQwDSYVv5FhRFaI0V1ECnwbz4j59T/G+rXNWaIQ==", + "dev": true, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/auth-unauthenticated": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/@octokit/auth-unauthenticated/-/auth-unauthenticated-3.0.5.tgz", + "integrity": "sha512-yH2GPFcjrTvDWPwJWWCh0tPPtTL5SMgivgKPA+6v/XmYN6hGQkAto8JtZibSKOpf8ipmeYhLNWQ2UgW0GYILCw==", + "dev": true, + "dependencies": { + "@octokit/request-error": "^3.0.0", + "@octokit/types": "^9.0.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/core": { + "version": "4.2.4", + "resolved": "https://registry.npmjs.org/@octokit/core/-/core-4.2.4.tgz", + "integrity": "sha512-rYKilwgzQ7/imScn3M9/pFfUf4I1AZEH3KhyJmtPdE2zfaXAn2mFfUy4FbKewzc2We5y/LlKLj36fWJLKC2SIQ==", + "dev": true, + "dependencies": { + "@octokit/auth-token": "^3.0.0", + "@octokit/graphql": "^5.0.0", + "@octokit/request": "^6.0.0", + "@octokit/request-error": "^3.0.0", + "@octokit/types": "^9.0.0", + "before-after-hook": "^2.2.0", + "universal-user-agent": "^6.0.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/endpoint": { + "version": "7.0.6", + "resolved": "https://registry.npmjs.org/@octokit/endpoint/-/endpoint-7.0.6.tgz", + "integrity": "sha512-5L4fseVRUsDFGR00tMWD/Trdeeihn999rTMGRMC1G/Ldi1uWlWJzI98H4Iak5DB/RVvQuyMYKqSK/R6mbSOQyg==", + "dev": true, + "dependencies": { + "@octokit/types": "^9.0.0", + "is-plain-object": "^5.0.0", + "universal-user-agent": "^6.0.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/graphql": { + "version": "5.0.6", + "resolved": "https://registry.npmjs.org/@octokit/graphql/-/graphql-5.0.6.tgz", + "integrity": "sha512-Fxyxdy/JH0MnIB5h+UQ3yCoh1FG4kWXfFKkpWqjZHw/p+Kc8Y44Hu/kCgNBT6nU1shNumEchmW/sUO1JuQnPcw==", + "dev": true, + "dependencies": { + "@octokit/request": "^6.0.0", + "@octokit/types": "^9.0.0", + "universal-user-agent": "^6.0.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/oauth-app": { + "version": "4.2.4", + "resolved": "https://registry.npmjs.org/@octokit/oauth-app/-/oauth-app-4.2.4.tgz", + "integrity": "sha512-iuOVFrmm5ZKNavRtYu5bZTtmlKLc5uVgpqTfMEqYYf2OkieV6VdxKZAb5qLVdEPL8LU2lMWcGpavPBV835cgoA==", + "dev": true, + "dependencies": { + "@octokit/auth-oauth-app": "^5.0.0", + "@octokit/auth-oauth-user": "^2.0.0", + "@octokit/auth-unauthenticated": "^3.0.0", + "@octokit/core": "^4.0.0", + "@octokit/oauth-authorization-url": "^5.0.0", + "@octokit/oauth-methods": "^2.0.0", + "@types/aws-lambda": "^8.10.83", + "fromentries": "^1.3.1", + "universal-user-agent": "^6.0.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/oauth-authorization-url": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/@octokit/oauth-authorization-url/-/oauth-authorization-url-5.0.0.tgz", + "integrity": "sha512-y1WhN+ERDZTh0qZ4SR+zotgsQUE1ysKnvBt1hvDRB2WRzYtVKQjn97HEPzoehh66Fj9LwNdlZh+p6TJatT0zzg==", + "dev": true, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/oauth-methods": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/@octokit/oauth-methods/-/oauth-methods-2.0.6.tgz", + "integrity": "sha512-l9Uml2iGN2aTWLZcm8hV+neBiFXAQ9+3sKiQe/sgumHlL6HDg0AQ8/l16xX/5jJvfxueqTW5CWbzd0MjnlfHZw==", + "dev": true, + "dependencies": { + "@octokit/oauth-authorization-url": "^5.0.0", + "@octokit/request": "^6.2.3", + "@octokit/request-error": "^3.0.3", + "@octokit/types": "^9.0.0", + "btoa-lite": "^1.0.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/openapi-types": { + "version": "18.0.0", + "resolved": "https://registry.npmjs.org/@octokit/openapi-types/-/openapi-types-18.0.0.tgz", + "integrity": "sha512-V8GImKs3TeQRxRtXFpG2wl19V7444NIOTDF24AWuIbmNaNYOQMWRbjcGDXV5B+0n887fgDcuMNOmlul+k+oJtw==", + "dev": true + }, + "node_modules/@octokit/plugin-paginate-rest": { + "version": "6.1.2", + "resolved": "https://registry.npmjs.org/@octokit/plugin-paginate-rest/-/plugin-paginate-rest-6.1.2.tgz", + "integrity": "sha512-qhrmtQeHU/IivxucOV1bbI/xZyC/iOBhclokv7Sut5vnejAIAEXVcGQeRpQlU39E0WwK9lNvJHphHri/DB6lbQ==", + "dev": true, + "dependencies": { + "@octokit/tsconfig": "^1.0.2", + "@octokit/types": "^9.2.3" + }, + "engines": { + "node": ">= 14" + }, + "peerDependencies": { + "@octokit/core": ">=4" + } + }, + "node_modules/@octokit/plugin-rest-endpoint-methods": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/@octokit/plugin-rest-endpoint-methods/-/plugin-rest-endpoint-methods-7.2.3.tgz", + "integrity": "sha512-I5Gml6kTAkzVlN7KCtjOM+Ruwe/rQppp0QU372K1GP7kNOYEKe8Xn5BW4sE62JAHdwpq95OQK/qGNyKQMUzVgA==", + "dev": true, + "dependencies": { + "@octokit/types": "^10.0.0" + }, + "engines": { + "node": ">= 14" + }, + "peerDependencies": { + "@octokit/core": ">=3" + } + }, + "node_modules/@octokit/plugin-rest-endpoint-methods/node_modules/@octokit/types": { + "version": "10.0.0", + "resolved": "https://registry.npmjs.org/@octokit/types/-/types-10.0.0.tgz", + "integrity": "sha512-Vm8IddVmhCgU1fxC1eyinpwqzXPEYu0NrYzD3YZjlGjyftdLBTeqNblRC0jmJmgxbJIsQlyogVeGnrNaaMVzIg==", + "dev": true, + "dependencies": { + "@octokit/openapi-types": "^18.0.0" + } + }, + "node_modules/@octokit/plugin-retry": { + "version": "4.1.6", + "resolved": "https://registry.npmjs.org/@octokit/plugin-retry/-/plugin-retry-4.1.6.tgz", + "integrity": "sha512-obkYzIgEC75r8+9Pnfiiqy3y/x1bc3QLE5B7qvv9wi9Kj0R5tGQFC6QMBg1154WQ9lAVypuQDGyp3hNpp15gQQ==", + "dev": true, + "dependencies": { + "@octokit/types": "^9.0.0", + "bottleneck": "^2.15.3" + }, + "engines": { + "node": ">= 14" + }, + "peerDependencies": { + "@octokit/core": ">=3" + } + }, + "node_modules/@octokit/plugin-throttling": { + "version": "5.2.3", + "resolved": "https://registry.npmjs.org/@octokit/plugin-throttling/-/plugin-throttling-5.2.3.tgz", + "integrity": "sha512-C9CFg9mrf6cugneKiaI841iG8DOv6P5XXkjmiNNut+swePxQ7RWEdAZRp5rJoE1hjsIqiYcKa/ZkOQ+ujPI39Q==", + "dev": true, + "dependencies": { + "@octokit/types": "^9.0.0", + "bottleneck": "^2.15.3" + }, + "engines": { + "node": ">= 14" + }, + "peerDependencies": { + "@octokit/core": "^4.0.0" + } + }, + "node_modules/@octokit/request": { + "version": "6.2.8", + "resolved": "https://registry.npmjs.org/@octokit/request/-/request-6.2.8.tgz", + "integrity": "sha512-ow4+pkVQ+6XVVsekSYBzJC0VTVvh/FCTUUgTsboGq+DTeWdyIFV8WSCdo0RIxk6wSkBTHqIK1mYuY7nOBXOchw==", + "dev": true, + "dependencies": { + "@octokit/endpoint": "^7.0.0", + "@octokit/request-error": "^3.0.0", + "@octokit/types": "^9.0.0", + "is-plain-object": "^5.0.0", + "node-fetch": "^2.6.7", + "universal-user-agent": "^6.0.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/request-error": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@octokit/request-error/-/request-error-3.0.3.tgz", + "integrity": "sha512-crqw3V5Iy2uOU5Np+8M/YexTlT8zxCfI+qu+LxUB7SZpje4Qmx3mub5DfEKSO8Ylyk0aogi6TYdf6kxzh2BguQ==", + "dev": true, + "dependencies": { + "@octokit/types": "^9.0.0", + "deprecation": "^2.0.0", + "once": "^1.4.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/tsconfig": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@octokit/tsconfig/-/tsconfig-1.0.2.tgz", + "integrity": "sha512-I0vDR0rdtP8p2lGMzvsJzbhdOWy405HcGovrspJ8RRibHnyRgggUSNO5AIox5LmqiwmatHKYsvj6VGFHkqS7lA==", + "dev": true + }, + "node_modules/@octokit/types": { + "version": "9.3.2", + "resolved": "https://registry.npmjs.org/@octokit/types/-/types-9.3.2.tgz", + "integrity": "sha512-D4iHGTdAnEEVsB8fl95m1hiz7D5YiRdQ9b/OEb3BYRVwbLsGHcRVPz+u+BgRLNk0Q0/4iZCBqDN96j2XNxfXrA==", + "dev": true, + "dependencies": { + "@octokit/openapi-types": "^18.0.0" + } + }, + "node_modules/@octokit/webhooks": { + "version": "10.9.1", + "resolved": "https://registry.npmjs.org/@octokit/webhooks/-/webhooks-10.9.1.tgz", + "integrity": "sha512-5NXU4VfsNOo2VSU/SrLrpPH2Z1ZVDOWFcET4EpnEBX1uh/v8Uz65UVuHIRx5TZiXhnWyRE9AO1PXHa+M/iWwZA==", + "dev": true, + "dependencies": { + "@octokit/request-error": "^3.0.0", + "@octokit/webhooks-methods": "^3.0.0", + "@octokit/webhooks-types": "6.11.0", + "aggregate-error": "^3.1.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/webhooks-methods": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@octokit/webhooks-methods/-/webhooks-methods-3.0.3.tgz", + "integrity": "sha512-2vM+DCNTJ5vL62O5LagMru6XnYhV4fJslK+5YUkTa6rWlW2S+Tqs1lF9Wr9OGqHfVwpBj3TeztWfVON/eUoW1Q==", + "dev": true, + "engines": { + "node": ">= 14" + } + }, + "node_modules/@octokit/webhooks-types": { + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@octokit/webhooks-types/-/webhooks-types-6.11.0.tgz", + "integrity": "sha512-AanzbulOHljrku1NGfafxdpTCfw2ENaWzH01N2vqQM+cUFbk868Cgh0xylz0JIM9BoKbfI++bdD6EYX0Q/UTEw==", + "dev": true + }, "node_modules/@openzeppelin/contracts": { "version": "4.9.2", "resolved": "https://registry.npmjs.org/@openzeppelin/contracts/-/contracts-4.9.2.tgz", @@ -4724,6 +5092,12 @@ "@types/estree": "*" } }, + "node_modules/@types/aws-lambda": { + "version": "8.10.119", + "resolved": "https://registry.npmjs.org/@types/aws-lambda/-/aws-lambda-8.10.119.tgz", + "integrity": "sha512-Vqm22aZrCvCd6I5g1SvpW151jfqwTzEZ7XJ3yZ6xaZG31nUEOEyzzVImjRcsN8Wi/QyPxId/x8GTtgIbsy8kEw==", + "dev": true + }, "node_modules/@types/babel__core": { "version": "7.20.1", "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.1.tgz", @@ -4770,6 +5144,12 @@ "@types/node": "*" } }, + "node_modules/@types/btoa-lite": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@types/btoa-lite/-/btoa-lite-1.0.0.tgz", + "integrity": "sha512-wJsiX1tosQ+J5+bY5LrSahHxr2wT+uME5UDwdN1kg4frt40euqA+wzECkmq4t5QbveHiJepfdThgQrPw6KiSlg==", + "dev": true + }, "node_modules/@types/chai": { "version": "4.3.5", "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.3.5.tgz", @@ -4945,6 +5325,21 @@ "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.30.tgz", "integrity": "sha512-sqm9g7mHlPY/43fcSNrCYfOeX9zkTTK+euO5E6+CVijSMm5tTjkVdwdqRkY3ljjIAf8679vps5jKUoJBCLsMDA==" }, + "node_modules/@types/jsonwebtoken": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/@types/jsonwebtoken/-/jsonwebtoken-9.0.2.tgz", + "integrity": "sha512-drE6uz7QBKq1fYqqoFKTDRdFCPHd5TCub75BM+D+cMx7NU9hUz7SESLfC2fSCXVFMO5Yj8sOWHuGqPgjc+fz0Q==", + "dev": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@types/lodash": { + "version": "4.14.196", + "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.196.tgz", + "integrity": "sha512-22y3o88f4a94mKljsZcanlNWPzO0uBsBdzLAngf2tp533LzZcQzb6+eZPJ+vCTt+bqF2XnvT9gejTLsAcJAJyQ==", + "dev": true + }, "node_modules/@types/lru-cache": { "version": "5.1.1", "resolved": "https://registry.npmjs.org/@types/lru-cache/-/lru-cache-5.1.1.tgz", @@ -6439,6 +6834,12 @@ "resolved": "https://registry.npmjs.org/bech32/-/bech32-1.1.4.tgz", "integrity": "sha512-s0IrSOzLlbvX7yp4WBfPITzpAU8sqQcpsmwXDiKwrG4r491vwCO/XpejasRNl0piBMe/DvP4Tz0mIS/X1DPJBQ==" }, + "node_modules/before-after-hook": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/before-after-hook/-/before-after-hook-2.2.3.tgz", + "integrity": "sha512-NzUnlZexiaH/46WDhANlyR2bXRopNg4F/zuSA3OpZnllCUgRaOF2znDioDWrmbNVsuZk6l9pMquQB38cfBZwkQ==", + "dev": true + }, "node_modules/bigint-buffer": { "version": "1.1.5", "resolved": "https://registry.npmjs.org/bigint-buffer/-/bigint-buffer-1.1.5.tgz", @@ -6528,6 +6929,12 @@ "text-encoding-utf-8": "^1.0.2" } }, + "node_modules/bottleneck": { + "version": "2.19.5", + "resolved": "https://registry.npmjs.org/bottleneck/-/bottleneck-2.19.5.tgz", + "integrity": "sha512-VHiNCbI1lKdl44tGrhNfU3lup0Tj/ZBMJB5/2ZbNXRCPuRCO7ed2mgcK4r17y+KB2EfuYuRaVlwNbAeaWGSpbw==", + "dev": true + }, "node_modules/boxen": { "version": "6.2.1", "resolved": "https://registry.npmjs.org/boxen/-/boxen-6.2.1.tgz", @@ -6743,6 +7150,12 @@ "node-int64": "^0.4.0" } }, + "node_modules/btoa-lite": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/btoa-lite/-/btoa-lite-1.0.0.tgz", + "integrity": "sha512-gvW7InbIyF8AicrqWoptdW08pUxuhq8BEgowNajy9RhiE86fmGAGl+bLKo6oB8QP0CkqHLowfN0oJdKC/J6LbA==", + "dev": true + }, "node_modules/buffer": { "version": "6.0.3", "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz", @@ -6766,6 +7179,12 @@ "ieee754": "^1.2.1" } }, + "node_modules/buffer-equal-constant-time": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", + "integrity": "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==", + "dev": true + }, "node_modules/buffer-from": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", @@ -7909,6 +8328,12 @@ "node": ">= 0.8" } }, + "node_modules/deprecation": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/deprecation/-/deprecation-2.3.1.tgz", + "integrity": "sha512-xmHIy4F3scKVwMsQ4WnVaS8bHOx0DmVwRywosKhaILI0ywMDWPtBSku2HNxRvF7jtwDRsoEwYQSfbxj8b7RlJQ==", + "dev": true + }, "node_modules/dequal": { "version": "2.0.3", "resolved": "https://registry.npmjs.org/dequal/-/dequal-2.0.3.tgz", @@ -8064,6 +8489,15 @@ "safer-buffer": "^2.1.0" } }, + "node_modules/ecdsa-sig-formatter": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", + "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", + "dev": true, + "dependencies": { + "safe-buffer": "^5.0.1" + } + }, "node_modules/electron-to-chromium": { "version": "1.4.451", "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.451.tgz", @@ -10409,6 +10843,26 @@ "integrity": "sha512-H5KQDspykdHuztLTg+ajGN0Z2qUjcEf3Ybxc6hLt0k7/zPkn29XnKnxlBPyW2XIddWrGaJBzBl4VLYOtk39yZg==", "dev": true }, + "node_modules/fromentries": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/fromentries/-/fromentries-1.3.2.tgz", + "integrity": "sha512-cHEpEQHUg0f8XdtZCc2ZAhrHzKzT0MrFUTcvx+hfxYu7rGMDc5SKoXFh+n4YigxsHXRzc6OrCshdR1bWH6HHyg==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, "node_modules/fs-extra": { "version": "7.0.1", "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz", @@ -12079,6 +12533,15 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/is-plain-object": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-5.0.0.tgz", + "integrity": "sha512-VRSzKkbMm5jMDoKLbltAkFQ5Qr7VDiTFGXxYFXXowVj387GeGNOCsOH6Msy00SGZ3Fp84b1Naa1psqgcCIEP5Q==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/is-reference": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/is-reference/-/is-reference-3.0.1.tgz", @@ -14829,6 +15292,55 @@ "node": "*" } }, + "node_modules/jsonwebtoken": { + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-9.0.1.tgz", + "integrity": "sha512-K8wx7eJ5TPvEjuiVSkv167EVboBDv9PZdDoF7BgeQnBLVvZWW9clr2PsQHVJDTKaEIH5JBIwHujGcHp7GgI2eg==", + "dev": true, + "dependencies": { + "jws": "^3.2.2", + "lodash": "^4.17.21", + "ms": "^2.1.1", + "semver": "^7.3.8" + }, + "engines": { + "node": ">=12", + "npm": ">=6" + } + }, + "node_modules/jsonwebtoken/node_modules/lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "dependencies": { + "yallist": "^4.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/jsonwebtoken/node_modules/semver": { + "version": "7.5.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", + "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", + "dev": true, + "dependencies": { + "lru-cache": "^6.0.0" + }, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/jsonwebtoken/node_modules/yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + }, "node_modules/jsprim": { "version": "1.4.2", "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.2.tgz", @@ -14845,6 +15357,27 @@ "node": ">=0.6.0" } }, + "node_modules/jwa": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", + "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", + "dev": true, + "dependencies": { + "buffer-equal-constant-time": "1.0.1", + "ecdsa-sig-formatter": "1.0.11", + "safe-buffer": "^5.0.1" + } + }, + "node_modules/jws": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", + "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", + "dev": true, + "dependencies": { + "jwa": "^1.4.1", + "safe-buffer": "^5.0.1" + } + }, "node_modules/keccak": { "version": "3.0.3", "resolved": "https://registry.npmjs.org/keccak/-/keccak-3.0.3.tgz", @@ -17412,6 +17945,26 @@ "integrity": "sha512-lgHwxlxV1qIg1Eap7LgIeoBWIMFibOjbrYPIPJZcI1mmGAI2m3lNYpK12Y+GBdPQ0U1hRwSord7GIaawz962qQ==", "dev": true }, + "node_modules/octokit": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/octokit/-/octokit-2.1.0.tgz", + "integrity": "sha512-Pxi6uKTjBRZWgAwsw1NgHdRlL+QASCN35OYS7X79o7PtBME0CLXEroZmPtEwlWZbPTP+iDbEy2wCbSOgm0uGIQ==", + "dev": true, + "dependencies": { + "@octokit/app": "^13.1.5", + "@octokit/core": "^4.2.1", + "@octokit/oauth-app": "^4.2.1", + "@octokit/plugin-paginate-rest": "^6.1.0", + "@octokit/plugin-rest-endpoint-methods": "^7.1.1", + "@octokit/plugin-retry": "^4.1.3", + "@octokit/plugin-throttling": "^5.2.2", + "@octokit/request-error": "^v3.0.3", + "@octokit/types": "^9.2.2" + }, + "engines": { + "node": ">= 14" + } + }, "node_modules/once": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", @@ -22258,6 +22811,22 @@ "url": "https://opencollective.com/unified" } }, + "node_modules/universal-github-app-jwt": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/universal-github-app-jwt/-/universal-github-app-jwt-1.1.1.tgz", + "integrity": "sha512-G33RTLrIBMFmlDV4u4CBF7dh71eWwykck4XgaxaIVeZKOYZRAAxvcGMRFTUclVY6xoUPQvO4Ne5wKGxYm/Yy9w==", + "dev": true, + "dependencies": { + "@types/jsonwebtoken": "^9.0.0", + "jsonwebtoken": "^9.0.0" + } + }, + "node_modules/universal-user-agent": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/universal-user-agent/-/universal-user-agent-6.0.0.tgz", + "integrity": "sha512-isyNax3wXoKaulPDZWHQqbmIx1k2tb9fb3GGDBRxCscfYV2Ch7WxPArBsFEG8s/safwXTT7H4QGhaIkTp9447w==", + "dev": true + }, "node_modules/universalify": { "version": "0.1.2", "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", @@ -26431,6 +27000,296 @@ "undici": "^5.14.0" } }, + "@octokit/app": { + "version": "13.1.8", + "resolved": "https://registry.npmjs.org/@octokit/app/-/app-13.1.8.tgz", + "integrity": "sha512-bCncePMguVyFpdBbnceFKfmPOuUD94T189GuQ0l00ZcQ+mX4hyPqnaWJlsXE2HSdA71eV7p8GPDZ+ErplTkzow==", + "dev": true, + "requires": { + "@octokit/auth-app": "^4.0.13", + "@octokit/auth-unauthenticated": "^3.0.0", + "@octokit/core": "^4.0.0", + "@octokit/oauth-app": "^4.0.7", + "@octokit/plugin-paginate-rest": "^6.0.0", + "@octokit/types": "^9.0.0", + "@octokit/webhooks": "^10.0.0" + } + }, + "@octokit/auth-app": { + "version": "4.0.13", + "resolved": "https://registry.npmjs.org/@octokit/auth-app/-/auth-app-4.0.13.tgz", + "integrity": "sha512-NBQkmR/Zsc+8fWcVIFrwDgNXS7f4XDrkd9LHdi9DPQw1NdGHLviLzRO2ZBwTtepnwHXW5VTrVU9eFGijMUqllg==", + "dev": true, + "requires": { + "@octokit/auth-oauth-app": "^5.0.0", + "@octokit/auth-oauth-user": "^2.0.0", + "@octokit/request": "^6.0.0", + "@octokit/request-error": "^3.0.0", + "@octokit/types": "^9.0.0", + "deprecation": "^2.3.1", + "lru-cache": "^9.0.0", + "universal-github-app-jwt": "^1.1.1", + "universal-user-agent": "^6.0.0" + }, + "dependencies": { + "lru-cache": { + "version": "9.1.2", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-9.1.2.tgz", + "integrity": "sha512-ERJq3FOzJTxBbFjZ7iDs+NiK4VI9Wz+RdrrAB8dio1oV+YvdPzUEE4QNiT2VD51DkIbCYRUUzCRkssXCHqSnKQ==", + "dev": true + } + } + }, + "@octokit/auth-oauth-app": { + "version": "5.0.6", + "resolved": "https://registry.npmjs.org/@octokit/auth-oauth-app/-/auth-oauth-app-5.0.6.tgz", + "integrity": "sha512-SxyfIBfeFcWd9Z/m1xa4LENTQ3l1y6Nrg31k2Dcb1jS5ov7pmwMJZ6OGX8q3K9slRgVpeAjNA1ipOAMHkieqyw==", + "dev": true, + "requires": { + "@octokit/auth-oauth-device": "^4.0.0", + "@octokit/auth-oauth-user": "^2.0.0", + "@octokit/request": "^6.0.0", + "@octokit/types": "^9.0.0", + "@types/btoa-lite": "^1.0.0", + "btoa-lite": "^1.0.0", + "universal-user-agent": "^6.0.0" + } + }, + "@octokit/auth-oauth-device": { + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/@octokit/auth-oauth-device/-/auth-oauth-device-4.0.5.tgz", + "integrity": "sha512-XyhoWRTzf2ZX0aZ52a6Ew5S5VBAfwwx1QnC2Np6Et3MWQpZjlREIcbcvVZtkNuXp6Z9EeiSLSDUqm3C+aMEHzQ==", + "dev": true, + "requires": { + "@octokit/oauth-methods": "^2.0.0", + "@octokit/request": "^6.0.0", + "@octokit/types": "^9.0.0", + "universal-user-agent": "^6.0.0" + } + }, + "@octokit/auth-oauth-user": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/@octokit/auth-oauth-user/-/auth-oauth-user-2.1.2.tgz", + "integrity": "sha512-kkRqNmFe7s5GQcojE3nSlF+AzYPpPv7kvP/xYEnE57584pixaFBH8Vovt+w5Y3E4zWUEOxjdLItmBTFAWECPAg==", + "dev": true, + "requires": { + "@octokit/auth-oauth-device": "^4.0.0", + "@octokit/oauth-methods": "^2.0.0", + "@octokit/request": "^6.0.0", + "@octokit/types": "^9.0.0", + "btoa-lite": "^1.0.0", + "universal-user-agent": "^6.0.0" + } + }, + "@octokit/auth-token": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/@octokit/auth-token/-/auth-token-3.0.4.tgz", + "integrity": "sha512-TWFX7cZF2LXoCvdmJWY7XVPi74aSY0+FfBZNSXEXFkMpjcqsQwDSYVv5FhRFaI0V1ECnwbz4j59T/G+rXNWaIQ==", + "dev": true + }, + "@octokit/auth-unauthenticated": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/@octokit/auth-unauthenticated/-/auth-unauthenticated-3.0.5.tgz", + "integrity": "sha512-yH2GPFcjrTvDWPwJWWCh0tPPtTL5SMgivgKPA+6v/XmYN6hGQkAto8JtZibSKOpf8ipmeYhLNWQ2UgW0GYILCw==", + "dev": true, + "requires": { + "@octokit/request-error": "^3.0.0", + "@octokit/types": "^9.0.0" + } + }, + "@octokit/core": { + "version": "4.2.4", + "resolved": "https://registry.npmjs.org/@octokit/core/-/core-4.2.4.tgz", + "integrity": "sha512-rYKilwgzQ7/imScn3M9/pFfUf4I1AZEH3KhyJmtPdE2zfaXAn2mFfUy4FbKewzc2We5y/LlKLj36fWJLKC2SIQ==", + "dev": true, + "requires": { + "@octokit/auth-token": "^3.0.0", + "@octokit/graphql": "^5.0.0", + "@octokit/request": "^6.0.0", + "@octokit/request-error": "^3.0.0", + "@octokit/types": "^9.0.0", + "before-after-hook": "^2.2.0", + "universal-user-agent": "^6.0.0" + } + }, + "@octokit/endpoint": { + "version": "7.0.6", + "resolved": "https://registry.npmjs.org/@octokit/endpoint/-/endpoint-7.0.6.tgz", + "integrity": "sha512-5L4fseVRUsDFGR00tMWD/Trdeeihn999rTMGRMC1G/Ldi1uWlWJzI98H4Iak5DB/RVvQuyMYKqSK/R6mbSOQyg==", + "dev": true, + "requires": { + "@octokit/types": "^9.0.0", + "is-plain-object": "^5.0.0", + "universal-user-agent": "^6.0.0" + } + }, + "@octokit/graphql": { + "version": "5.0.6", + "resolved": "https://registry.npmjs.org/@octokit/graphql/-/graphql-5.0.6.tgz", + "integrity": "sha512-Fxyxdy/JH0MnIB5h+UQ3yCoh1FG4kWXfFKkpWqjZHw/p+Kc8Y44Hu/kCgNBT6nU1shNumEchmW/sUO1JuQnPcw==", + "dev": true, + "requires": { + "@octokit/request": "^6.0.0", + "@octokit/types": "^9.0.0", + "universal-user-agent": "^6.0.0" + } + }, + "@octokit/oauth-app": { + "version": "4.2.4", + "resolved": "https://registry.npmjs.org/@octokit/oauth-app/-/oauth-app-4.2.4.tgz", + "integrity": "sha512-iuOVFrmm5ZKNavRtYu5bZTtmlKLc5uVgpqTfMEqYYf2OkieV6VdxKZAb5qLVdEPL8LU2lMWcGpavPBV835cgoA==", + "dev": true, + "requires": { + "@octokit/auth-oauth-app": "^5.0.0", + "@octokit/auth-oauth-user": "^2.0.0", + "@octokit/auth-unauthenticated": "^3.0.0", + "@octokit/core": "^4.0.0", + "@octokit/oauth-authorization-url": "^5.0.0", + "@octokit/oauth-methods": "^2.0.0", + "@types/aws-lambda": "^8.10.83", + "fromentries": "^1.3.1", + "universal-user-agent": "^6.0.0" + } + }, + "@octokit/oauth-authorization-url": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/@octokit/oauth-authorization-url/-/oauth-authorization-url-5.0.0.tgz", + "integrity": "sha512-y1WhN+ERDZTh0qZ4SR+zotgsQUE1ysKnvBt1hvDRB2WRzYtVKQjn97HEPzoehh66Fj9LwNdlZh+p6TJatT0zzg==", + "dev": true + }, + "@octokit/oauth-methods": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/@octokit/oauth-methods/-/oauth-methods-2.0.6.tgz", + "integrity": "sha512-l9Uml2iGN2aTWLZcm8hV+neBiFXAQ9+3sKiQe/sgumHlL6HDg0AQ8/l16xX/5jJvfxueqTW5CWbzd0MjnlfHZw==", + "dev": true, + "requires": { + "@octokit/oauth-authorization-url": "^5.0.0", + "@octokit/request": "^6.2.3", + "@octokit/request-error": "^3.0.3", + "@octokit/types": "^9.0.0", + "btoa-lite": "^1.0.0" + } + }, + "@octokit/openapi-types": { + "version": "18.0.0", + "resolved": "https://registry.npmjs.org/@octokit/openapi-types/-/openapi-types-18.0.0.tgz", + "integrity": "sha512-V8GImKs3TeQRxRtXFpG2wl19V7444NIOTDF24AWuIbmNaNYOQMWRbjcGDXV5B+0n887fgDcuMNOmlul+k+oJtw==", + "dev": true + }, + "@octokit/plugin-paginate-rest": { + "version": "6.1.2", + "resolved": "https://registry.npmjs.org/@octokit/plugin-paginate-rest/-/plugin-paginate-rest-6.1.2.tgz", + "integrity": "sha512-qhrmtQeHU/IivxucOV1bbI/xZyC/iOBhclokv7Sut5vnejAIAEXVcGQeRpQlU39E0WwK9lNvJHphHri/DB6lbQ==", + "dev": true, + "requires": { + "@octokit/tsconfig": "^1.0.2", + "@octokit/types": "^9.2.3" + } + }, + "@octokit/plugin-rest-endpoint-methods": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/@octokit/plugin-rest-endpoint-methods/-/plugin-rest-endpoint-methods-7.2.3.tgz", + "integrity": "sha512-I5Gml6kTAkzVlN7KCtjOM+Ruwe/rQppp0QU372K1GP7kNOYEKe8Xn5BW4sE62JAHdwpq95OQK/qGNyKQMUzVgA==", + "dev": true, + "requires": { + "@octokit/types": "^10.0.0" + }, + "dependencies": { + "@octokit/types": { + "version": "10.0.0", + "resolved": "https://registry.npmjs.org/@octokit/types/-/types-10.0.0.tgz", + "integrity": "sha512-Vm8IddVmhCgU1fxC1eyinpwqzXPEYu0NrYzD3YZjlGjyftdLBTeqNblRC0jmJmgxbJIsQlyogVeGnrNaaMVzIg==", + "dev": true, + "requires": { + "@octokit/openapi-types": "^18.0.0" + } + } + } + }, + "@octokit/plugin-retry": { + "version": "4.1.6", + "resolved": "https://registry.npmjs.org/@octokit/plugin-retry/-/plugin-retry-4.1.6.tgz", + "integrity": "sha512-obkYzIgEC75r8+9Pnfiiqy3y/x1bc3QLE5B7qvv9wi9Kj0R5tGQFC6QMBg1154WQ9lAVypuQDGyp3hNpp15gQQ==", + "dev": true, + "requires": { + "@octokit/types": "^9.0.0", + "bottleneck": "^2.15.3" + } + }, + "@octokit/plugin-throttling": { + "version": "5.2.3", + "resolved": "https://registry.npmjs.org/@octokit/plugin-throttling/-/plugin-throttling-5.2.3.tgz", + "integrity": "sha512-C9CFg9mrf6cugneKiaI841iG8DOv6P5XXkjmiNNut+swePxQ7RWEdAZRp5rJoE1hjsIqiYcKa/ZkOQ+ujPI39Q==", + "dev": true, + "requires": { + "@octokit/types": "^9.0.0", + "bottleneck": "^2.15.3" + } + }, + "@octokit/request": { + "version": "6.2.8", + "resolved": "https://registry.npmjs.org/@octokit/request/-/request-6.2.8.tgz", + "integrity": "sha512-ow4+pkVQ+6XVVsekSYBzJC0VTVvh/FCTUUgTsboGq+DTeWdyIFV8WSCdo0RIxk6wSkBTHqIK1mYuY7nOBXOchw==", + "dev": true, + "requires": { + "@octokit/endpoint": "^7.0.0", + "@octokit/request-error": "^3.0.0", + "@octokit/types": "^9.0.0", + "is-plain-object": "^5.0.0", + "node-fetch": "^2.6.7", + "universal-user-agent": "^6.0.0" + } + }, + "@octokit/request-error": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@octokit/request-error/-/request-error-3.0.3.tgz", + "integrity": "sha512-crqw3V5Iy2uOU5Np+8M/YexTlT8zxCfI+qu+LxUB7SZpje4Qmx3mub5DfEKSO8Ylyk0aogi6TYdf6kxzh2BguQ==", + "dev": true, + "requires": { + "@octokit/types": "^9.0.0", + "deprecation": "^2.0.0", + "once": "^1.4.0" + } + }, + "@octokit/tsconfig": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@octokit/tsconfig/-/tsconfig-1.0.2.tgz", + "integrity": "sha512-I0vDR0rdtP8p2lGMzvsJzbhdOWy405HcGovrspJ8RRibHnyRgggUSNO5AIox5LmqiwmatHKYsvj6VGFHkqS7lA==", + "dev": true + }, + "@octokit/types": { + "version": "9.3.2", + "resolved": "https://registry.npmjs.org/@octokit/types/-/types-9.3.2.tgz", + "integrity": "sha512-D4iHGTdAnEEVsB8fl95m1hiz7D5YiRdQ9b/OEb3BYRVwbLsGHcRVPz+u+BgRLNk0Q0/4iZCBqDN96j2XNxfXrA==", + "dev": true, + "requires": { + "@octokit/openapi-types": "^18.0.0" + } + }, + "@octokit/webhooks": { + "version": "10.9.1", + "resolved": "https://registry.npmjs.org/@octokit/webhooks/-/webhooks-10.9.1.tgz", + "integrity": "sha512-5NXU4VfsNOo2VSU/SrLrpPH2Z1ZVDOWFcET4EpnEBX1uh/v8Uz65UVuHIRx5TZiXhnWyRE9AO1PXHa+M/iWwZA==", + "dev": true, + "requires": { + "@octokit/request-error": "^3.0.0", + "@octokit/webhooks-methods": "^3.0.0", + "@octokit/webhooks-types": "6.11.0", + "aggregate-error": "^3.1.0" + } + }, + "@octokit/webhooks-methods": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@octokit/webhooks-methods/-/webhooks-methods-3.0.3.tgz", + "integrity": "sha512-2vM+DCNTJ5vL62O5LagMru6XnYhV4fJslK+5YUkTa6rWlW2S+Tqs1lF9Wr9OGqHfVwpBj3TeztWfVON/eUoW1Q==", + "dev": true + }, + "@octokit/webhooks-types": { + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@octokit/webhooks-types/-/webhooks-types-6.11.0.tgz", + "integrity": "sha512-AanzbulOHljrku1NGfafxdpTCfw2ENaWzH01N2vqQM+cUFbk868Cgh0xylz0JIM9BoKbfI++bdD6EYX0Q/UTEw==", + "dev": true + }, "@openzeppelin/contracts": { "version": "4.9.2", "resolved": "https://registry.npmjs.org/@openzeppelin/contracts/-/contracts-4.9.2.tgz", @@ -26812,6 +27671,12 @@ "@types/estree": "*" } }, + "@types/aws-lambda": { + "version": "8.10.119", + "resolved": "https://registry.npmjs.org/@types/aws-lambda/-/aws-lambda-8.10.119.tgz", + "integrity": "sha512-Vqm22aZrCvCd6I5g1SvpW151jfqwTzEZ7XJ3yZ6xaZG31nUEOEyzzVImjRcsN8Wi/QyPxId/x8GTtgIbsy8kEw==", + "dev": true + }, "@types/babel__core": { "version": "7.20.1", "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.1.tgz", @@ -26858,6 +27723,12 @@ "@types/node": "*" } }, + "@types/btoa-lite": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@types/btoa-lite/-/btoa-lite-1.0.0.tgz", + "integrity": "sha512-wJsiX1tosQ+J5+bY5LrSahHxr2wT+uME5UDwdN1kg4frt40euqA+wzECkmq4t5QbveHiJepfdThgQrPw6KiSlg==", + "dev": true + }, "@types/chai": { "version": "4.3.5", "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.3.5.tgz", @@ -27033,6 +27904,21 @@ "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.30.tgz", "integrity": "sha512-sqm9g7mHlPY/43fcSNrCYfOeX9zkTTK+euO5E6+CVijSMm5tTjkVdwdqRkY3ljjIAf8679vps5jKUoJBCLsMDA==" }, + "@types/jsonwebtoken": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/@types/jsonwebtoken/-/jsonwebtoken-9.0.2.tgz", + "integrity": "sha512-drE6uz7QBKq1fYqqoFKTDRdFCPHd5TCub75BM+D+cMx7NU9hUz7SESLfC2fSCXVFMO5Yj8sOWHuGqPgjc+fz0Q==", + "dev": true, + "requires": { + "@types/node": "*" + } + }, + "@types/lodash": { + "version": "4.14.196", + "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.196.tgz", + "integrity": "sha512-22y3o88f4a94mKljsZcanlNWPzO0uBsBdzLAngf2tp533LzZcQzb6+eZPJ+vCTt+bqF2XnvT9gejTLsAcJAJyQ==", + "dev": true + }, "@types/lru-cache": { "version": "5.1.1", "resolved": "https://registry.npmjs.org/@types/lru-cache/-/lru-cache-5.1.1.tgz", @@ -28183,6 +29069,12 @@ "resolved": "https://registry.npmjs.org/bech32/-/bech32-1.1.4.tgz", "integrity": "sha512-s0IrSOzLlbvX7yp4WBfPITzpAU8sqQcpsmwXDiKwrG4r491vwCO/XpejasRNl0piBMe/DvP4Tz0mIS/X1DPJBQ==" }, + "before-after-hook": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/before-after-hook/-/before-after-hook-2.2.3.tgz", + "integrity": "sha512-NzUnlZexiaH/46WDhANlyR2bXRopNg4F/zuSA3OpZnllCUgRaOF2znDioDWrmbNVsuZk6l9pMquQB38cfBZwkQ==", + "dev": true + }, "bigint-buffer": { "version": "1.1.5", "resolved": "https://registry.npmjs.org/bigint-buffer/-/bigint-buffer-1.1.5.tgz", @@ -28261,6 +29153,12 @@ "text-encoding-utf-8": "^1.0.2" } }, + "bottleneck": { + "version": "2.19.5", + "resolved": "https://registry.npmjs.org/bottleneck/-/bottleneck-2.19.5.tgz", + "integrity": "sha512-VHiNCbI1lKdl44tGrhNfU3lup0Tj/ZBMJB5/2ZbNXRCPuRCO7ed2mgcK4r17y+KB2EfuYuRaVlwNbAeaWGSpbw==", + "dev": true + }, "boxen": { "version": "6.2.1", "resolved": "https://registry.npmjs.org/boxen/-/boxen-6.2.1.tgz", @@ -28425,6 +29323,12 @@ "node-int64": "^0.4.0" } }, + "btoa-lite": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/btoa-lite/-/btoa-lite-1.0.0.tgz", + "integrity": "sha512-gvW7InbIyF8AicrqWoptdW08pUxuhq8BEgowNajy9RhiE86fmGAGl+bLKo6oB8QP0CkqHLowfN0oJdKC/J6LbA==", + "dev": true + }, "buffer": { "version": "6.0.3", "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz", @@ -28434,6 +29338,12 @@ "ieee754": "^1.2.1" } }, + "buffer-equal-constant-time": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", + "integrity": "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==", + "dev": true + }, "buffer-from": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", @@ -29268,6 +30178,12 @@ "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", "dev": true }, + "deprecation": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/deprecation/-/deprecation-2.3.1.tgz", + "integrity": "sha512-xmHIy4F3scKVwMsQ4WnVaS8bHOx0DmVwRywosKhaILI0ywMDWPtBSku2HNxRvF7jtwDRsoEwYQSfbxj8b7RlJQ==", + "dev": true + }, "dequal": { "version": "2.0.3", "resolved": "https://registry.npmjs.org/dequal/-/dequal-2.0.3.tgz", @@ -29391,6 +30307,15 @@ "safer-buffer": "^2.1.0" } }, + "ecdsa-sig-formatter": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", + "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", + "dev": true, + "requires": { + "safe-buffer": "^5.0.1" + } + }, "electron-to-chromium": { "version": "1.4.451", "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.451.tgz", @@ -31218,6 +32143,12 @@ "integrity": "sha512-H5KQDspykdHuztLTg+ajGN0Z2qUjcEf3Ybxc6hLt0k7/zPkn29XnKnxlBPyW2XIddWrGaJBzBl4VLYOtk39yZg==", "dev": true }, + "fromentries": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/fromentries/-/fromentries-1.3.2.tgz", + "integrity": "sha512-cHEpEQHUg0f8XdtZCc2ZAhrHzKzT0MrFUTcvx+hfxYu7rGMDc5SKoXFh+n4YigxsHXRzc6OrCshdR1bWH6HHyg==", + "dev": true + }, "fs-extra": { "version": "7.0.1", "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz", @@ -32428,6 +33359,12 @@ "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-4.1.0.tgz", "integrity": "sha512-+Pgi+vMuUNkJyExiMBt5IlFoMyKnr5zhJ4Uspz58WOhBF5QoIZkFyNHIbBAtHwzVAgk5RtndVNsDRN61/mmDqg==" }, + "is-plain-object": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-5.0.0.tgz", + "integrity": "sha512-VRSzKkbMm5jMDoKLbltAkFQ5Qr7VDiTFGXxYFXXowVj387GeGNOCsOH6Msy00SGZ3Fp84b1Naa1psqgcCIEP5Q==", + "dev": true + }, "is-reference": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/is-reference/-/is-reference-3.0.1.tgz", @@ -34535,6 +35472,44 @@ "through": ">=2.2.7 <3" } }, + "jsonwebtoken": { + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-9.0.1.tgz", + "integrity": "sha512-K8wx7eJ5TPvEjuiVSkv167EVboBDv9PZdDoF7BgeQnBLVvZWW9clr2PsQHVJDTKaEIH5JBIwHujGcHp7GgI2eg==", + "dev": true, + "requires": { + "jws": "^3.2.2", + "lodash": "^4.17.21", + "ms": "^2.1.1", + "semver": "^7.3.8" + }, + "dependencies": { + "lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "requires": { + "yallist": "^4.0.0" + } + }, + "semver": { + "version": "7.5.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", + "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } + }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + } + } + }, "jsprim": { "version": "1.4.2", "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.2.tgz", @@ -34548,6 +35523,27 @@ "verror": "1.10.0" } }, + "jwa": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", + "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", + "dev": true, + "requires": { + "buffer-equal-constant-time": "1.0.1", + "ecdsa-sig-formatter": "1.0.11", + "safe-buffer": "^5.0.1" + } + }, + "jws": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", + "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", + "dev": true, + "requires": { + "jwa": "^1.4.1", + "safe-buffer": "^5.0.1" + } + }, "keccak": { "version": "3.0.3", "resolved": "https://registry.npmjs.org/keccak/-/keccak-3.0.3.tgz", @@ -36358,6 +37354,23 @@ "integrity": "sha512-lgHwxlxV1qIg1Eap7LgIeoBWIMFibOjbrYPIPJZcI1mmGAI2m3lNYpK12Y+GBdPQ0U1hRwSord7GIaawz962qQ==", "dev": true }, + "octokit": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/octokit/-/octokit-2.1.0.tgz", + "integrity": "sha512-Pxi6uKTjBRZWgAwsw1NgHdRlL+QASCN35OYS7X79o7PtBME0CLXEroZmPtEwlWZbPTP+iDbEy2wCbSOgm0uGIQ==", + "dev": true, + "requires": { + "@octokit/app": "^13.1.5", + "@octokit/core": "^4.2.1", + "@octokit/oauth-app": "^4.2.1", + "@octokit/plugin-paginate-rest": "^6.1.0", + "@octokit/plugin-rest-endpoint-methods": "^7.1.1", + "@octokit/plugin-retry": "^4.1.3", + "@octokit/plugin-throttling": "^5.2.2", + "@octokit/request-error": "^v3.0.3", + "@octokit/types": "^9.2.2" + } + }, "once": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", @@ -39967,6 +40980,22 @@ "unist-util-is": "^5.0.0" } }, + "universal-github-app-jwt": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/universal-github-app-jwt/-/universal-github-app-jwt-1.1.1.tgz", + "integrity": "sha512-G33RTLrIBMFmlDV4u4CBF7dh71eWwykck4XgaxaIVeZKOYZRAAxvcGMRFTUclVY6xoUPQvO4Ne5wKGxYm/Yy9w==", + "dev": true, + "requires": { + "@types/jsonwebtoken": "^9.0.0", + "jsonwebtoken": "^9.0.0" + } + }, + "universal-user-agent": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/universal-user-agent/-/universal-user-agent-6.0.0.tgz", + "integrity": "sha512-isyNax3wXoKaulPDZWHQqbmIx1k2tb9fb3GGDBRxCscfYV2Ch7WxPArBsFEG8s/safwXTT7H4QGhaIkTp9447w==", + "dev": true + }, "universalify": { "version": "0.1.2", "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", diff --git a/package.json b/package.json index 5ef2f1c139d..0db3df11e27 100644 --- a/package.json +++ b/package.json @@ -23,7 +23,7 @@ "lint-solc": "solhint 'public/samples/**/*.sol'", "prepare": "husky install", "test": "jest", - "generate-cl-node-env-files": "npx ts-node _src/nodes-config.ts" + "generate-cl-node-env-files": "npx ts-node -r tsconfig-paths/register src/scripts/nodes-config/nodes-config.ts" }, "dependencies": { "@11ty/eleventy-fetch": "^4.0.0", @@ -113,5 +113,4 @@ "url": "https://github.com/smartcontractkit/documentation/issues" }, "homepage": "https://github.com/smartcontractkit/documentation#readme" - } diff --git a/public/reference/nodesConf.json b/public/reference/nodesConf.json deleted file mode 100644 index 539f68bc957..00000000000 --- a/public/reference/nodesConf.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "owner": "smartcontractkit", - "repo": "chainlink", - "path": "docs/CONFIG.md", - "current-tags": ["v1.6.0", "v1.7.0", "v1.7.1", "v1.8.0"] -} diff --git a/src/pages/chainlink-nodes/v1/config/index.mdx b/src/pages/chainlink-nodes/v1/config/index.mdx new file mode 100644 index 00000000000..e531322c646 --- /dev/null +++ b/src/pages/chainlink-nodes/v1/config/index.mdx @@ -0,0 +1,13 @@ +--- +layout: ../../../../layouts/MainLayout.astro +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +--- + +**Topics** + +- [v1.8.0](/chainlink-nodes/v1/config/v1_8_0) +- [v1.7.1](/chainlink-nodes/v1/config/v1_7_1) +- [v1.7.0](/chainlink-nodes/v1/config/v1_7_0) +- [v1.6.0](/chainlink-nodes/v1/config/v1_6_0) diff --git a/docs/chainlink-nodes/config/v1_6_0.md b/src/pages/chainlink-nodes/v1/config/v1_6_0.mdx similarity index 99% rename from docs/chainlink-nodes/config/v1_6_0.md rename to src/pages/chainlink-nodes/v1/config/v1_6_0.mdx index 42cde591382..654a169a56b 100644 --- a/docs/chainlink-nodes/config/v1_6_0.md +++ b/src/pages/chainlink-nodes/v1/config/v1_6_0.mdx @@ -1,12 +1,12 @@ --- -layout: nodes.liquid +layout: ../../../../layouts/MainLayout.astro section: nodeOperator date: Last Modified -title: 'Configuring Chainlink Nodes' -permalink: 'docs/chainlink-nodes/config/v1_6_0/' +title: "Configuring Chainlink Nodes" +permalink: "docs/chainlink-nodes/config/v1_6_0/" --- -[//]: # 'Documentation generated from docs.toml - DO NOT EDIT.' +[//]: # "Documentation generated from docs.toml - DO NOT EDIT." ## Table of contents diff --git a/docs/chainlink-nodes/config/v1_7_0.md b/src/pages/chainlink-nodes/v1/config/v1_7_0.mdx similarity index 99% rename from docs/chainlink-nodes/config/v1_7_0.md rename to src/pages/chainlink-nodes/v1/config/v1_7_0.mdx index 9dc0b46bd17..52d9494e3de 100644 --- a/docs/chainlink-nodes/config/v1_7_0.md +++ b/src/pages/chainlink-nodes/v1/config/v1_7_0.mdx @@ -1,12 +1,12 @@ --- -layout: nodes.liquid +layout: ../../../../layouts/MainLayout.astro section: nodeOperator date: Last Modified -title: 'Configuring Chainlink Nodes' -permalink: 'docs/chainlink-nodes/config/v1_7_0/' +title: "Configuring Chainlink Nodes" +permalink: "docs/chainlink-nodes/config/v1_7_0/" --- -[//]: # 'Documentation generated from docs.toml - DO NOT EDIT.' +[//]: # "Documentation generated from docs.toml - DO NOT EDIT." ## Table of contents diff --git a/docs/chainlink-nodes/config/v1_7_1.md b/src/pages/chainlink-nodes/v1/config/v1_7_1.mdx similarity index 99% rename from docs/chainlink-nodes/config/v1_7_1.md rename to src/pages/chainlink-nodes/v1/config/v1_7_1.mdx index 6c50229f928..7d1e51ff4c2 100644 --- a/docs/chainlink-nodes/config/v1_7_1.md +++ b/src/pages/chainlink-nodes/v1/config/v1_7_1.mdx @@ -1,12 +1,12 @@ --- -layout: nodes.liquid +layout: ../../../../layouts/MainLayout.astro section: nodeOperator date: Last Modified -title: 'Configuring Chainlink Nodes' -permalink: 'docs/chainlink-nodes/config/v1_7_1/' +title: "Configuring Chainlink Nodes" +permalink: "docs/chainlink-nodes/config/v1_7_1/" --- -[//]: # 'Documentation generated from docs.toml - DO NOT EDIT.' +[//]: # "Documentation generated from docs.toml - DO NOT EDIT." ## Table of contents diff --git a/docs/chainlink-nodes/config/v1_8_0.md b/src/pages/chainlink-nodes/v1/config/v1_8_0.mdx similarity index 99% rename from docs/chainlink-nodes/config/v1_8_0.md rename to src/pages/chainlink-nodes/v1/config/v1_8_0.mdx index e2e8784ea5f..8d09f510de4 100644 --- a/docs/chainlink-nodes/config/v1_8_0.md +++ b/src/pages/chainlink-nodes/v1/config/v1_8_0.mdx @@ -1,13 +1,11 @@ --- -layout: nodes.liquid +layout: ../../../../layouts/MainLayout.astro section: nodeOperator date: Last Modified -title: 'Configuring Chainlink Nodes' -permalink: 'docs/chainlink-nodes/config/v1_8_0/' +title: "Configuring Chainlink Nodes" +permalink: "docs/chainlink-nodes/config/v1_8_0/" --- -[//]: # 'Documentation generated from docs.toml - DO NOT EDIT.' - ## Table of contents - [Global](#Global) diff --git a/public/nodes-config.ts b/src/scripts/nodes-config/nodes-config.ts similarity index 50% rename from public/nodes-config.ts rename to src/scripts/nodes-config/nodes-config.ts index 065eae96e4b..a085f1a110e 100644 --- a/public/nodes-config.ts +++ b/src/scripts/nodes-config/nodes-config.ts @@ -1,36 +1,42 @@ -import nodesConfig from './reference/nodesConf.json'; -import { Octokit } from 'octokit'; -import { createTokenAuth } from '@octokit/auth-token'; -import fetch from 'node-fetch'; -import { writeFile, readFile } from 'fs/promises'; -import { normalize } from 'path'; -import { format } from 'prettier'; - -import * as dotenv from 'dotenv'; -dotenv.config(); - -const getTags = async (repo: string) => { - const PAT = process.env.PAT; - if (!PAT) throw new Error('PAT not found in .env'); - const auth = createTokenAuth(PAT); - const authentication = await auth(); +import { Octokit } from "octokit" +import { createTokenAuth } from "@octokit/auth-token" +import fetch from "node-fetch" +import { writeFile, readFile } from "fs/promises" +import { normalize } from "path" +import { format } from "prettier" + +import * as dotenv from "dotenv" +dotenv.config() + +const nodesConfig = { + owner: "smartcontractkit", + repo: "chainlink", + path: "docs/CONFIG.md", + "current-tags": ["v1.6.0", "v1.7.0", "v1.7.1", "v1.8.0"], +} + +const getTags = async () => { + const PAT = process.env.PAT + if (!PAT) throw new Error("PAT not found in .env") + const auth = createTokenAuth(PAT) + const authentication = await auth() const octokit = new Octokit({ auth: authentication.token, - }); + }) interface Node { - tagName: string; + tagName: string } interface Edge { - node: Node; + node: Node } interface GetTagsResponse { repository: { releases: { - edges: Edge[]; - }; - }; + edges: Edge[] + } + } } const response = (await octokit.graphql(`{ @@ -43,87 +49,87 @@ const getTags = async (repo: string) => { } } } - }`)) as GetTagsResponse; + }`)) as GetTagsResponse - return response.repository.releases.edges.map((edge) => edge.node.tagName); -}; + return response.repository.releases.edges.map((edge) => edge.node.tagName) +} const filterTags = (tags: string[]) => { - const currentTags = nodesConfig['current-tags'] as string[]; + const currentTags = nodesConfig["current-tags"] as string[] // Test to follow this pattern: v0.8.1 , v0.8.11 , v0.11.12...Etc - const pattern = new RegExp(/^v\d{1,2}\.\d{1,2}\.\d{1,2}$/); + const pattern = /^v\d{1,2}\.\d{1,2}\.\d{1,2}$/ - return tags.filter((tag) => pattern.test(tag) && currentTags.indexOf(tag) === -1); -}; + return tags.filter((tag) => pattern.test(tag) && currentTags.indexOf(tag) === -1) +} const sortTags = (tags: string[]) => { return tags.sort((t1, t2) => { // remove v - const tag1 = t1.slice(1), - tag2 = t2.slice(1); - const version1 = tag1.split('.').map((x) => parseInt(x)); - const version2 = tag2.split('.').map((x) => parseInt(x)); - if (version1.length !== version2.length) throw new Error(`cannot sort tags ${t1},${t2}`); + const tag1 = t1.slice(1) + const tag2 = t2.slice(1) + const version1 = tag1.split(".").map((x) => parseInt(x)) + const version2 = tag2.split(".").map((x) => parseInt(x)) + if (version1.length !== version2.length) throw new Error(`cannot sort tags ${t1},${t2}`) for (let i = 0; i < version1.length; i++) { if (version1[i] < version2[i]) { - return -1; + return -1 } else if (version1[i] > version2[i]) { - return 1; + return 1 } } - return 0; - }); -}; + return 0 + }) +} const updateIndex = async (tags: { tagName: string; path: string }[]) => { - if (tags.length === 0) return; - const path = normalize(`./docs/chainlink-nodes/config/index.md`); - let data = (await readFile(path)).toString(); + if (tags.length === 0) return + const path = normalize(`./docs/chainlink-nodes/config/index.md`) + let data = (await readFile(path)).toString() for (const tag of tags) { - const entry = `- [${tag.tagName}](${tag.path})`; - data = data.replace('**Topics**', `**Topics**\n${entry}`); + const entry = `- [${tag.tagName}](${tag.path})` + data = data.replace("**Topics**", `**Topics**\n${entry}`) } await writeFile( path, format(data, { - parser: 'markdown', + parser: "markdown", semi: true, - trailingComma: 'es5', + trailingComma: "es5", singleQuote: true, printWidth: 120, }), { - flag: 'w', + flag: "w", } - ); -}; + ) +} const updateTags = async (tags: { tagName: string; path: string }[]) => { - if (tags.length === 0) return; + if (tags.length === 0) return for (const tag of tags) { - (nodesConfig['current-tags'] as string[]).push(tag.tagName); + ;(nodesConfig["current-tags"] as string[]).push(tag.tagName) } - const nodesConfigPath = normalize('./_src/reference/nodesConf.json'); + const nodesConfigPath = normalize("./_src/reference/nodesConf.json") await writeFile( nodesConfigPath, format(JSON.stringify(nodesConfig), { - parser: 'json', + parser: "json", semi: true, - trailingComma: 'es5', + trailingComma: "es5", singleQuote: true, printWidth: 120, }), { - flag: 'w', + flag: "w", } - ); -}; + ) +} const writeConfigFile = async (tagName: string) => { - const patternTagInFile = '__TAG__'; + const patternTagInFile = "__TAG__" const fileHeader = ` --- layout: nodes.liquid @@ -132,72 +138,72 @@ date: Last Modified title: "Configuring Chainlink Nodes" permalink: "docs/chainlink-nodes/config/${patternTagInFile}/" --- -`; +` - const tagInPath = tagName.replace(/\./g, '_'); + const tagInPath = tagName.replace(/\./g, "_") const clean = [ { - from: ':warning:', - to: '⚠️', + from: ":warning:", + to: "⚠️", }, - ]; - const path = normalize(`./docs/chainlink-nodes/config/${tagInPath}.md`); + ] + const path = normalize(`./docs/chainlink-nodes/config/${tagInPath}.md`) const url = normalize( `https://raw.githubusercontent.com/${nodesConfig.owner}/${nodesConfig.repo}/${tagName}/${nodesConfig.path}` - ); - const response = await fetch(url); + ) + const response = await fetch(url) if (response.status === 200) { - let data = await (await fetch(url)).text(); + let data = await (await fetch(url)).text() for (const key in clean) { - data = data.replace(new RegExp(clean[key].from, 'g'), clean[key].to); + data = data.replace(new RegExp(clean[key].from, "g"), clean[key].to) } - const content = fileHeader.replace(patternTagInFile, tagInPath) + data; + const content = fileHeader.replace(patternTagInFile, tagInPath) + data await writeFile( path, format(content, { - parser: 'markdown', + parser: "markdown", semi: true, - trailingComma: 'es5', + trailingComma: "es5", singleQuote: true, printWidth: 120, }), { - flag: 'w', + flag: "w", } - ); + ) - return { tagName, path: `/docs/chainlink-nodes/config/${tagInPath}/` }; + return { tagName, path: `/docs/chainlink-nodes/config/${tagInPath}/` } } else if (response.status !== 404) { - throw new Error(`couldn't fetch ${url}. status ${response.status}`); + throw new Error(`couldn't fetch ${url}. status ${response.status}`) } - return { tagName: '', path: '' }; -}; + return { tagName: "", path: "" } +} const writeConfigFiles = async (tags: string[]) => { interface Result { - success: { tagName: string; path: string }[]; + success: { tagName: string; path: string }[] error: { - tag: string; - errorMessage: any; - }[]; + tag: string + errorMessage: unknown + }[] } - const result: Result = { success: [], error: [] }; + const result: Result = { success: [], error: [] } for (const tag of tags) { try { - const successTag = await writeConfigFile(tag); - if (successTag.tagName) result.success.push(successTag); + const successTag = await writeConfigFile(tag) + if (successTag.tagName) result.success.push(successTag) } catch (error) { - result.error.push({ tag, errorMessage: error }); + result.error.push({ tag, errorMessage: error }) } } - return result; -}; -getTags(nodesConfig.repo).then(async (w) => { - const sortedTags = sortTags(filterTags(w)); - const result = await writeConfigFiles(sortedTags); - console.log(`config files generated ${JSON.stringify(result)}`); - await updateIndex(result.success); - await updateTags(result.success); - if (result.error.length > 0) throw new Error(`an error happened ${JSON.stringify(result.error)}`); -}); + return result +} +getTags().then(async (w) => { + const sortedTags = sortTags(filterTags(w)) + const result = await writeConfigFiles(sortedTags) + console.log(`config files generated ${JSON.stringify(result)}`) + await updateIndex(result.success) + await updateTags(result.success) + if (result.error.length > 0) throw new Error(`an error happened ${JSON.stringify(result.error)}`) +}) From 17509a4b237403462cdb3c25db8f4e2013b46742 Mon Sep 17 00:00:00 2001 From: aelmanaa Date: Mon, 31 Jul 2023 17:15:31 +0200 Subject: [PATCH 3/5] nodes config --- package-lock.json | 66 +- package.json | 13 +- src/pages/chainlink-nodes/v1/config/index.mdx | 46 + .../chainlink-nodes/v1/config/v1_10_0.mdx | 5180 +++++++++++++++ .../chainlink-nodes/v1/config/v1_11_0.mdx | 5403 ++++++++++++++++ .../chainlink-nodes/v1/config/v1_12_0.mdx | 5323 +++++++++++++++ .../chainlink-nodes/v1/config/v1_13_0.mdx | 5182 +++++++++++++++ .../chainlink-nodes/v1/config/v1_6_0.mdx | 158 +- .../chainlink-nodes/v1/config/v1_7_0.mdx | 162 +- .../chainlink-nodes/v1/config/v1_7_1.mdx | 162 +- .../chainlink-nodes/v1/config/v1_8_0.mdx | 174 +- .../chainlink-nodes/v1/config/v1_8_1.mdx | 4539 +++++++++++++ .../chainlink-nodes/v1/config/v1_9_0.mdx | 4616 +++++++++++++ src/pages/chainlink-nodes/v2/config/index.mdx | 29 + .../chainlink-nodes/v2/config/v2_0_0.mdx | 5394 ++++++++++++++++ .../chainlink-nodes/v2/config/v2_1_0.mdx | 5440 ++++++++++++++++ .../chainlink-nodes/v2/config/v2_2_0.mdx | 5547 ++++++++++++++++ .../chainlink-nodes/v2/config/v2_3_0.mdx | 5714 +++++++++++++++++ src/scripts/nodes-config/config.json | 21 + src/scripts/nodes-config/nodes-config.ts | 189 +- src/scripts/nodes-config/transformation.ts | 42 + 21 files changed, 52884 insertions(+), 516 deletions(-) create mode 100644 src/pages/chainlink-nodes/v1/config/v1_10_0.mdx create mode 100644 src/pages/chainlink-nodes/v1/config/v1_11_0.mdx create mode 100644 src/pages/chainlink-nodes/v1/config/v1_12_0.mdx create mode 100644 src/pages/chainlink-nodes/v1/config/v1_13_0.mdx create mode 100644 src/pages/chainlink-nodes/v1/config/v1_8_1.mdx create mode 100644 src/pages/chainlink-nodes/v1/config/v1_9_0.mdx create mode 100644 src/pages/chainlink-nodes/v2/config/index.mdx create mode 100644 src/pages/chainlink-nodes/v2/config/v2_0_0.mdx create mode 100644 src/pages/chainlink-nodes/v2/config/v2_1_0.mdx create mode 100644 src/pages/chainlink-nodes/v2/config/v2_2_0.mdx create mode 100644 src/pages/chainlink-nodes/v2/config/v2_3_0.mdx create mode 100644 src/scripts/nodes-config/config.json create mode 100644 src/scripts/nodes-config/transformation.ts diff --git a/package-lock.json b/package-lock.json index 2673e547999..c49366b24f6 100644 --- a/package-lock.json +++ b/package-lock.json @@ -44,6 +44,7 @@ "@project-serum/anchor": "^0.26.0", "@types/lodash": "^4.14.182", "@types/node": "^20.4.5", + "@types/node-fetch": "^2.6.4", "@typescript-eslint/eslint-plugin": "^5.62.0", "@typescript-eslint/parser": "^5.62.0", "astro": "^2.8.1", @@ -5393,6 +5394,30 @@ "integrity": "sha512-rt40Nk13II9JwQBdeYqmbn2Q6IVTA5uPhvSO+JVqdXw/6/4glI6oR9ezty/A9Hg5u7JH4OmYmuQ+XvjKm0Datg==", "devOptional": true }, + "node_modules/@types/node-fetch": { + "version": "2.6.4", + "resolved": "https://registry.npmjs.org/@types/node-fetch/-/node-fetch-2.6.4.tgz", + "integrity": "sha512-1ZX9fcN4Rvkvgv4E6PAY5WXUFWFcRWxZa3EW83UjycOB9ljJCedb2CupIP4RZMEwF/M3eTcCihbBRgwtGbg5Rg==", + "dev": true, + "dependencies": { + "@types/node": "*", + "form-data": "^3.0.0" + } + }, + "node_modules/@types/node-fetch/node_modules/form-data": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz", + "integrity": "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==", + "dev": true, + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, "node_modules/@types/parse5": { "version": "6.0.3", "resolved": "https://registry.npmjs.org/@types/parse5/-/parse5-6.0.3.tgz", @@ -6540,8 +6565,7 @@ "version": "0.4.0", "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", - "dev": true, - "peer": true + "dev": true }, "node_modules/at-least-node": { "version": "1.0.0", @@ -7877,7 +7901,6 @@ "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", "dev": true, - "peer": true, "dependencies": { "delayed-stream": "~1.0.0" }, @@ -8309,7 +8332,6 @@ "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", "dev": true, - "peer": true, "engines": { "node": ">=0.4.0" } @@ -17330,7 +17352,6 @@ "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", "dev": true, - "peer": true, "engines": { "node": ">= 0.6" } @@ -17340,7 +17361,6 @@ "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", "dev": true, - "peer": true, "dependencies": { "mime-db": "1.52.0" }, @@ -27972,6 +27992,29 @@ "integrity": "sha512-rt40Nk13II9JwQBdeYqmbn2Q6IVTA5uPhvSO+JVqdXw/6/4glI6oR9ezty/A9Hg5u7JH4OmYmuQ+XvjKm0Datg==", "devOptional": true }, + "@types/node-fetch": { + "version": "2.6.4", + "resolved": "https://registry.npmjs.org/@types/node-fetch/-/node-fetch-2.6.4.tgz", + "integrity": "sha512-1ZX9fcN4Rvkvgv4E6PAY5WXUFWFcRWxZa3EW83UjycOB9ljJCedb2CupIP4RZMEwF/M3eTcCihbBRgwtGbg5Rg==", + "dev": true, + "requires": { + "@types/node": "*", + "form-data": "^3.0.0" + }, + "dependencies": { + "form-data": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz", + "integrity": "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==", + "dev": true, + "requires": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + } + } + } + }, "@types/parse5": { "version": "6.0.3", "resolved": "https://registry.npmjs.org/@types/parse5/-/parse5-6.0.3.tgz", @@ -28846,8 +28889,7 @@ "version": "0.4.0", "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", - "dev": true, - "peer": true + "dev": true }, "at-least-node": { "version": "1.0.0", @@ -29842,7 +29884,6 @@ "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", "dev": true, - "peer": true, "requires": { "delayed-stream": "~1.0.0" } @@ -30164,8 +30205,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", - "dev": true, - "peer": true + "dev": true }, "delegate": { "version": "3.2.0", @@ -36901,15 +36941,13 @@ "version": "1.52.0", "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", - "dev": true, - "peer": true + "dev": true }, "mime-types": { "version": "2.1.35", "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", "dev": true, - "peer": true, "requires": { "mime-db": "1.52.0" } diff --git a/package.json b/package.json index 0db3df11e27..7dcfe64cceb 100644 --- a/package.json +++ b/package.json @@ -55,9 +55,13 @@ "@chainlink/solana-sdk": "^0.2.2", "@nomicfoundation/hardhat-toolbox": "^2.0.2", "@nomiclabs/hardhat-ethers": "^2.2.3", + "@octokit/auth-token": "^3.0.1", + "@octokit/auth-unauthenticated": "^3.0.2", "@openzeppelin/contracts": "^4.9.2", "@project-serum/anchor": "^0.26.0", + "@types/lodash": "^4.14.182", "@types/node": "^20.4.5", + "@types/node-fetch": "^2.6.4", "@typescript-eslint/eslint-plugin": "^5.62.0", "@typescript-eslint/parser": "^5.62.0", "astro": "^2.8.1", @@ -74,6 +78,7 @@ "husky": "^8.0.3", "lint-staged": "^13.2.3", "lodash": "^4.17.21", + "octokit": "^2.0.7", "prettier": "^2.8.8", "prettier-plugin-astro": "^0.8.1", "prettier-plugin-solidity": "^1.1.3", @@ -84,15 +89,11 @@ "solhint-plugin-prettier": "^0.0.5", "ts-jest": "^29.1.1", "tsconfig-paths": "^4.2.0", - "typescript": "^5.1.6", - "@octokit/auth-token": "^3.0.1", - "@octokit/auth-unauthenticated": "^3.0.2", - "@types/lodash": "^4.14.182", - "octokit": "^2.0.7" + "typescript": "^5.1.6" }, "lint-staged": { "*.{css,md,mdx,yml,yaml,astro}": "prettier --write", - "*.{js,ts,json}": [ + "*.{js,ts}": [ "prettier --write", "eslint" ], diff --git a/src/pages/chainlink-nodes/v1/config/index.mdx b/src/pages/chainlink-nodes/v1/config/index.mdx index e531322c646..844c3aef3f6 100644 --- a/src/pages/chainlink-nodes/v1/config/index.mdx +++ b/src/pages/chainlink-nodes/v1/config/index.mdx @@ -7,6 +7,52 @@ title: "Configuring Chainlink Nodes" **Topics** +- [v1.13.0](/chainlink-nodes/v1/config/v1_13_0) +- [v1.12.0](/chainlink-nodes/v1/config/v1_12_0) +- [v1.11.0](/chainlink-nodes/v1/config/v1_11_0) +- [v1.10.0](/chainlink-nodes/v1/config/v1_10_0) +- [v1.9.0](/chainlink-nodes/v1/config/v1_9_0) +- [v1.8.1](/chainlink-nodes/v1/config/v1_8_1) +- [v1.8.0](/chainlink-nodes/v1/config/v1_8_0) +- [v1.7.1](/chainlink-nodes/v1/config/v1_7_1) +- [v1.7.0](/chainlink-nodes/v1/config/v1_7_0) +- [v1.6.0](/chainlink-nodes/v1/config/v1_6_0) +- [v1.13.0](/chainlink-nodes/v1/config/v1_13_0) +- [v1.12.0](/chainlink-nodes/v1/config/v1_12_0) +- [v1.11.0](/chainlink-nodes/v1/config/v1_11_0) +- [v1.10.0](/chainlink-nodes/v1/config/v1_10_0) +- [v1.9.0](/chainlink-nodes/v1/config/v1_9_0) +- [v1.8.1](/chainlink-nodes/v1/config/v1_8_1) +- [v1.8.0](/chainlink-nodes/v1/config/v1_8_0) +- [v1.7.1](/chainlink-nodes/v1/config/v1_7_1) +- [v1.7.0](/chainlink-nodes/v1/config/v1_7_0) +- [v1.6.0](/chainlink-nodes/v1/config/v1_6_0) +- [v1.13.0](/chainlink-nodes/v1/config/v1_13_0) +- [v1.12.0](/chainlink-nodes/v1/config/v1_12_0) +- [v1.11.0](/chainlink-nodes/v1/config/v1_11_0) +- [v1.10.0](/chainlink-nodes/v1/config/v1_10_0) +- [v1.9.0](/chainlink-nodes/v1/config/v1_9_0) +- [v1.8.1](/chainlink-nodes/v1/config/v1_8_1) +- [v1.8.0](/chainlink-nodes/v1/config/v1_8_0) +- [v1.7.1](/chainlink-nodes/v1/config/v1_7_1) +- [v1.7.0](/chainlink-nodes/v1/config/v1_7_0) +- [v1.6.0](/chainlink-nodes/v1/config/v1_6_0) +- [v1.13.0](/chainlink-nodes/v1/config/v1_13_0) +- [v1.12.0](/chainlink-nodes/v1/config/v1_12_0) +- [v1.11.0](/chainlink-nodes/v1/config/v1_11_0) +- [v1.10.0](/chainlink-nodes/v1/config/v1_10_0) +- [v1.9.0](/chainlink-nodes/v1/config/v1_9_0) +- [v1.8.1](/chainlink-nodes/v1/config/v1_8_1) +- [v1.8.0](/chainlink-nodes/v1/config/v1_8_0) +- [v1.7.1](/chainlink-nodes/v1/config/v1_7_1) +- [v1.7.0](/chainlink-nodes/v1/config/v1_7_0) +- [v1.6.0](/chainlink-nodes/v1/config/v1_6_0) +- [v1.13.0](/chainlink-nodes/v1/config/v1_13_0) +- [v1.12.0](/chainlink-nodes/v1/config/v1_12_0) +- [v1.11.0](/chainlink-nodes/v1/config/v1_11_0) +- [v1.10.0](/chainlink-nodes/v1/config/v1_10_0) +- [v1.9.0](/chainlink-nodes/v1/config/v1_9_0) +- [v1.8.1](/chainlink-nodes/v1/config/v1_8_1) - [v1.8.0](/chainlink-nodes/v1/config/v1_8_0) - [v1.7.1](/chainlink-nodes/v1/config/v1_7_1) - [v1.7.0](/chainlink-nodes/v1/config/v1_7_0) diff --git a/src/pages/chainlink-nodes/v1/config/v1_10_0.mdx b/src/pages/chainlink-nodes/v1/config/v1_10_0.mdx new file mode 100644 index 00000000000..37334518eea --- /dev/null +++ b/src/pages/chainlink-nodes/v1/config/v1_10_0.mdx @@ -0,0 +1,5180 @@ +--- +layout: ../../../../layouts/MainLayout.astro +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +--- + +import { Aside } from "@components" + +This document describes the TOML format for configuration. + +See also [SECRETS.md](secrets.md) + +## Table of contents + +- [Global](#Global) +- [Feature](#Feature) +- [Database](#Database) + - [Backup](#Database-Backup) + - [Listener](#Database-Listener) + - [Lock](#Database-Lock) +- [TelemetryIngress](#TelemetryIngress) +- [AuditLogger](#AuditLogger) +- [Log](#Log) + - [File](#Log-File) +- [WebServer](#WebServer) + - [RateLimit](#WebServer-RateLimit) + - [MFA](#WebServer-MFA) + - [TLS](#WebServer-TLS) +- [JobPipeline](#JobPipeline) + - [HTTPRequest](#JobPipeline-HTTPRequest) +- [FluxMonitor](#FluxMonitor) +- [OCR2](#OCR2) +- [OCR](#OCR) +- [P2P](#P2P) + - [V1](#P2P-V1) + - [V2](#P2P-V2) +- [Keeper](#Keeper) + - [Registry](#Keeper-Registry) +- [AutoPprof](#AutoPprof) +- [Pyroscope](#Pyroscope) +- [Sentry](#Sentry) +- [EVM](#EVM) + - [Transactions](#EVM-Transactions) + - [BalanceMonitor](#EVM-BalanceMonitor) + - [GasEstimator](#EVM-GasEstimator) + - [LimitJobType](#EVM-GasEstimator-LimitJobType) + - [BlockHistory](#EVM-GasEstimator-BlockHistory) + - [HeadTracker](#EVM-HeadTracker) + - [KeySpecific](#EVM-KeySpecific) + - [NodePool](#EVM-NodePool) + - [OCR](#EVM-OCR) + - [Nodes](#EVM-Nodes) + - [Automation](#EVM-OCR2-Automation) +- [Solana](#Solana) + - [Nodes](#Solana-Nodes) +- [Starknet](#Starknet) + - [Nodes](#Starknet-Nodes) +- [Terra](#Terra) + - [Nodes](#Terra-Nodes) + +## Global + +```toml +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL for the node to push stats to. + +### InsecureFastScrypt + + + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = false # Default +LogPoller = false # Default +UICSAKeys = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = false # Default +``` + +FeedsManager enables the experimental feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### UICSAKeys + +```toml +UICSAKeys = false # Default +``` + +UICSAKeys enables CSA Keys in the UI. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +LogQueries = false # Default +MaxIdleConns = 10 # Default +MaxOpenConns = 20 # Default +MigrateOnStartup = true # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for queries to idle in transaction before timing out. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed for a query stuck waiting to take a lock before timing out. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### LogQueries + +```toml +LogQueries = false # Default +``` + +LogQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### MaxIdleConns + +```toml +MaxIdleConns = 10 # Default +``` + +MaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MaxOpenConns + +```toml +MaxOpenConns = 20 # Default +``` + +MaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `$ROOT/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + + + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + + + +```toml +[Database.Lock] +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. + +Because of the complications with advisory locks, Chainlink nodes with v2.0 and later only support `lease` locking mode. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +This setting applies only if `Mode` is set to enable lease locking. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +This setting applies only if Mode is set to enable lease locking. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Example +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Example +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## AuditLogger + +```toml +[AuditLogger] +Enabled = false # Default +ForwardToUrl = 'http://localhost:9898' # Example +JsonWrapperKey = 'event' # Example +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled determines if this logger should be configured at all + +### ForwardToUrl + +```toml +ForwardToUrl = 'http://localhost:9898' # Example +``` + +ForwardToUrl is where you want to forward logs to + +### JsonWrapperKey + +```toml +JsonWrapperKey = 'event' # Example +``` + +JsonWrapperKey if set wraps the map of data under another single key to make parsing easier + +### Headers + +```toml +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +Headers is the set of headers you wish to pass along with each request + +## Log + +```toml +[Log] +Level = 'info' # Default +JSONConsole = false # Default +UnixTS = false # Default +``` + +### Level + +```toml +Level = 'info' # Default +``` + +Level determines both what is printed on the screen and what is written to the log file. + +The available levels are: + +- "debug": Useful for forensic debugging of issues. +- "info": High-level informational messages. (default) +- "warn": A mild error occurred that might require non-urgent action. Check these warnings semi-regularly to see if any of them require attention. These warnings usually happen due to factors outside of the control of the node operator. Examples: Unexpected responses from a remote API or misleading networking errors. +- "error": An unexpected error occurred during the regular operation of a well-maintained node. Node operators might need to take action to remedy this error. Check these regularly to see if any of them require attention. Examples: Use of deprecated configuration options or incorrectly configured settings that cause a job to fail. +- "crit": A critical error occurred. The node might be unable to function. Node operators should take immediate action to fix these errors. Examples: The node could not boot because a network socket could not be opened or the database became inaccessible. +- "panic": An exceptional error occurred that could not be handled. If the node is unresponsive, node operators should try to restart their nodes and notify the Chainlink team of a potential bug. +- "fatal": The node encountered an unrecoverable problem and had to exit. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## Log.File + +```toml +[Log.File] +Dir = '/my/log/directory' # Example +MaxSize = '5120mb' # Default +MaxAgeDays = 0 # Default +MaxBackups = 1 # Default +``` + +### Dir + +```toml +Dir = '/my/log/directory' # Example +``` + +Dir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### MaxSize + +```toml +MaxSize = '5120mb' # Default +``` + +MaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### MaxAgeDays + +```toml +MaxAgeDays = 0 # Default +``` + +MaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### MaxBackups + +```toml +MaxBackups = 1 # Default +``` + +MaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `MaxAgeDays` variable can still cause them to get deleted. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +SessionReaperExpiration = '240h' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + + + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +### SessionReaperExpiration + +```toml +SessionReaperExpiration = '240h' # Default +``` + +SessionReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 1000 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 1000 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '~/.cl/certs' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '~/.cl/certs' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +## JobPipeline + +```toml +[JobPipeline] +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + + + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## JobPipeline.HTTPRequest + +```toml +[JobPipeline.HTTPRequest] +DefaultTimeout = '15s' # Default +MaxSize = '32768' # Default +``` + +### DefaultTimeout + +```toml +DefaultTimeout = '15s' # Default +``` + +DefaultTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### MaxSize + +```toml +MaxSize = '32768' # Default +``` + +MaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +Enabled = false # Default +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR2 jobs. + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +## OCR + +```toml +[OCR] +Enabled = false # Default +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +This section applies only if you are running off-chain reporting jobs. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +Enabled = true # Default +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerstoreWriteInterval = '5m' # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables P2P V1. + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivityBootstrapCheckInterval = '20s' # Default +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively# DefaultBootstrapPeers is the default set of bootstrap peers. +cheap. We set this to 1 minute during our test.DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + + + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + + + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerstoreWriteInterval + + + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +Enabled = false # Default +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables P2P V2. + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in host:port form as accepted by net.Dial. The addresses should be reachable by peers of interest. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaxGracePeriod = 100 # Default +TurnLookBack = 1_000 # Default +TurnFlagEnabled = false # Default +UpkeepCheckGasPriceEnabled = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaxGracePeriod + + + +```toml +MaxGracePeriod = 100 # Default +``` + +MaxGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### TurnLookBack + +```toml +TurnLookBack = 1_000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +### TurnFlagEnabled + +```toml +TurnFlagEnabled = false # Default +``` + +TurnFlagEnabled enables a new algorithm for how keepers take turns. + +### UpkeepCheckGasPriceEnabled + + + +```toml +UpkeepCheckGasPriceEnabled = false # Default +``` + +UpkeepCheckGasPriceEnabled includes gas price in calls to `checkUpkeep()` when set to `true`. + +## Keeper.Registry + +```toml +[Keeper.Registry] +CheckGasOverhead = 200_000 # Default +PerformGasOverhead = 300_000 # Default +SyncInterval = '30m' # Default +MaxPerformDataSize = 5_000 # Default +SyncUpkeepQueueSize = 10 # Default +``` + +### CheckGasOverhead + + + +```toml +CheckGasOverhead = 200_000 # Default +``` + +CheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### PerformGasOverhead + + + +```toml +PerformGasOverhead = 300_000 # Default +``` + +PerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### SyncInterval + + + +```toml +SyncInterval = '30m' # Default +``` + +SyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### MaxPerformDataSize + + + +```toml +MaxPerformDataSize = 5_000 # Default +``` + +MaxPerformDataSize is the max size of perform data. + +### SyncUpkeepQueueSize + + + +```toml +SyncUpkeepQueueSize = 10 # Default +``` + +SyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Pyroscope + +```toml +[Pyroscope] +ServerAddress = 'http://localhost:4040' # Example +Environment = 'mainnet' # Default +``` + +### ServerAddress + +```toml +ServerAddress = 'http://localhost:4040' # Example +``` + +ServerAddress sets the address that will receive the profile logs. It enables the profiling service. + +### Environment + +```toml +Environment = 'mainnet' # Default +``` + +Environment sets the target environment tag in which profiles will be added to. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'my-custom-env' # Example +Release = 'v1.2.3' # Example +``` + +### Debug + + + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'my-custom-env' # Example +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## EVM + +EVM defaults depend on ChainID: + +### Ethereum Mainnet (1) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Ropsten (3) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Rinkeby (4) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Goerli (5) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Mainnet (10) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### RSK Mainnet (30) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### RSK Testnet (31) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Kovan (42) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### BSC Mainnet (56) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Testnet (65) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Mainnet (66) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Kovan (69) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### xDai Mainnet (100) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 100 +LogPollInterval = '5s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Heco Mainnet (128) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mainnet (137) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Mainnet (250) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Goerli (420) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0xdc2CC710e42857672E7907CF474a69B63B93089f' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### Metis Rinkeby (588) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Metis Mainnet (1088) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Simulated (1337) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '100' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '0s' +ResendAfterThreshold = '0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 100 +SamplingInterval = '0s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Testnet (4002) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Alpha (28528) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimismBedrock' +FinalityDepth = 200 +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '1m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '30s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 300 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Mainnet (42161) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Fuji (43113) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Mainnet (43114) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mumbai (80001) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Rinkeby (421611) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Goerli (421613) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xdc2CC710e42857672E7907CF474a69B63B93089f' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Sepolia (11155111) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xb227f007804c16546Bd054dfED2E7A1fD5437678' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Mainnet (1666600000) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Testnet (1666700000) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockBackfillDepth + + + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'Optimism' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + + + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + + + +```toml +LogBackfillBatchSize = 100 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + + + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### LogKeepBlocksDepth + + + +```toml +LogKeepBlocksDepth = 100000 # Default +``` + +LogKeepBlocksDepth works in conjunction with Feature.LogPoller. Controls how many blocks the poller will keep, must be greater than FinalityDepth+1. + +### MinContractPayment + +```toml +MinContractPayment = '10000000000000 juels' # Default +``` + +MinContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before `NodePool` marks rpc endpoints as +out-of-sync, and `HeadTracker` logs warnings. + +Set to zero to disable out-of-sync checking. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 100 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### RPCBlockQueryDelay + + + +```toml +RPCBlockQueryDelay = 1 # Default +``` + +RPCBlockQueryDelay controls the number of blocks to trail behind head in the block history estimator and balance monitor. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +## EVM.Transactions + +```toml +[EVM.Transactions] +ForwardersEnabled = false # Default +MaxInFlight = 16 # Default +MaxQueued = 250 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '168h' # Default +ResendAfterThreshold = '1m' # Default +``` + +### ForwardersEnabled + +```toml +ForwardersEnabled = false # Default +``` + +ForwardersEnabled enables or disables sending transactions through forwarder contracts. + +### MaxInFlight + +```toml +MaxInFlight = 16 # Default +``` + +MaxInFlight controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueued + +```toml +MaxQueued = 250 # Default +``` + +MaxQueued is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the EthTx reaper will run. + +### ReaperThreshold + +```toml +ReaperThreshold = '168h' # Default +``` + +ReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### ResendAfterThreshold + +```toml +ResendAfterThreshold = '1m' # Default +``` + +ResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitMax = 500_000 # Default +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 10 # Default +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMin = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `Optimism2`/`L2Suggested` is a special mode only for use with Optimism and Metis blockchains. This mode will use the gas price suggested by the rpc endpoint via `eth_gasPrice`. +- `Arbitrum` is a special mode only for use with Arbitrum blockchains. It uses the suggested gas price (up to `ETH_MAX_GAS_PRICE_WEI`, with `1000 gwei` default) as well as an estimated gas limit (up to `ETH_GAS_LIMIT_MAX`, with `1,000,000,000` default). + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. +This applies to both legacy and EIP1559 transactions. +Note that it is impossible to disable the maximum limit. Setting this value to zero will prevent paying anything for any transaction (which can be useful in some rare cases). +Most chains by default have the maximum set to 2\*\*256-1 Wei which is the maximum allowed gas price on EVM-compatible chains, and is so large it may as well be unlimited. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitMax + +```toml +LimitMax = 500_000 # Default +``` + +LimitMax sets a maximum for _estimated_ gas limits. This currently only applies to `Arbitrum` `GasEstimatorMode`. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes Optimism L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 10 # Default +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap=current block base fee * (1.125 ^ N)` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMin` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMax` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMin + +```toml +TipCapMin = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.LimitJobType + +```toml +[EVM.GasEstimator.LimitJobType] +OCR = 100_000 # Example +DR = 100_000 # Example +VRF = 100_000 # Example +FM = 100_000 # Example +Keeper = 100_000 # Example +``` + +### OCR + +```toml +OCR = 100_000 # Example +``` + +OCR overrides LimitDefault for OCR jobs. + +### DR + +```toml +DR = 100_000 # Example +``` + +DR overrides LimitDefault for Direct Request jobs. + +### VRF + +```toml +VRF = 100_000 # Example +``` + +VRF overrides LimitDefault for VRF jobs. + +### FM + +```toml +FM = 100_000 # Example +``` + +FM overrides LimitDefault for Flux Monitor jobs. + +### Keeper + +```toml +Keeper = 100_000 # Example +``` + +Keeper overrides LimitDefault for Keeper jobs. + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 4 # Default +BlockHistorySize = 8 # Default +CheckInclusionBlocks = 12 # Default +CheckInclusionPercentile = 90 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 4 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### CheckInclusionBlocks + +```toml +CheckInclusionBlocks = 12 # Default +``` + +CheckInclusionBlocks is the number of recent blocks to use to detect if there is a transaction propagation/connectivity issue, and to prevent bumping in these cases. +This can help avoid the situation where RPC nodes are not propagating transactions for some non-price-related reason (e.g. go-ethereum bug, networking issue etc) and bumping gas would not help. + +Set to zero to disable connectivity checking completely. + +### CheckInclusionPercentile + +```toml +CheckInclusionPercentile = 90 # Default +``` + +CheckInclusionPercentile controls the percentile that a transaction must have been higher than for all the blocks in the inclusion check window in order to register as a connectivity issue. + +For example, if CheckInclusionBlocks=12 and CheckInclusionPercentile=90 then further bumping will be prevented for any transaction with any attempt that has a higher price than the 90th percentile for the most recent 12 blocks. + +### EIP1559FeeCapBufferBlocks + + + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +The head tracker continually listens for new heads from the chain. + +In addition to these settings, it log warnings if `EVM.NoNewHeadsThreshold` is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + + + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMax. + +## EVM.NodePool + +```toml +[EVM.NodePool] +PollFailureThreshold = 5 # Default +PollInterval = '10s' # Default +SelectionMode = 'HighestHead' # Default +``` + +The node pool manages multiple RPC endpoints. + +In addition to these settings, `EVM.NoNewHeadsThreshold` controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 5 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +### SelectionMode + +```toml +SelectionMode = 'HighestHead' # Default +``` + +SelectionMode controls node selection strategy: HighestHead or RoundRobin. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Recommended for primary nodes. Required for `SendOnly`. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +## EVM.OCR2.Automation + +```toml +[EVM.OCR2.Automation] +GasLimit = 5300000 # Default +``` + +### GasLimit + +```toml +GasLimit = 5300000 # Default +``` + +GasLimit controls the gas limit for transmit transactions from ocr2automation job. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1m' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Starknet + +```toml +[[Starknet]] +ChainID = 'foobar' # Example +Enabled = true # Default +OCR2CachePollPeriod = '5s' # Default +OCR2CacheTTL = '1m' # Default +RequestTimeout = '10s' # Default +TxTimeout = '1m' # Default +TxSendFrequency = '5s' # Default +TxMaxBatchSize = 100 # Default +``` + +### ChainID + +```toml +ChainID = 'foobar' # Example +``` + +ChainID is the Starknet chain ID. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '5s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### RequestTimeout + +```toml +RequestTimeout = '10s' # Default +``` + +RequestTimeout is the RPC client timeout. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxSendFrequency + +```toml +TxSendFrequency = '5s' # Default +``` + +TxSendFrequency is how often to broadcast batches of txes. + +### TxMaxBatchSize + +```toml +TxMaxBatchSize = 100 # Default +``` + +TxMaxBatchSize limits the size of tx batches. + +## Starknet.Nodes + +```toml +[[Starknet.Nodes]] +Name = 'primary' # Example +URL = 'http://stark.node' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://stark.node' # Example +``` + +URL is the base HTTP(S) endpoint for this node. + +## Terra + +```toml +[[Terra]] +ChainID = 'Bombay-12' # Example +Enabled = true # Default +BlockRate = '6s' # Default +BlocksUntilTxTimeout = 30 # Default +ConfirmPollPeriod = '1s' # Default +FallbackGasPriceULuna = '0.015' # Default +FCDURL = 'http://terra.com' # Example +GasLimitMultiplier = '1.5' # Default +MaxMsgsPerBatch = 100 # Default +OCR2CachePollPeriod = '4s' # Default +OCR2CacheTTL = '1m' # Default +TxMsgTimeout = '10m' # Default +``` + +### ChainID + +```toml +ChainID = 'Bombay-12' # Example +``` + +ChainID is the Terra chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockRate + +```toml +BlockRate = '6s' # Default +``` + +BlockRate is the average time between blocks. + +### BlocksUntilTxTimeout + +```toml +BlocksUntilTxTimeout = 30 # Default +``` + +BlocksUntilTxTimeout is the number of blocks to wait before giving up on the tx getting confirmed. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '1s' # Default +``` + +ConfirmPollPeriod sets how often check for tx confirmation. + +### FallbackGasPriceULuna + +```toml +FallbackGasPriceULuna = '0.015' # Default +``` + +FallbackGasPriceULuna sets a fallback gas price to use when the estimator is not available. + +### FCDURL + +```toml +FCDURL = 'http://terra.com' # Example +``` + +FCDURL sets the FCD URL. + +### GasLimitMultiplier + +```toml +GasLimitMultiplier = '1.5' # Default +``` + +GasLimitMultiplier scales the estimated gas limit. + +### MaxMsgsPerBatch + +```toml +MaxMsgsPerBatch = 100 # Default +``` + +MaxMsgsPerBatch limits the numbers of mesages per transaction batch. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '4s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxMsgTimeout + +```toml +TxMsgTimeout = '10m' # Default +``` + +TxMsgTimeout is the maximum age for resending transaction before they expire. + +## Terra.Nodes + +```toml +[[Terra.Nodes]] +Name = 'primary' # Example +TendermintURL = 'http://tender.mint' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### TendermintURL + +```toml +TendermintURL = 'http://tender.mint' # Example +``` + +TendermintURL is the HTTP(S) tendermint endpoint for this node. diff --git a/src/pages/chainlink-nodes/v1/config/v1_11_0.mdx b/src/pages/chainlink-nodes/v1/config/v1_11_0.mdx new file mode 100644 index 00000000000..1219ea3db75 --- /dev/null +++ b/src/pages/chainlink-nodes/v1/config/v1_11_0.mdx @@ -0,0 +1,5403 @@ +--- +layout: ../../../../layouts/MainLayout.astro +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +--- + +import { Aside } from "@components" + +This document describes the TOML format for configuration. + +See also [SECRETS.md](SECRETS.md) + +## Example + +```toml +Log.Level = 'debug' + +[[EVM]] +ChainID = '1' # Required + +[[EVM.Nodes]] +Name = 'fake' # Required +WSURL = 'wss://foo.bar/ws' +HTTPURL = 'https://foo.bar' # Required +``` + +## Table of contents + +- [Global](#Global) +- [Feature](#Feature) +- [Database](#Database) + - [Backup](#Database-Backup) + - [Listener](#Database-Listener) + - [Lock](#Database-Lock) +- [TelemetryIngress](#TelemetryIngress) +- [AuditLogger](#AuditLogger) +- [Log](#Log) + - [File](#Log-File) +- [WebServer](#WebServer) + - [RateLimit](#WebServer-RateLimit) + - [MFA](#WebServer-MFA) + - [TLS](#WebServer-TLS) +- [JobPipeline](#JobPipeline) + - [HTTPRequest](#JobPipeline-HTTPRequest) +- [FluxMonitor](#FluxMonitor) +- [OCR2](#OCR2) +- [OCR](#OCR) +- [P2P](#P2P) + - [V1](#P2P-V1) + - [V2](#P2P-V2) +- [Keeper](#Keeper) + - [Registry](#Keeper-Registry) +- [AutoPprof](#AutoPprof) +- [Pyroscope](#Pyroscope) +- [Sentry](#Sentry) +- [EVM](#EVM) + - [Transactions](#EVM-Transactions) + - [BalanceMonitor](#EVM-BalanceMonitor) + - [GasEstimator](#EVM-GasEstimator) + - [LimitJobType](#EVM-GasEstimator-LimitJobType) + - [BlockHistory](#EVM-GasEstimator-BlockHistory) + - [HeadTracker](#EVM-HeadTracker) + - [KeySpecific](#EVM-KeySpecific) + - [NodePool](#EVM-NodePool) + - [OCR](#EVM-OCR) + - [Nodes](#EVM-Nodes) + - [Automation](#EVM-OCR2-Automation) +- [Solana](#Solana) + - [Nodes](#Solana-Nodes) +- [Starknet](#Starknet) + - [Nodes](#Starknet-Nodes) +- [Terra](#Terra) + - [Nodes](#Terra-Nodes) + +## Global + +```toml +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL for the node to push stats to. + +### InsecureFastScrypt + + + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = false # Default +LogPoller = false # Default +UICSAKeys = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = false # Default +``` + +FeedsManager enables the experimental feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### UICSAKeys + +```toml +UICSAKeys = false # Default +``` + +UICSAKeys enables CSA Keys in the UI. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +LogQueries = false # Default +MaxIdleConns = 10 # Default +MaxOpenConns = 20 # Default +MigrateOnStartup = true # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for queries to idle in transaction before timing out. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed for a query stuck waiting to take a lock before timing out. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### LogQueries + +```toml +LogQueries = false # Default +``` + +LogQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### MaxIdleConns + +```toml +MaxIdleConns = 10 # Default +``` + +MaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MaxOpenConns + +```toml +MaxOpenConns = 20 # Default +``` + +MaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `$ROOT/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + + + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + + + +```toml +[Database.Lock] +Enabled = true # Default +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. + +Because of the complications with advisory locks, Chainlink nodes with v2.0 and later only support `lease` locking mode. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables the database lock. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Example +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Example +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## AuditLogger + +```toml +[AuditLogger] +Enabled = false # Default +ForwardToUrl = 'http://localhost:9898' # Example +JsonWrapperKey = 'event' # Example +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled determines if this logger should be configured at all + +### ForwardToUrl + +```toml +ForwardToUrl = 'http://localhost:9898' # Example +``` + +ForwardToUrl is where you want to forward logs to + +### JsonWrapperKey + +```toml +JsonWrapperKey = 'event' # Example +``` + +JsonWrapperKey if set wraps the map of data under another single key to make parsing easier + +### Headers + +```toml +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +Headers is the set of headers you wish to pass along with each request + +## Log + +```toml +[Log] +Level = 'info' # Default +JSONConsole = false # Default +UnixTS = false # Default +``` + +### Level + +```toml +Level = 'info' # Default +``` + +Level determines both what is printed on the screen and what is written to the log file. + +The available levels are: + +- "debug": Useful for forensic debugging of issues. +- "info": High-level informational messages. (default) +- "warn": A mild error occurred that might require non-urgent action. Check these warnings semi-regularly to see if any of them require attention. These warnings usually happen due to factors outside of the control of the node operator. Examples: Unexpected responses from a remote API or misleading networking errors. +- "error": An unexpected error occurred during the regular operation of a well-maintained node. Node operators might need to take action to remedy this error. Check these regularly to see if any of them require attention. Examples: Use of deprecated configuration options or incorrectly configured settings that cause a job to fail. +- "crit": A critical error occurred. The node might be unable to function. Node operators should take immediate action to fix these errors. Examples: The node could not boot because a network socket could not be opened or the database became inaccessible. +- "panic": An exceptional error occurred that could not be handled. If the node is unresponsive, node operators should try to restart their nodes and notify the Chainlink team of a potential bug. +- "fatal": The node encountered an unrecoverable problem and had to exit. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## Log.File + +```toml +[Log.File] +Dir = '/my/log/directory' # Example +MaxSize = '5120mb' # Default +MaxAgeDays = 0 # Default +MaxBackups = 1 # Default +``` + +### Dir + +```toml +Dir = '/my/log/directory' # Example +``` + +Dir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### MaxSize + +```toml +MaxSize = '5120mb' # Default +``` + +MaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### MaxAgeDays + +```toml +MaxAgeDays = 0 # Default +``` + +MaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### MaxBackups + +```toml +MaxBackups = 1 # Default +``` + +MaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `MaxAgeDays` variable can still cause them to get deleted. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeCacheTTL = '0s' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +SessionReaperExpiration = '240h' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeCacheTTL + +```toml +BridgeCacheTTL = '0s' # Default +``` + +BridgeCacheTTL controls the cache TTL for all bridge tasks to use old values in newer observations in case of intermittent failure. It's disabled by default. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + + + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +### SessionReaperExpiration + +```toml +SessionReaperExpiration = '240h' # Default +``` + +SessionReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 1000 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 1000 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '~/.cl/certs' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '~/.cl/certs' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +## JobPipeline + +```toml +[JobPipeline] +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + + + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## JobPipeline.HTTPRequest + +```toml +[JobPipeline.HTTPRequest] +DefaultTimeout = '15s' # Default +MaxSize = '32768' # Default +``` + +### DefaultTimeout + +```toml +DefaultTimeout = '15s' # Default +``` + +DefaultTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### MaxSize + +```toml +MaxSize = '32768' # Default +``` + +MaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +Enabled = false # Default +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR2 jobs. + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +## OCR + +```toml +[OCR] +Enabled = false # Default +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +This section applies only if you are running off-chain reporting jobs. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +Enabled = true # Default +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerstoreWriteInterval = '5m' # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables P2P V1. + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivityBootstrapCheckInterval = '20s' # Default +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively# DefaultBootstrapPeers is the default set of bootstrap peers. +cheap. We set this to 1 minute during our test.DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + + + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + + + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerstoreWriteInterval + + + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +Enabled = false # Default +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables P2P V2. + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in host:port form as accepted by net.Dial. The addresses should be reachable by peers of interest. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaxGracePeriod = 100 # Default +TurnLookBack = 1_000 # Default +TurnFlagEnabled = false # Default +UpkeepCheckGasPriceEnabled = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaxGracePeriod + + + +```toml +MaxGracePeriod = 100 # Default +``` + +MaxGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### TurnLookBack + +```toml +TurnLookBack = 1_000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +### TurnFlagEnabled + +```toml +TurnFlagEnabled = false # Default +``` + +TurnFlagEnabled enables a new algorithm for how keepers take turns. + +### UpkeepCheckGasPriceEnabled + + + +```toml +UpkeepCheckGasPriceEnabled = false # Default +``` + +UpkeepCheckGasPriceEnabled includes gas price in calls to `checkUpkeep()` when set to `true`. + +## Keeper.Registry + +```toml +[Keeper.Registry] +CheckGasOverhead = 200_000 # Default +PerformGasOverhead = 300_000 # Default +SyncInterval = '30m' # Default +MaxPerformDataSize = 5_000 # Default +SyncUpkeepQueueSize = 10 # Default +``` + +### CheckGasOverhead + + + +```toml +CheckGasOverhead = 200_000 # Default +``` + +CheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### PerformGasOverhead + + + +```toml +PerformGasOverhead = 300_000 # Default +``` + +PerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### SyncInterval + + + +```toml +SyncInterval = '30m' # Default +``` + +SyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### MaxPerformDataSize + + + +```toml +MaxPerformDataSize = 5_000 # Default +``` + +MaxPerformDataSize is the max size of perform data. + +### SyncUpkeepQueueSize + + + +```toml +SyncUpkeepQueueSize = 10 # Default +``` + +SyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Pyroscope + +```toml +[Pyroscope] +ServerAddress = 'http://localhost:4040' # Example +Environment = 'mainnet' # Default +``` + +### ServerAddress + +```toml +ServerAddress = 'http://localhost:4040' # Example +``` + +ServerAddress sets the address that will receive the profile logs. It enables the profiling service. + +### Environment + +```toml +Environment = 'mainnet' # Default +``` + +Environment sets the target environment tag in which profiles will be added to. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'my-custom-env' # Example +Release = 'v1.2.3' # Example +``` + +### Debug + + + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'my-custom-env' # Example +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## EVM + +EVM defaults depend on ChainID: + +### Ethereum Mainnet (1) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Ropsten (3) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Rinkeby (4) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Goerli (5) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Mainnet (10) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### RSK Mainnet (30) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### RSK Testnet (31) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Kovan (42) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### BSC Mainnet (56) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Testnet (65) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Mainnet (66) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Kovan (69) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### xDai Mainnet (100) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 100 +LogPollInterval = '5s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Heco Mainnet (128) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mainnet (137) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Mainnet (250) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Goerli (420) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0xdc2CC710e42857672E7907CF474a69B63B93089f' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### Metis Rinkeby (588) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Klaytn Testnet (1001) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Metis Mainnet (1088) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Simulated (1337) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '100' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '0s' +ResendAfterThreshold = '0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 100 +SamplingInterval = '0s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Testnet (4002) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Klaytn Mainnet (8217) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Alpha (28528) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimismBedrock' +FinalityDepth = 200 +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '1m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '30s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 300 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Mainnet (42161) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Fuji (43113) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Mainnet (43114) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mumbai (80001) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Rinkeby (421611) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Goerli (421613) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xdc2CC710e42857672E7907CF474a69B63B93089f' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Sepolia (11155111) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xb227f007804c16546Bd054dfED2E7A1fD5437678' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Mainnet (1666600000) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Testnet (1666700000) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockBackfillDepth + + + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'Optimism' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + + + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + + + +```toml +LogBackfillBatchSize = 100 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + + + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### LogKeepBlocksDepth + + + +```toml +LogKeepBlocksDepth = 100000 # Default +``` + +LogKeepBlocksDepth works in conjunction with Feature.LogPoller. Controls how many blocks the poller will keep, must be greater than FinalityDepth+1. + +### MinContractPayment + +```toml +MinContractPayment = '10000000000000 juels' # Default +``` + +MinContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before `NodePool` marks rpc endpoints as +out-of-sync, and `HeadTracker` logs warnings. + +Set to zero to disable out-of-sync checking. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 100 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### RPCBlockQueryDelay + + + +```toml +RPCBlockQueryDelay = 1 # Default +``` + +RPCBlockQueryDelay controls the number of blocks to trail behind head in the block history estimator and balance monitor. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +## EVM.Transactions + +```toml +[EVM.Transactions] +ForwardersEnabled = false # Default +MaxInFlight = 16 # Default +MaxQueued = 250 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '168h' # Default +ResendAfterThreshold = '1m' # Default +``` + +### ForwardersEnabled + +```toml +ForwardersEnabled = false # Default +``` + +ForwardersEnabled enables or disables sending transactions through forwarder contracts. + +### MaxInFlight + +```toml +MaxInFlight = 16 # Default +``` + +MaxInFlight controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueued + +```toml +MaxQueued = 250 # Default +``` + +MaxQueued is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the EthTx reaper will run. + +### ReaperThreshold + +```toml +ReaperThreshold = '168h' # Default +``` + +ReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### ResendAfterThreshold + +```toml +ResendAfterThreshold = '1m' # Default +``` + +ResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitMax = 500_000 # Default +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 10 # Default +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMin = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `Optimism2`/`L2Suggested` is a special mode only for use with Optimism and Metis blockchains. This mode will use the gas price suggested by the rpc endpoint via `eth_gasPrice`. +- `Arbitrum` is a special mode only for use with Arbitrum blockchains. It uses the suggested gas price (up to `ETH_MAX_GAS_PRICE_WEI`, with `1000 gwei` default) as well as an estimated gas limit (up to `ETH_GAS_LIMIT_MAX`, with `1,000,000,000` default). + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. +This applies to both legacy and EIP1559 transactions. +Note that it is impossible to disable the maximum limit. Setting this value to zero will prevent paying anything for any transaction (which can be useful in some rare cases). +Most chains by default have the maximum set to 2\*\*256-1 Wei which is the maximum allowed gas price on EVM-compatible chains, and is so large it may as well be unlimited. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitMax + +```toml +LimitMax = 500_000 # Default +``` + +LimitMax sets a maximum for _estimated_ gas limits. This currently only applies to `Arbitrum` `GasEstimatorMode`. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes Optimism L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 10 # Default +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap=current block base fee * (1.125 ^ N)` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMin` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMax` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMin + +```toml +TipCapMin = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.LimitJobType + +```toml +[EVM.GasEstimator.LimitJobType] +OCR = 100_000 # Example +DR = 100_000 # Example +VRF = 100_000 # Example +FM = 100_000 # Example +Keeper = 100_000 # Example +``` + +### OCR + +```toml +OCR = 100_000 # Example +``` + +OCR overrides LimitDefault for OCR jobs. + +### DR + +```toml +DR = 100_000 # Example +``` + +DR overrides LimitDefault for Direct Request jobs. + +### VRF + +```toml +VRF = 100_000 # Example +``` + +VRF overrides LimitDefault for VRF jobs. + +### FM + +```toml +FM = 100_000 # Example +``` + +FM overrides LimitDefault for Flux Monitor jobs. + +### Keeper + +```toml +Keeper = 100_000 # Example +``` + +Keeper overrides LimitDefault for Keeper jobs. + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 4 # Default +BlockHistorySize = 8 # Default +CheckInclusionBlocks = 12 # Default +CheckInclusionPercentile = 90 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 4 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### CheckInclusionBlocks + +```toml +CheckInclusionBlocks = 12 # Default +``` + +CheckInclusionBlocks is the number of recent blocks to use to detect if there is a transaction propagation/connectivity issue, and to prevent bumping in these cases. +This can help avoid the situation where RPC nodes are not propagating transactions for some non-price-related reason (e.g. go-ethereum bug, networking issue etc) and bumping gas would not help. + +Set to zero to disable connectivity checking completely. + +### CheckInclusionPercentile + +```toml +CheckInclusionPercentile = 90 # Default +``` + +CheckInclusionPercentile controls the percentile that a transaction must have been higher than for all the blocks in the inclusion check window in order to register as a connectivity issue. + +For example, if CheckInclusionBlocks=12 and CheckInclusionPercentile=90 then further bumping will be prevented for any transaction with any attempt that has a higher price than the 90th percentile for the most recent 12 blocks. + +### EIP1559FeeCapBufferBlocks + + + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +The head tracker continually listens for new heads from the chain. + +In addition to these settings, it log warnings if `EVM.NoNewHeadsThreshold` is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + + + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMax. + +## EVM.NodePool + +```toml +[EVM.NodePool] +PollFailureThreshold = 5 # Default +PollInterval = '10s' # Default +SelectionMode = 'HighestHead' # Default +SyncThreshold = 5 # Default +``` + +The node pool manages multiple RPC endpoints. + +In addition to these settings, `EVM.NoNewHeadsThreshold` controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 5 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +### SelectionMode + +```toml +SelectionMode = 'HighestHead' # Default +``` + +SelectionMode controls node selection strategy: + +- HighestHead: use the node with the highest head number +- RoundRobin: rotate through nodes, per-request +- TotalDifficulty: use the node with the greatest total difficulty + +### SyncThreshold + +```toml +SyncThreshold = 5 # Default +``` + +SyncThreshold controls how far a node may lag behind the best node before being marked out-of-sync. +Depending on `SelectionMode`, this represents a difference in the number of blocks (`HighestHead`, `RoundRobin`), or total difficulty (`TotalDifficulty`). + +Set to 0 to disable this check. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Recommended for primary nodes. Required for `SendOnly`. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +## EVM.OCR2.Automation + +```toml +[EVM.OCR2.Automation] +GasLimit = 5300000 # Default +``` + +### GasLimit + +```toml +GasLimit = 5300000 # Default +``` + +GasLimit controls the gas limit for transmit transactions from ocr2automation job. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1m' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Starknet + +```toml +[[Starknet]] +ChainID = 'foobar' # Example +Enabled = true # Default +OCR2CachePollPeriod = '5s' # Default +OCR2CacheTTL = '1m' # Default +RequestTimeout = '10s' # Default +TxTimeout = '1m' # Default +TxSendFrequency = '5s' # Default +TxMaxBatchSize = 100 # Default +``` + +### ChainID + +```toml +ChainID = 'foobar' # Example +``` + +ChainID is the Starknet chain ID. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '5s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### RequestTimeout + +```toml +RequestTimeout = '10s' # Default +``` + +RequestTimeout is the RPC client timeout. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxSendFrequency + +```toml +TxSendFrequency = '5s' # Default +``` + +TxSendFrequency is how often to broadcast batches of txes. + +### TxMaxBatchSize + +```toml +TxMaxBatchSize = 100 # Default +``` + +TxMaxBatchSize limits the size of tx batches. + +## Starknet.Nodes + +```toml +[[Starknet.Nodes]] +Name = 'primary' # Example +URL = 'http://stark.node' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://stark.node' # Example +``` + +URL is the base HTTP(S) endpoint for this node. + +## Terra + +```toml +[[Terra]] +ChainID = 'Bombay-12' # Example +Enabled = true # Default +BlockRate = '6s' # Default +BlocksUntilTxTimeout = 30 # Default +ConfirmPollPeriod = '1s' # Default +FallbackGasPriceULuna = '0.015' # Default +FCDURL = 'http://terra.com' # Example +GasLimitMultiplier = '1.5' # Default +MaxMsgsPerBatch = 100 # Default +OCR2CachePollPeriod = '4s' # Default +OCR2CacheTTL = '1m' # Default +TxMsgTimeout = '10m' # Default +``` + +### ChainID + +```toml +ChainID = 'Bombay-12' # Example +``` + +ChainID is the Terra chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockRate + +```toml +BlockRate = '6s' # Default +``` + +BlockRate is the average time between blocks. + +### BlocksUntilTxTimeout + +```toml +BlocksUntilTxTimeout = 30 # Default +``` + +BlocksUntilTxTimeout is the number of blocks to wait before giving up on the tx getting confirmed. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '1s' # Default +``` + +ConfirmPollPeriod sets how often check for tx confirmation. + +### FallbackGasPriceULuna + +```toml +FallbackGasPriceULuna = '0.015' # Default +``` + +FallbackGasPriceULuna sets a fallback gas price to use when the estimator is not available. + +### FCDURL + +```toml +FCDURL = 'http://terra.com' # Example +``` + +FCDURL sets the FCD URL. + +### GasLimitMultiplier + +```toml +GasLimitMultiplier = '1.5' # Default +``` + +GasLimitMultiplier scales the estimated gas limit. + +### MaxMsgsPerBatch + +```toml +MaxMsgsPerBatch = 100 # Default +``` + +MaxMsgsPerBatch limits the numbers of mesages per transaction batch. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '4s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxMsgTimeout + +```toml +TxMsgTimeout = '10m' # Default +``` + +TxMsgTimeout is the maximum age for resending transaction before they expire. + +## Terra.Nodes + +```toml +[[Terra.Nodes]] +Name = 'primary' # Example +TendermintURL = 'http://tender.mint' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### TendermintURL + +```toml +TendermintURL = 'http://tender.mint' # Example +``` + +TendermintURL is the HTTP(S) tendermint endpoint for this node. diff --git a/src/pages/chainlink-nodes/v1/config/v1_12_0.mdx b/src/pages/chainlink-nodes/v1/config/v1_12_0.mdx new file mode 100644 index 00000000000..40319d29000 --- /dev/null +++ b/src/pages/chainlink-nodes/v1/config/v1_12_0.mdx @@ -0,0 +1,5323 @@ +--- +layout: ../../../../layouts/MainLayout.astro +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +--- + +import { Aside } from "@components" + +This document describes the TOML format for configuration. + +See also [SECRETS.md](SECRETS.md) + +## Example + +```toml +Log.Level = 'debug' + +[[EVM]] +ChainID = '1' # Required + +[[EVM.Nodes]] +Name = 'fake' # Required +WSURL = 'wss://foo.bar/ws' +HTTPURL = 'https://foo.bar' # Required +``` + +## Table of contents + +- [Global](#Global) +- [Feature](#Feature) +- [Database](#Database) + - [Backup](#Database-Backup) + - [Listener](#Database-Listener) + - [Lock](#Database-Lock) +- [TelemetryIngress](#TelemetryIngress) +- [AuditLogger](#AuditLogger) +- [Log](#Log) + - [File](#Log-File) +- [WebServer](#WebServer) + - [RateLimit](#WebServer-RateLimit) + - [MFA](#WebServer-MFA) + - [TLS](#WebServer-TLS) +- [JobPipeline](#JobPipeline) + - [HTTPRequest](#JobPipeline-HTTPRequest) +- [FluxMonitor](#FluxMonitor) +- [OCR2](#OCR2) +- [OCR](#OCR) +- [P2P](#P2P) + - [V1](#P2P-V1) + - [V2](#P2P-V2) +- [Keeper](#Keeper) + - [Registry](#Keeper-Registry) +- [AutoPprof](#AutoPprof) +- [Pyroscope](#Pyroscope) +- [Sentry](#Sentry) +- [EVM](#EVM) + - [Transactions](#EVM-Transactions) + - [BalanceMonitor](#EVM-BalanceMonitor) + - [GasEstimator](#EVM-GasEstimator) + - [LimitJobType](#EVM-GasEstimator-LimitJobType) + - [BlockHistory](#EVM-GasEstimator-BlockHistory) + - [HeadTracker](#EVM-HeadTracker) + - [KeySpecific](#EVM-KeySpecific) + - [NodePool](#EVM-NodePool) + - [OCR](#EVM-OCR) + - [Nodes](#EVM-Nodes) + - [Automation](#EVM-OCR2-Automation) +- [Solana](#Solana) + - [Nodes](#Solana-Nodes) +- [Starknet](#Starknet) + - [Nodes](#Starknet-Nodes) +- [Terra](#Terra) + - [Nodes](#Terra-Nodes) + +## Global + +```toml +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL for the node to push stats to. + +### InsecureFastScrypt + + + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = false # Default +LogPoller = false # Default +UICSAKeys = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = false # Default +``` + +FeedsManager enables the experimental feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### UICSAKeys + +```toml +UICSAKeys = false # Default +``` + +UICSAKeys enables CSA Keys in the UI. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +LogQueries = false # Default +MaxIdleConns = 10 # Default +MaxOpenConns = 20 # Default +MigrateOnStartup = true # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for queries to idle in transaction before timing out. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed for a query stuck waiting to take a lock before timing out. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### LogQueries + +```toml +LogQueries = false # Default +``` + +LogQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### MaxIdleConns + +```toml +MaxIdleConns = 10 # Default +``` + +MaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MaxOpenConns + +```toml +MaxOpenConns = 20 # Default +``` + +MaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `$ROOT/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + + + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + + + +```toml +[Database.Lock] +Enabled = true # Default +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. + +Because of the complications with advisory locks, Chainlink nodes with v2.0 and later only support `lease` locking mode. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables the database lock. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Example +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Example +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## AuditLogger + +```toml +[AuditLogger] +Enabled = false # Default +ForwardToUrl = 'http://localhost:9898' # Example +JsonWrapperKey = 'event' # Example +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled determines if this logger should be configured at all + +### ForwardToUrl + +```toml +ForwardToUrl = 'http://localhost:9898' # Example +``` + +ForwardToUrl is where you want to forward logs to + +### JsonWrapperKey + +```toml +JsonWrapperKey = 'event' # Example +``` + +JsonWrapperKey if set wraps the map of data under another single key to make parsing easier + +### Headers + +```toml +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +Headers is the set of headers you wish to pass along with each request + +## Log + +```toml +[Log] +Level = 'info' # Default +JSONConsole = false # Default +UnixTS = false # Default +``` + +### Level + +```toml +Level = 'info' # Default +``` + +Level determines both what is printed on the screen and what is written to the log file. + +The available levels are: + +- "debug": Useful for forensic debugging of issues. +- "info": High-level informational messages. (default) +- "warn": A mild error occurred that might require non-urgent action. Check these warnings semi-regularly to see if any of them require attention. These warnings usually happen due to factors outside of the control of the node operator. Examples: Unexpected responses from a remote API or misleading networking errors. +- "error": An unexpected error occurred during the regular operation of a well-maintained node. Node operators might need to take action to remedy this error. Check these regularly to see if any of them require attention. Examples: Use of deprecated configuration options or incorrectly configured settings that cause a job to fail. +- "crit": A critical error occurred. The node might be unable to function. Node operators should take immediate action to fix these errors. Examples: The node could not boot because a network socket could not be opened or the database became inaccessible. +- "panic": An exceptional error occurred that could not be handled. If the node is unresponsive, node operators should try to restart their nodes and notify the Chainlink team of a potential bug. +- "fatal": The node encountered an unrecoverable problem and had to exit. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## Log.File + +```toml +[Log.File] +Dir = '/my/log/directory' # Example +MaxSize = '5120mb' # Default +MaxAgeDays = 0 # Default +MaxBackups = 1 # Default +``` + +### Dir + +```toml +Dir = '/my/log/directory' # Example +``` + +Dir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### MaxSize + +```toml +MaxSize = '5120mb' # Default +``` + +MaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### MaxAgeDays + +```toml +MaxAgeDays = 0 # Default +``` + +MaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### MaxBackups + +```toml +MaxBackups = 1 # Default +``` + +MaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `MaxAgeDays` variable can still cause them to get deleted. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeCacheTTL = '0s' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +SessionReaperExpiration = '240h' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeCacheTTL + +```toml +BridgeCacheTTL = '0s' # Default +``` + +BridgeCacheTTL controls the cache TTL for all bridge tasks to use old values in newer observations in case of intermittent failure. It's disabled by default. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + + + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +### SessionReaperExpiration + +```toml +SessionReaperExpiration = '240h' # Default +``` + +SessionReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 1000 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 1000 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '~/.cl/certs' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '~/.cl/certs' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +## JobPipeline + +```toml +[JobPipeline] +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +MaxSuccessfulRuns = 10000 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### MaxSuccessfulRuns + +```toml +MaxSuccessfulRuns = 10000 # Default +``` + +MaxSuccessfulRuns caps the number of completed successful runs per pipeline +spec in the database. You can set it to zero as a performance optimisation; +this will avoid saving any successful run. + +Note this is not a hard cap, it can drift slightly larger than this but not +by more than 5% or so. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + + + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## JobPipeline.HTTPRequest + +```toml +[JobPipeline.HTTPRequest] +DefaultTimeout = '15s' # Default +MaxSize = '32768' # Default +``` + +### DefaultTimeout + +```toml +DefaultTimeout = '15s' # Default +``` + +DefaultTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### MaxSize + +```toml +MaxSize = '32768' # Default +``` + +MaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +Enabled = false # Default +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR2 jobs. + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +## OCR + +```toml +[OCR] +Enabled = false # Default +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +This section applies only if you are running off-chain reporting jobs. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +Enabled = true # Default +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerstoreWriteInterval = '5m' # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables P2P V1. + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivity +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively +cheap. We set this to 1 minute during our test. + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + + + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + + + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerstoreWriteInterval + + + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +Enabled = false # Default +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables P2P V2. +Note: V1.Enabled is true by default, so it must be set false in order to run V2 only. + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in host:port form as accepted by net.Dial. The addresses should be reachable by peers of interest. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaxGracePeriod = 100 # Default +TurnLookBack = 1_000 # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaxGracePeriod + + + +```toml +MaxGracePeriod = 100 # Default +``` + +MaxGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### TurnLookBack + +```toml +TurnLookBack = 1_000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +## Keeper.Registry + +```toml +[Keeper.Registry] +CheckGasOverhead = 200_000 # Default +PerformGasOverhead = 300_000 # Default +SyncInterval = '30m' # Default +MaxPerformDataSize = 5_000 # Default +SyncUpkeepQueueSize = 10 # Default +``` + +### CheckGasOverhead + + + +```toml +CheckGasOverhead = 200_000 # Default +``` + +CheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### PerformGasOverhead + + + +```toml +PerformGasOverhead = 300_000 # Default +``` + +PerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### SyncInterval + + + +```toml +SyncInterval = '30m' # Default +``` + +SyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### MaxPerformDataSize + + + +```toml +MaxPerformDataSize = 5_000 # Default +``` + +MaxPerformDataSize is the max size of perform data. + +### SyncUpkeepQueueSize + + + +```toml +SyncUpkeepQueueSize = 10 # Default +``` + +SyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Pyroscope + +```toml +[Pyroscope] +ServerAddress = 'http://localhost:4040' # Example +Environment = 'mainnet' # Default +``` + +### ServerAddress + +```toml +ServerAddress = 'http://localhost:4040' # Example +``` + +ServerAddress sets the address that will receive the profile logs. It enables the profiling service. + +### Environment + +```toml +Environment = 'mainnet' # Default +``` + +Environment sets the target environment tag in which profiles will be added to. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'my-custom-env' # Example +Release = 'v1.2.3' # Example +``` + +### Debug + + + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'my-custom-env' # Example +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## EVM + +EVM defaults depend on ChainID: + +### Ethereum Mainnet (1) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Ropsten (3) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Rinkeby (4) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Goerli (5) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Mainnet (10) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### RSK Mainnet (30) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### RSK Testnet (31) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Kovan (42) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### BSC Mainnet (56) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Testnet (65) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Mainnet (66) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Kovan (69) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### xDai Mainnet (100) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 100 +LogPollInterval = '5s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Heco Mainnet (128) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mainnet (137) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Mainnet (250) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 3800000 +``` + +### Optimism Goerli (420) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimismBedrock' +FinalityDepth = 200 +LinkContractAddress = '0xdc2CC710e42857672E7907CF474a69B63B93089f' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '1m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '30s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 wei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 300 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### Metis Rinkeby (588) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Klaytn Testnet (1001) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Metis Mainnet (1088) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Simulated (1337) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '100' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '0s' +ResendAfterThreshold = '0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 100 +SamplingInterval = '0s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Testnet (4002) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 3800000 +``` + +### Klaytn Mainnet (8217) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Mainnet (42161) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Fuji (43113) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Mainnet (43114) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mumbai (80001) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Rinkeby (421611) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Goerli (421613) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xd14838A68E8AFBAdE5efb411d5871ea0011AFd28' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Sepolia (11155111) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xb227f007804c16546Bd054dfED2E7A1fD5437678' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Mainnet (1666600000) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Testnet (1666700000) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockBackfillDepth + + + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'Optimism' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + + + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + + + +```toml +LogBackfillBatchSize = 100 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + + + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### LogKeepBlocksDepth + + + +```toml +LogKeepBlocksDepth = 100000 # Default +``` + +LogKeepBlocksDepth works in conjunction with Feature.LogPoller. Controls how many blocks the poller will keep, must be greater than FinalityDepth+1. + +### MinContractPayment + +```toml +MinContractPayment = '10000000000000 juels' # Default +``` + +MinContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before `NodePool` marks rpc endpoints as +out-of-sync, and `HeadTracker` logs warnings. + +Set to zero to disable out-of-sync checking. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 100 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### RPCBlockQueryDelay + + + +```toml +RPCBlockQueryDelay = 1 # Default +``` + +RPCBlockQueryDelay controls the number of blocks to trail behind head in the block history estimator and balance monitor. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +## EVM.Transactions + +```toml +[EVM.Transactions] +ForwardersEnabled = false # Default +MaxInFlight = 16 # Default +MaxQueued = 250 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '168h' # Default +ResendAfterThreshold = '1m' # Default +``` + +### ForwardersEnabled + +```toml +ForwardersEnabled = false # Default +``` + +ForwardersEnabled enables or disables sending transactions through forwarder contracts. + +### MaxInFlight + +```toml +MaxInFlight = 16 # Default +``` + +MaxInFlight controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueued + +```toml +MaxQueued = 250 # Default +``` + +MaxQueued is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the EthTx reaper will run. + +### ReaperThreshold + +```toml +ReaperThreshold = '168h' # Default +``` + +ReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### ResendAfterThreshold + +```toml +ResendAfterThreshold = '1m' # Default +``` + +ResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitMax = 500_000 # Default +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 10 # Default +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMin = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `Optimism2`/`L2Suggested` is a special mode only for use with Optimism and Metis blockchains. This mode will use the gas price suggested by the rpc endpoint via `eth_gasPrice`. +- `Arbitrum` is a special mode only for use with Arbitrum blockchains. It uses the suggested gas price (up to `ETH_MAX_GAS_PRICE_WEI`, with `1000 gwei` default) as well as an estimated gas limit (up to `ETH_GAS_LIMIT_MAX`, with `1,000,000,000` default). + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. +This applies to both legacy and EIP1559 transactions. +Note that it is impossible to disable the maximum limit. Setting this value to zero will prevent paying anything for any transaction (which can be useful in some rare cases). +Most chains by default have the maximum set to 2\*\*256-1 Wei which is the maximum allowed gas price on EVM-compatible chains, and is so large it may as well be unlimited. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitMax + +```toml +LimitMax = 500_000 # Default +``` + +LimitMax sets a maximum for _estimated_ gas limits. This currently only applies to `Arbitrum` `GasEstimatorMode`. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes Optimism L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 10 # Default +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap = ( current block base fee * (1.125 ^ N) + tipcap )` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMin` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMax` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMin + +```toml +TipCapMin = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.LimitJobType + +```toml +[EVM.GasEstimator.LimitJobType] +OCR = 100_000 # Example +DR = 100_000 # Example +VRF = 100_000 # Example +FM = 100_000 # Example +Keeper = 100_000 # Example +``` + +### OCR + +```toml +OCR = 100_000 # Example +``` + +OCR overrides LimitDefault for OCR jobs. + +### DR + +```toml +DR = 100_000 # Example +``` + +DR overrides LimitDefault for Direct Request jobs. + +### VRF + +```toml +VRF = 100_000 # Example +``` + +VRF overrides LimitDefault for VRF jobs. + +### FM + +```toml +FM = 100_000 # Example +``` + +FM overrides LimitDefault for Flux Monitor jobs. + +### Keeper + +```toml +Keeper = 100_000 # Example +``` + +Keeper overrides LimitDefault for Keeper jobs. + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 4 # Default +BlockHistorySize = 8 # Default +CheckInclusionBlocks = 12 # Default +CheckInclusionPercentile = 90 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 4 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### CheckInclusionBlocks + +```toml +CheckInclusionBlocks = 12 # Default +``` + +CheckInclusionBlocks is the number of recent blocks to use to detect if there is a transaction propagation/connectivity issue, and to prevent bumping in these cases. +This can help avoid the situation where RPC nodes are not propagating transactions for some non-price-related reason (e.g. go-ethereum bug, networking issue etc) and bumping gas would not help. + +Set to zero to disable connectivity checking completely. + +### CheckInclusionPercentile + +```toml +CheckInclusionPercentile = 90 # Default +``` + +CheckInclusionPercentile controls the percentile that a transaction must have been higher than for all the blocks in the inclusion check window in order to register as a connectivity issue. + +For example, if CheckInclusionBlocks=12 and CheckInclusionPercentile=90 then further bumping will be prevented for any transaction with any attempt that has a higher price than the 90th percentile for the most recent 12 blocks. + +### EIP1559FeeCapBufferBlocks + + + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +The head tracker continually listens for new heads from the chain. + +In addition to these settings, it log warnings if `EVM.NoNewHeadsThreshold` is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + + + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMax. + +## EVM.NodePool + +```toml +[EVM.NodePool] +PollFailureThreshold = 5 # Default +PollInterval = '10s' # Default +SelectionMode = 'HighestHead' # Default +SyncThreshold = 5 # Default +``` + +The node pool manages multiple RPC endpoints. + +In addition to these settings, `EVM.NoNewHeadsThreshold` controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 5 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +### SelectionMode + +```toml +SelectionMode = 'HighestHead' # Default +``` + +SelectionMode controls node selection strategy: + +- HighestHead: use the node with the highest head number +- RoundRobin: rotate through nodes, per-request +- TotalDifficulty: use the node with the greatest total difficulty + +### SyncThreshold + +```toml +SyncThreshold = 5 # Default +``` + +SyncThreshold controls how far a node may lag behind the best node before being marked out-of-sync. +Depending on `SelectionMode`, this represents a difference in the number of blocks (`HighestHead`, `RoundRobin`), or total difficulty (`TotalDifficulty`). + +Set to 0 to disable this check. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Required for all nodes. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +## EVM.OCR2.Automation + +```toml +[EVM.OCR2.Automation] +GasLimit = 5300000 # Default +``` + +### GasLimit + +```toml +GasLimit = 5300000 # Default +``` + +GasLimit controls the gas limit for transmit transactions from ocr2automation job. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1m' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Starknet + +```toml +[[Starknet]] +ChainID = 'foobar' # Example +Enabled = true # Default +OCR2CachePollPeriod = '5s' # Default +OCR2CacheTTL = '1m' # Default +RequestTimeout = '10s' # Default +TxTimeout = '1m' # Default +TxSendFrequency = '5s' # Default +TxMaxBatchSize = 100 # Default +``` + +### ChainID + +```toml +ChainID = 'foobar' # Example +``` + +ChainID is the Starknet chain ID. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '5s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### RequestTimeout + +```toml +RequestTimeout = '10s' # Default +``` + +RequestTimeout is the RPC client timeout. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxSendFrequency + +```toml +TxSendFrequency = '5s' # Default +``` + +TxSendFrequency is how often to broadcast batches of txes. + +### TxMaxBatchSize + +```toml +TxMaxBatchSize = 100 # Default +``` + +TxMaxBatchSize limits the size of tx batches. + +## Starknet.Nodes + +```toml +[[Starknet.Nodes]] +Name = 'primary' # Example +URL = 'http://stark.node' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://stark.node' # Example +``` + +URL is the base HTTP(S) endpoint for this node. + +## Terra + +```toml +[[Terra]] +ChainID = 'Bombay-12' # Example +Enabled = true # Default +BlockRate = '6s' # Default +BlocksUntilTxTimeout = 30 # Default +ConfirmPollPeriod = '1s' # Default +FallbackGasPriceULuna = '0.015' # Default +FCDURL = 'http://terra.com' # Example +GasLimitMultiplier = '1.5' # Default +MaxMsgsPerBatch = 100 # Default +OCR2CachePollPeriod = '4s' # Default +OCR2CacheTTL = '1m' # Default +TxMsgTimeout = '10m' # Default +``` + +### ChainID + +```toml +ChainID = 'Bombay-12' # Example +``` + +ChainID is the Terra chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockRate + +```toml +BlockRate = '6s' # Default +``` + +BlockRate is the average time between blocks. + +### BlocksUntilTxTimeout + +```toml +BlocksUntilTxTimeout = 30 # Default +``` + +BlocksUntilTxTimeout is the number of blocks to wait before giving up on the tx getting confirmed. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '1s' # Default +``` + +ConfirmPollPeriod sets how often check for tx confirmation. + +### FallbackGasPriceULuna + +```toml +FallbackGasPriceULuna = '0.015' # Default +``` + +FallbackGasPriceULuna sets a fallback gas price to use when the estimator is not available. + +### FCDURL + +```toml +FCDURL = 'http://terra.com' # Example +``` + +FCDURL sets the FCD URL. + +### GasLimitMultiplier + +```toml +GasLimitMultiplier = '1.5' # Default +``` + +GasLimitMultiplier scales the estimated gas limit. + +### MaxMsgsPerBatch + +```toml +MaxMsgsPerBatch = 100 # Default +``` + +MaxMsgsPerBatch limits the numbers of mesages per transaction batch. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '4s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxMsgTimeout + +```toml +TxMsgTimeout = '10m' # Default +``` + +TxMsgTimeout is the maximum age for resending transaction before they expire. + +## Terra.Nodes + +```toml +[[Terra.Nodes]] +Name = 'primary' # Example +TendermintURL = 'http://tender.mint' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### TendermintURL + +```toml +TendermintURL = 'http://tender.mint' # Example +``` + +TendermintURL is the HTTP(S) tendermint endpoint for this node. diff --git a/src/pages/chainlink-nodes/v1/config/v1_13_0.mdx b/src/pages/chainlink-nodes/v1/config/v1_13_0.mdx new file mode 100644 index 00000000000..f7caf8b9de6 --- /dev/null +++ b/src/pages/chainlink-nodes/v1/config/v1_13_0.mdx @@ -0,0 +1,5182 @@ +--- +layout: ../../../../layouts/MainLayout.astro +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +--- + +import { Aside } from "@components" + +This document describes the TOML format for configuration. + +See also [SECRETS.md](SECRETS.md) + +## Example + +```toml +Log.Level = 'debug' + +[[EVM]] +ChainID = '1' # Required + +[[EVM.Nodes]] +Name = 'fake' # Required +WSURL = 'wss://foo.bar/ws' +HTTPURL = 'https://foo.bar' # Required +``` + +## Global + +```toml +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL for the node to push stats to. + +### InsecureFastScrypt + + + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = true # Default +LogPoller = false # Default +UICSAKeys = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = true # Default +``` + +FeedsManager enables the feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### UICSAKeys + +```toml +UICSAKeys = false # Default +``` + +UICSAKeys enables CSA Keys in the UI. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +LogQueries = false # Default +MaxIdleConns = 10 # Default +MaxOpenConns = 20 # Default +MigrateOnStartup = true # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for queries to idle in transaction before timing out. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed for a query stuck waiting to take a lock before timing out. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### LogQueries + +```toml +LogQueries = false # Default +``` + +LogQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### MaxIdleConns + +```toml +MaxIdleConns = 10 # Default +``` + +MaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use caution when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MaxOpenConns + +```toml +MaxOpenConns = 20 # Default +``` + +MaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use caution when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `$ROOT/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + + + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + + + +```toml +[Database.Lock] +Enabled = true # Default +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. + +Because of the complications with advisory locks, Chainlink nodes with v2.0 and later only support `lease` locking mode. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables the database lock. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Example +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Example +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## AuditLogger + +```toml +[AuditLogger] +Enabled = false # Default +ForwardToUrl = 'http://localhost:9898' # Example +JsonWrapperKey = 'event' # Example +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled determines if this logger should be configured at all + +### ForwardToUrl + +```toml +ForwardToUrl = 'http://localhost:9898' # Example +``` + +ForwardToUrl is where you want to forward logs to + +### JsonWrapperKey + +```toml +JsonWrapperKey = 'event' # Example +``` + +JsonWrapperKey if set wraps the map of data under another single key to make parsing easier + +### Headers + +```toml +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +Headers is the set of headers you wish to pass along with each request + +## Log + +```toml +[Log] +Level = 'info' # Default +JSONConsole = false # Default +UnixTS = false # Default +``` + +### Level + +```toml +Level = 'info' # Default +``` + +Level determines both what is printed on the screen and what is written to the log file. + +The available levels are: + +- "debug": Useful for forensic debugging of issues. +- "info": High-level informational messages. (default) +- "warn": A mild error occurred that might require non-urgent action. Check these warnings semi-regularly to see if any of them require attention. These warnings usually happen due to factors outside of the control of the node operator. Examples: Unexpected responses from a remote API or misleading networking errors. +- "error": An unexpected error occurred during the regular operation of a well-maintained node. Node operators might need to take action to remedy this error. Check these regularly to see if any of them require attention. Examples: Use of deprecated configuration options or incorrectly configured settings that cause a job to fail. +- "crit": A critical error occurred. The node might be unable to function. Node operators should take immediate action to fix these errors. Examples: The node could not boot because a network socket could not be opened or the database became inaccessible. +- "panic": An exceptional error occurred that could not be handled. If the node is unresponsive, node operators should try to restart their nodes and notify the Chainlink team of a potential bug. +- "fatal": The node encountered an unrecoverable problem and had to exit. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## Log.File + +```toml +[Log.File] +Dir = '/my/log/directory' # Example +MaxSize = '5120mb' # Default +MaxAgeDays = 0 # Default +MaxBackups = 1 # Default +``` + +### Dir + +```toml +Dir = '/my/log/directory' # Example +``` + +Dir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### MaxSize + +```toml +MaxSize = '5120mb' # Default +``` + +MaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### MaxAgeDays + +```toml +MaxAgeDays = 0 # Default +``` + +MaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### MaxBackups + +```toml +MaxBackups = 1 # Default +``` + +MaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `MaxAgeDays` variable can still cause them to get deleted. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeCacheTTL = '0s' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +SessionReaperExpiration = '240h' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeCacheTTL + +```toml +BridgeCacheTTL = '0s' # Default +``` + +BridgeCacheTTL controls the cache TTL for all bridge tasks to use old values in newer observations in case of intermittent failure. It's disabled by default. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + + + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +### SessionReaperExpiration + +```toml +SessionReaperExpiration = '240h' # Default +``` + +SessionReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 1000 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 1000 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '~/.cl/certs' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '~/.cl/certs' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +## JobPipeline + +```toml +[JobPipeline] +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +MaxSuccessfulRuns = 10000 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### MaxSuccessfulRuns + +```toml +MaxSuccessfulRuns = 10000 # Default +``` + +MaxSuccessfulRuns caps the number of completed successful runs per pipeline +spec in the database. You can set it to zero as a performance optimisation; +this will avoid saving any successful run. + +Note this is not a hard cap, it can drift slightly larger than this but not +by more than 5% or so. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + + + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## JobPipeline.HTTPRequest + +```toml +[JobPipeline.HTTPRequest] +DefaultTimeout = '15s' # Default +MaxSize = '32768' # Default +``` + +### DefaultTimeout + +```toml +DefaultTimeout = '15s' # Default +``` + +DefaultTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### MaxSize + +```toml +MaxSize = '32768' # Default +``` + +MaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +Enabled = false # Default +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR2 jobs. + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +## OCR + +```toml +[OCR] +Enabled = false # Default +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +This section applies only if you are running off-chain reporting jobs. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +Enabled = true # Default +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerstoreWriteInterval = '5m' # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables P2P V1. + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivity +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively +cheap. We set this to 1 minute during our test. + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + + + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + + + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerstoreWriteInterval + + + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +Enabled = false # Default +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables P2P V2. +Note: V1.Enabled is true by default, so it must be set false in order to run V2 only. + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in host:port form as accepted by net.Dial. The addresses should be reachable by peers of interest. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaxGracePeriod = 100 # Default +TurnLookBack = 1_000 # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaxGracePeriod + + + +```toml +MaxGracePeriod = 100 # Default +``` + +MaxGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### TurnLookBack + +```toml +TurnLookBack = 1_000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +## Keeper.Registry + +```toml +[Keeper.Registry] +CheckGasOverhead = 200_000 # Default +PerformGasOverhead = 300_000 # Default +SyncInterval = '30m' # Default +MaxPerformDataSize = 5_000 # Default +SyncUpkeepQueueSize = 10 # Default +``` + +### CheckGasOverhead + + + +```toml +CheckGasOverhead = 200_000 # Default +``` + +CheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### PerformGasOverhead + + + +```toml +PerformGasOverhead = 300_000 # Default +``` + +PerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### SyncInterval + + + +```toml +SyncInterval = '30m' # Default +``` + +SyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### MaxPerformDataSize + + + +```toml +MaxPerformDataSize = 5_000 # Default +``` + +MaxPerformDataSize is the max size of perform data. + +### SyncUpkeepQueueSize + + + +```toml +SyncUpkeepQueueSize = 10 # Default +``` + +SyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Pyroscope + +```toml +[Pyroscope] +ServerAddress = 'http://localhost:4040' # Example +Environment = 'mainnet' # Default +``` + +### ServerAddress + +```toml +ServerAddress = 'http://localhost:4040' # Example +``` + +ServerAddress sets the address that will receive the profile logs. It enables the profiling service. + +### Environment + +```toml +Environment = 'mainnet' # Default +``` + +Environment sets the target environment tag in which profiles will be added to. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'my-custom-env' # Example +Release = 'v1.2.3' # Example +``` + +### Debug + + + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'my-custom-env' # Example +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## EVM + +EVM defaults depend on ChainID: + +### Ethereum Mainnet (1) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Ropsten (3) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Rinkeby (4) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Goerli (5) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Mainnet (10) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### RSK Mainnet (30) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### RSK Testnet (31) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Kovan (42) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### BSC Mainnet (56) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Testnet (65) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Mainnet (66) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Kovan (69) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### xDai Mainnet (100) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 100 +LogPollInterval = '5s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Heco Mainnet (128) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mainnet (137) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Mainnet (250) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 3800000 +``` + +### Optimism Goerli (420) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimismBedrock' +FinalityDepth = 200 +LinkContractAddress = '0xdc2CC710e42857672E7907CF474a69B63B93089f' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '1m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '30s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 wei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 300 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### Metis Rinkeby (588) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Klaytn Testnet (1001) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Metis Mainnet (1088) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Simulated (1337) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '100' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '0s' +ResendAfterThreshold = '0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 100 +SamplingInterval = '0s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Testnet (4002) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 3800000 +``` + +### Klaytn Mainnet (8217) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Mainnet (42161) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Fuji (43113) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Mainnet (43114) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mumbai (80001) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Rinkeby (421611) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Goerli (421613) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xd14838A68E8AFBAdE5efb411d5871ea0011AFd28' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Sepolia (11155111) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xb227f007804c16546Bd054dfED2E7A1fD5437678' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Mainnet (1666600000) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Testnet (1666700000) + +```toml +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockBackfillDepth + + + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'Optimism' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + + + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + + + +```toml +LogBackfillBatchSize = 100 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + + + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### LogKeepBlocksDepth + + + +```toml +LogKeepBlocksDepth = 100000 # Default +``` + +LogKeepBlocksDepth works in conjunction with Feature.LogPoller. Controls how many blocks the poller will keep, must be greater than FinalityDepth+1. + +### MinContractPayment + +```toml +MinContractPayment = '10000000000000 juels' # Default +``` + +MinContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before `NodePool` marks rpc endpoints as +out-of-sync, and `HeadTracker` logs warnings. + +Set to zero to disable out-of-sync checking. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 100 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### RPCBlockQueryDelay + + + +```toml +RPCBlockQueryDelay = 1 # Default +``` + +RPCBlockQueryDelay controls the number of blocks to trail behind head in the block history estimator and balance monitor. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +## EVM.Transactions + +```toml +[EVM.Transactions] +ForwardersEnabled = false # Default +MaxInFlight = 16 # Default +MaxQueued = 250 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '168h' # Default +ResendAfterThreshold = '1m' # Default +``` + +### ForwardersEnabled + +```toml +ForwardersEnabled = false # Default +``` + +ForwardersEnabled enables or disables sending transactions through forwarder contracts. + +### MaxInFlight + +```toml +MaxInFlight = 16 # Default +``` + +MaxInFlight controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueued + +```toml +MaxQueued = 250 # Default +``` + +MaxQueued is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the EthTx reaper will run. + +### ReaperThreshold + +```toml +ReaperThreshold = '168h' # Default +``` + +ReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### ResendAfterThreshold + +```toml +ResendAfterThreshold = '1m' # Default +``` + +ResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitMax = 500_000 # Default +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 10 # Default +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMin = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `Optimism2`/`L2Suggested` is a special mode only for use with Optimism and Metis blockchains. This mode will use the gas price suggested by the rpc endpoint via `eth_gasPrice`. +- `Arbitrum` is a special mode only for use with Arbitrum blockchains. It uses the suggested gas price (up to `ETH_MAX_GAS_PRICE_WEI`, with `1000 gwei` default) as well as an estimated gas limit (up to `ETH_GAS_LIMIT_MAX`, with `1,000,000,000` default). + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. +This applies to both legacy and EIP1559 transactions. +Note that it is impossible to disable the maximum limit. Setting this value to zero will prevent paying anything for any transaction (which can be useful in some rare cases). +Most chains by default have the maximum set to 2\*\*256-1 Wei which is the maximum allowed gas price on EVM-compatible chains, and is so large it may as well be unlimited. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitMax + +```toml +LimitMax = 500_000 # Default +``` + +LimitMax sets a maximum for _estimated_ gas limits. This currently only applies to `Arbitrum` `GasEstimatorMode`. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes Optimism L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 10 # Default +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap = ( current block base fee * (1.125 ^ N) + tipcap )` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMin` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMax` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMin + +```toml +TipCapMin = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.LimitJobType + +```toml +[EVM.GasEstimator.LimitJobType] +OCR = 100_000 # Example +DR = 100_000 # Example +VRF = 100_000 # Example +FM = 100_000 # Example +Keeper = 100_000 # Example +``` + +### OCR + +```toml +OCR = 100_000 # Example +``` + +OCR overrides LimitDefault for OCR jobs. + +### DR + +```toml +DR = 100_000 # Example +``` + +DR overrides LimitDefault for Direct Request jobs. + +### VRF + +```toml +VRF = 100_000 # Example +``` + +VRF overrides LimitDefault for VRF jobs. + +### FM + +```toml +FM = 100_000 # Example +``` + +FM overrides LimitDefault for Flux Monitor jobs. + +### Keeper + +```toml +Keeper = 100_000 # Example +``` + +Keeper overrides LimitDefault for Keeper jobs. + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 4 # Default +BlockHistorySize = 8 # Default +CheckInclusionBlocks = 12 # Default +CheckInclusionPercentile = 90 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 4 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### CheckInclusionBlocks + +```toml +CheckInclusionBlocks = 12 # Default +``` + +CheckInclusionBlocks is the number of recent blocks to use to detect if there is a transaction propagation/connectivity issue, and to prevent bumping in these cases. +This can help avoid the situation where RPC nodes are not propagating transactions for some non-price-related reason (e.g. go-ethereum bug, networking issue etc) and bumping gas would not help. + +Set to zero to disable connectivity checking completely. + +### CheckInclusionPercentile + +```toml +CheckInclusionPercentile = 90 # Default +``` + +CheckInclusionPercentile controls the percentile that a transaction must have been higher than for all the blocks in the inclusion check window in order to register as a connectivity issue. + +For example, if CheckInclusionBlocks=12 and CheckInclusionPercentile=90 then further bumping will be prevented for any transaction with any attempt that has a higher price than the 90th percentile for the most recent 12 blocks. + +### EIP1559FeeCapBufferBlocks + + + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +The head tracker continually listens for new heads from the chain. + +In addition to these settings, it log warnings if `EVM.NoNewHeadsThreshold` is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + + + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMax. + +## EVM.NodePool + +```toml +[EVM.NodePool] +PollFailureThreshold = 5 # Default +PollInterval = '10s' # Default +SelectionMode = 'HighestHead' # Default +SyncThreshold = 5 # Default +``` + +The node pool manages multiple RPC endpoints. + +In addition to these settings, `EVM.NoNewHeadsThreshold` controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 5 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +### SelectionMode + +```toml +SelectionMode = 'HighestHead' # Default +``` + +SelectionMode controls node selection strategy: + +- HighestHead: use the node with the highest head number +- RoundRobin: rotate through nodes, per-request +- TotalDifficulty: use the node with the greatest total difficulty + +### SyncThreshold + +```toml +SyncThreshold = 5 # Default +``` + +SyncThreshold controls how far a node may lag behind the best node before being marked out-of-sync. +Depending on `SelectionMode`, this represents a difference in the number of blocks (`HighestHead`, `RoundRobin`), or total difficulty (`TotalDifficulty`). + +Set to 0 to disable this check. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Required for all nodes. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +## EVM.OCR2.Automation + +```toml +[EVM.OCR2.Automation] +GasLimit = 5300000 # Default +``` + +### GasLimit + +```toml +GasLimit = 5300000 # Default +``` + +GasLimit controls the gas limit for transmit transactions from ocr2automation job. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1m' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +FeeEstimatorMode = 'fixed' # Default +ComputeUnitPriceMax = 1000 # Default +ComputeUnitPriceMin = 0 # Default +ComputeUnitPriceDefault = 0 # Default +FeeBumpPeriod = '3s' # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +### FeeEstimatorMode + +```toml +FeeEstimatorMode = 'fixed' # Default +``` + +FeeEstimatorMode is the method used to determine the base fee + +### ComputeUnitPriceMax + +```toml +ComputeUnitPriceMax = 1000 # Default +``` + +ComputeUnitPriceMax is the maximum price per compute unit that a transaction can be bumped to + +### ComputeUnitPriceMin + +```toml +ComputeUnitPriceMin = 0 # Default +``` + +ComputeUnitPriceMin is the minimum price per compute unit that transaction can have + +### ComputeUnitPriceDefault + +```toml +ComputeUnitPriceDefault = 0 # Default +``` + +ComputeUnitPriceDefault is the default price per compute unit price, and the starting base fee when FeeEstimatorMode = 'fixed' + +### FeeBumpPeriod + +```toml +FeeBumpPeriod = '3s' # Default +``` + +FeeBumpPeriod is the amount of time before a tx is retried with a fee bump + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Starknet + +```toml +[[Starknet]] +ChainID = 'foobar' # Example +Enabled = true # Default +OCR2CachePollPeriod = '5s' # Default +OCR2CacheTTL = '1m' # Default +RequestTimeout = '10s' # Default +TxTimeout = '1m' # Default +TxSendFrequency = '5s' # Default +TxMaxBatchSize = 100 # Default +``` + +### ChainID + +```toml +ChainID = 'foobar' # Example +``` + +ChainID is the Starknet chain ID. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '5s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### RequestTimeout + +```toml +RequestTimeout = '10s' # Default +``` + +RequestTimeout is the RPC client timeout. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxSendFrequency + +```toml +TxSendFrequency = '5s' # Default +``` + +TxSendFrequency is how often to broadcast batches of txes. + +### TxMaxBatchSize + +```toml +TxMaxBatchSize = 100 # Default +``` + +TxMaxBatchSize limits the size of tx batches. + +## Starknet.Nodes + +```toml +[[Starknet.Nodes]] +Name = 'primary' # Example +URL = 'http://stark.node' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://stark.node' # Example +``` + +URL is the base HTTP(S) endpoint for this node. diff --git a/src/pages/chainlink-nodes/v1/config/v1_6_0.mdx b/src/pages/chainlink-nodes/v1/config/v1_6_0.mdx index 654a169a56b..d8658867337 100644 --- a/src/pages/chainlink-nodes/v1/config/v1_6_0.mdx +++ b/src/pages/chainlink-nodes/v1/config/v1_6_0.mdx @@ -3,10 +3,10 @@ layout: ../../../../layouts/MainLayout.astro section: nodeOperator date: Last Modified title: "Configuring Chainlink Nodes" -permalink: "docs/chainlink-nodes/config/v1_6_0/" --- -[//]: # "Documentation generated from docs.toml - DO NOT EDIT." +import { Aside } from "@components" +[//]: # (Documentation generated from docs.toml - DO NOT EDIT.) ## Table of contents @@ -75,7 +75,7 @@ ExplorerURL is the websocket URL for the node to push stats to. ### InsecureFastScrypt -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml InsecureFastScrypt = false # Default @@ -280,7 +280,7 @@ Set to `0` to disable periodic backups. ## Database.Listener -⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + ```toml [Database.Listener] @@ -317,7 +317,7 @@ FallbackPollInterval controls how often clients should manually poll as a fallba ## Database.Lock -⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + ```toml [Database.Lock] @@ -598,7 +598,7 @@ Usually this will be the same as the URL/IP and port you use to connect to the C ### HTTPWriteTimeout -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml HTTPWriteTimeout = '10s' # Default @@ -816,7 +816,7 @@ ReaperThreshold determines the age limit for job runs. Completed job runs older ### ResultWriteQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml ResultWriteQueueDepth = 100 # Default @@ -834,7 +834,7 @@ SimulateTransactions = false # Default ### DefaultTransactionQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DefaultTransactionQueueDepth = 1 # Default @@ -1011,7 +1011,7 @@ if one doesn't exist. Recommended values are between two and five minutes. ### DefaultTransactionQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DefaultTransactionQueueDepth = 1 # Default @@ -1157,7 +1157,7 @@ misconfiguring it. ### DHTLookupInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DHTLookupInterval = 10 # Default @@ -1187,7 +1187,7 @@ ListenPort is the port to listen on. If left blank, the node randomly selects a ### NewStreamTimeout -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml NewStreamTimeout = '10s' # Default @@ -1209,7 +1209,7 @@ PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the firs ### PeerstoreWriteInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml PeerstoreWriteInterval = '5m' # Default @@ -1288,7 +1288,7 @@ UpkeepCheckGasPriceEnabled = false # Default ### DefaultTransactionQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DefaultTransactionQueueDepth = 1 # Default @@ -1322,7 +1322,7 @@ BaseFeeBufferPercent specifies the percentage to add to the base fee used for ch ### MaximumGracePeriod -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml MaximumGracePeriod = 100 # Default @@ -1332,7 +1332,7 @@ MaximumGracePeriod is the maximum number of blocks that a keeper will wait after ### RegistryCheckGasOverhead -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistryCheckGasOverhead = '200000' # Default @@ -1342,7 +1342,7 @@ RegistryCheckGasOverhead is the amount of extra gas to provide checkUpkeep() cal ### RegistryPerformGasOverhead -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistryPerformGasOverhead = '150000' # Default @@ -1352,7 +1352,7 @@ RegistryPerformGasOverhead is the amount of extra gas to provide performUpkeep() ### RegistrySyncInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistrySyncInterval = '30m' # Default @@ -1362,7 +1362,7 @@ RegistrySyncInterval is the interval in which the RegistrySynchronizer performs ### RegistrySyncUpkeepQueueSize -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistrySyncUpkeepQueueSize = 10 # Default @@ -1388,7 +1388,7 @@ TurnFlagEnabled enables a new algorithm for how keepers take turns. ### UpkeepCheckGasPriceEnabled -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml UpkeepCheckGasPriceEnabled = false # Default @@ -1526,7 +1526,7 @@ Release = 'v1.2.3' # Example ### Debug -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml Debug = false # Default @@ -1562,7 +1562,7 @@ Release overrides the Sentry release to the given value. Otherwise uses the comp EVM defaults depend on ChainID: -
Ethereum Mainnet (1)

+### Ethereum Mainnet (1) ```toml FinalityDepth = 50 @@ -1626,9 +1626,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Ropsten (3)

+### Ethereum Ropsten (3) ```toml FinalityDepth = 50 @@ -1691,9 +1689,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Rinkeby (4)

+### Ethereum Rinkeby (4) ```toml FinalityDepth = 50 @@ -1756,9 +1752,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Goerli (5)

+### Ethereum Goerli (5) ```toml FinalityDepth = 50 @@ -1821,9 +1815,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Optimism Mainnet (10)

+### Optimism Mainnet (10) ```toml ChainType = 'optimism' @@ -1887,9 +1879,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
RSK Mainnet (30)

+### RSK Mainnet (30) ```toml FinalityDepth = 50 @@ -1952,9 +1942,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
RSK Testnet (31)

+### RSK Testnet (31) ```toml FinalityDepth = 50 @@ -2017,9 +2005,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Kovan (42)

+### Ethereum Kovan (42) ```toml FinalityDepth = 50 @@ -2083,9 +2069,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
BSC Mainnet (56)

+### BSC Mainnet (56) ```toml FinalityDepth = 50 @@ -2148,9 +2132,7 @@ DatabaseTimeout = '2s' ObservationGracePeriod = '500ms' ``` -

- -
OKX Testnet (65)

+### OKX Testnet (65) ```toml FinalityDepth = 50 @@ -2212,9 +2194,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
OKX Mainnet (66)

+### OKX Mainnet (66) ```toml FinalityDepth = 50 @@ -2276,9 +2256,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Optimism Kovan (69)

+### Optimism Kovan (69) ```toml ChainType = 'optimism' @@ -2342,9 +2320,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
xDai Mainnet (100)

+### xDai Mainnet (100) ```toml ChainType = 'xdai' @@ -2408,9 +2384,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Heco Mainnet (128)

+### Heco Mainnet (128) ```toml FinalityDepth = 50 @@ -2473,9 +2447,7 @@ DatabaseTimeout = '2s' ObservationGracePeriod = '500ms' ``` -

- -
Polygon Mainnet (137)

+### Polygon Mainnet (137) ```toml FinalityDepth = 500 @@ -2538,9 +2510,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Fantom Mainnet (250)

+### Fantom Mainnet (250) ```toml FinalityDepth = 50 @@ -2603,9 +2573,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Metis Rinkeby (588)

+### Metis Rinkeby (588) ```toml ChainType = 'metis' @@ -2668,9 +2636,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Metis Mainnet (1088)

+### Metis Mainnet (1088) ```toml ChainType = 'metis' @@ -2733,9 +2699,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Fantom Testnet (4002)

+### Fantom Testnet (4002) ```toml FinalityDepth = 50 @@ -2798,9 +2762,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Arbitrum Mainnet (42161)

+### Arbitrum Mainnet (42161) ```toml ChainType = 'arbitrum' @@ -2864,9 +2826,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Avalanche Fuji (43113)

+### Avalanche Fuji (43113) ```toml FinalityDepth = 1 @@ -2929,9 +2889,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Avalanche Mainnet (43114)

+### Avalanche Mainnet (43114) ```toml FinalityDepth = 1 @@ -2994,9 +2952,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Polygon Mumbai (80001)

+### Polygon Mumbai (80001) ```toml FinalityDepth = 500 @@ -3059,9 +3015,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Arbitrum Rinkeby (421611)

+### Arbitrum Rinkeby (421611) ```toml ChainType = 'arbitrum' @@ -3125,9 +3079,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Harmony Mainnet (1666600000)

+### Harmony Mainnet (1666600000) ```toml FinalityDepth = 50 @@ -3190,9 +3142,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Harmony Testnet (1666700000)

+### Harmony Testnet (1666700000) ```toml FinalityDepth = 50 @@ -3255,8 +3205,6 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- ### ChainID ```toml @@ -3275,7 +3223,7 @@ Enabled enables this chain. ### BlockBackfillDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml BlockBackfillDepth = 10 # Default @@ -3328,7 +3276,7 @@ A re-org occurs at height 47 starting at block 41, transaction is NOT marked for ### FlagsContractAddress -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example @@ -3346,7 +3294,7 @@ LinkContractAddress is the canonical ERC-677 LINK token contract address on the ### LogBackfillBatchSize -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml LogBackfillBatchSize = 100 # Default @@ -3356,7 +3304,7 @@ LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill ### LogPollInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml LogPollInterval = '15s' # Default @@ -3480,7 +3428,7 @@ Enabled balance monitoring for all keys. ### BlockDelay -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml BlockDelay = 1 # Default @@ -3756,7 +3704,7 @@ BlockHistorySize controls the number of past blocks to keep in memory to use as ### EIP1559FeeCapBufferBlocks -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml EIP1559FeeCapBufferBlocks = 13 # Example @@ -3826,7 +3774,7 @@ for the head tracker before we start dropping heads to keep up. ### SamplingInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml SamplingInterval = '1s' # Default diff --git a/src/pages/chainlink-nodes/v1/config/v1_7_0.mdx b/src/pages/chainlink-nodes/v1/config/v1_7_0.mdx index 52d9494e3de..e941dfd8057 100644 --- a/src/pages/chainlink-nodes/v1/config/v1_7_0.mdx +++ b/src/pages/chainlink-nodes/v1/config/v1_7_0.mdx @@ -3,10 +3,10 @@ layout: ../../../../layouts/MainLayout.astro section: nodeOperator date: Last Modified title: "Configuring Chainlink Nodes" -permalink: "docs/chainlink-nodes/config/v1_7_0/" --- -[//]: # "Documentation generated from docs.toml - DO NOT EDIT." +import { Aside } from "@components" +[//]: # (Documentation generated from docs.toml - DO NOT EDIT.) ## Table of contents @@ -75,7 +75,7 @@ ExplorerURL is the websocket URL for the node to push stats to. ### InsecureFastScrypt -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml InsecureFastScrypt = false # Default @@ -280,7 +280,7 @@ Set to `0` to disable periodic backups. ## Database.Listener -⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + ```toml [Database.Listener] @@ -317,7 +317,7 @@ FallbackPollInterval controls how often clients should manually poll as a fallba ## Database.Lock -⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + ```toml [Database.Lock] @@ -598,7 +598,7 @@ Usually this will be the same as the URL/IP and port you use to connect to the C ### HTTPWriteTimeout -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml HTTPWriteTimeout = '10s' # Default @@ -816,7 +816,7 @@ ReaperThreshold determines the age limit for job runs. Completed job runs older ### ResultWriteQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml ResultWriteQueueDepth = 100 # Default @@ -834,7 +834,7 @@ SimulateTransactions = false # Default ### DefaultTransactionQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DefaultTransactionQueueDepth = 1 # Default @@ -1011,7 +1011,7 @@ if one doesn't exist. Recommended values are between two and five minutes. ### DefaultTransactionQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DefaultTransactionQueueDepth = 1 # Default @@ -1157,7 +1157,7 @@ misconfiguring it. ### DHTLookupInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DHTLookupInterval = 10 # Default @@ -1187,7 +1187,7 @@ ListenPort is the port to listen on. If left blank, the node randomly selects a ### NewStreamTimeout -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml NewStreamTimeout = '10s' # Default @@ -1209,7 +1209,7 @@ PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the firs ### PeerstoreWriteInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml PeerstoreWriteInterval = '5m' # Default @@ -1288,7 +1288,7 @@ UpkeepCheckGasPriceEnabled = false # Default ### DefaultTransactionQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DefaultTransactionQueueDepth = 1 # Default @@ -1322,7 +1322,7 @@ BaseFeeBufferPercent specifies the percentage to add to the base fee used for ch ### MaximumGracePeriod -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml MaximumGracePeriod = 100 # Default @@ -1332,7 +1332,7 @@ MaximumGracePeriod is the maximum number of blocks that a keeper will wait after ### RegistryCheckGasOverhead -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistryCheckGasOverhead = '200000' # Default @@ -1342,7 +1342,7 @@ RegistryCheckGasOverhead is the amount of extra gas to provide checkUpkeep() cal ### RegistryPerformGasOverhead -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistryPerformGasOverhead = '150000' # Default @@ -1352,7 +1352,7 @@ RegistryPerformGasOverhead is the amount of extra gas to provide performUpkeep() ### RegistrySyncInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistrySyncInterval = '30m' # Default @@ -1362,7 +1362,7 @@ RegistrySyncInterval is the interval in which the RegistrySynchronizer performs ### RegistrySyncUpkeepQueueSize -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistrySyncUpkeepQueueSize = 10 # Default @@ -1388,7 +1388,7 @@ TurnFlagEnabled enables a new algorithm for how keepers take turns. ### UpkeepCheckGasPriceEnabled -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml UpkeepCheckGasPriceEnabled = false # Default @@ -1526,7 +1526,7 @@ Release = 'v1.2.3' # Example ### Debug -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml Debug = false # Default @@ -1562,7 +1562,7 @@ Release overrides the Sentry release to the given value. Otherwise uses the comp EVM defaults depend on ChainID: -
Ethereum Mainnet (1)

+### Ethereum Mainnet (1) ```toml FinalityDepth = 50 @@ -1626,9 +1626,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Ropsten (3)

+### Ethereum Ropsten (3) ```toml FinalityDepth = 50 @@ -1691,9 +1689,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Rinkeby (4)

+### Ethereum Rinkeby (4) ```toml FinalityDepth = 50 @@ -1756,9 +1752,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Goerli (5)

+### Ethereum Goerli (5) ```toml FinalityDepth = 50 @@ -1821,9 +1815,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Optimism Mainnet (10)

+### Optimism Mainnet (10) ```toml ChainType = 'optimism' @@ -1887,9 +1879,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
RSK Mainnet (30)

+### RSK Mainnet (30) ```toml FinalityDepth = 50 @@ -1952,9 +1942,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
RSK Testnet (31)

+### RSK Testnet (31) ```toml FinalityDepth = 50 @@ -2017,9 +2005,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Kovan (42)

+### Ethereum Kovan (42) ```toml FinalityDepth = 50 @@ -2083,9 +2069,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
BSC Mainnet (56)

+### BSC Mainnet (56) ```toml FinalityDepth = 50 @@ -2148,9 +2132,7 @@ DatabaseTimeout = '2s' ObservationGracePeriod = '500ms' ``` -

- -
OKX Testnet (65)

+### OKX Testnet (65) ```toml FinalityDepth = 50 @@ -2212,9 +2194,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
OKX Mainnet (66)

+### OKX Mainnet (66) ```toml FinalityDepth = 50 @@ -2276,9 +2256,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Optimism Kovan (69)

+### Optimism Kovan (69) ```toml ChainType = 'optimism' @@ -2342,9 +2320,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
xDai Mainnet (100)

+### xDai Mainnet (100) ```toml ChainType = 'xdai' @@ -2408,9 +2384,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Heco Mainnet (128)

+### Heco Mainnet (128) ```toml FinalityDepth = 50 @@ -2473,9 +2447,7 @@ DatabaseTimeout = '2s' ObservationGracePeriod = '500ms' ``` -

- -
Polygon Mainnet (137)

+### Polygon Mainnet (137) ```toml FinalityDepth = 500 @@ -2538,9 +2510,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Fantom Mainnet (250)

+### Fantom Mainnet (250) ```toml FinalityDepth = 50 @@ -2603,9 +2573,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Metis Rinkeby (588)

+### Metis Rinkeby (588) ```toml ChainType = 'metis' @@ -2668,9 +2636,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Metis Mainnet (1088)

+### Metis Mainnet (1088) ```toml ChainType = 'metis' @@ -2733,9 +2699,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Fantom Testnet (4002)

+### Fantom Testnet (4002) ```toml FinalityDepth = 50 @@ -2798,9 +2762,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Arbitrum Mainnet (42161)

+### Arbitrum Mainnet (42161) ```toml ChainType = 'arbitrum' @@ -2864,9 +2826,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Avalanche Fuji (43113)

+### Avalanche Fuji (43113) ```toml FinalityDepth = 1 @@ -2929,9 +2889,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Avalanche Mainnet (43114)

+### Avalanche Mainnet (43114) ```toml FinalityDepth = 1 @@ -2994,9 +2952,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Polygon Mumbai (80001)

+### Polygon Mumbai (80001) ```toml FinalityDepth = 500 @@ -3059,9 +3015,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Arbitrum Rinkeby (421611)

+### Arbitrum Rinkeby (421611) ```toml ChainType = 'arbitrum' @@ -3125,9 +3079,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Sepolia (11155111)

+### Ethereum Sepolia (11155111) ```toml FinalityDepth = 50 @@ -3190,9 +3142,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Harmony Mainnet (1666600000)

+### Harmony Mainnet (1666600000) ```toml FinalityDepth = 50 @@ -3255,9 +3205,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Harmony Testnet (1666700000)

+### Harmony Testnet (1666700000) ```toml FinalityDepth = 50 @@ -3320,8 +3268,6 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- ### ChainID ```toml @@ -3340,7 +3286,7 @@ Enabled enables this chain. ### BlockBackfillDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml BlockBackfillDepth = 10 # Default @@ -3393,7 +3339,7 @@ A re-org occurs at height 47 starting at block 41, transaction is NOT marked for ### FlagsContractAddress -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example @@ -3411,7 +3357,7 @@ LinkContractAddress is the canonical ERC-677 LINK token contract address on the ### LogBackfillBatchSize -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml LogBackfillBatchSize = 100 # Default @@ -3421,7 +3367,7 @@ LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill ### LogPollInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml LogPollInterval = '15s' # Default @@ -3545,7 +3491,7 @@ Enabled balance monitoring for all keys. ### BlockDelay -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml BlockDelay = 1 # Default @@ -3866,7 +3812,7 @@ BlockHistorySize controls the number of past blocks to keep in memory to use as ### EIP1559FeeCapBufferBlocks -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml EIP1559FeeCapBufferBlocks = 13 # Example @@ -3936,7 +3882,7 @@ for the head tracker before we start dropping heads to keep up. ### SamplingInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml SamplingInterval = '1s' # Default diff --git a/src/pages/chainlink-nodes/v1/config/v1_7_1.mdx b/src/pages/chainlink-nodes/v1/config/v1_7_1.mdx index 7d1e51ff4c2..e941dfd8057 100644 --- a/src/pages/chainlink-nodes/v1/config/v1_7_1.mdx +++ b/src/pages/chainlink-nodes/v1/config/v1_7_1.mdx @@ -3,10 +3,10 @@ layout: ../../../../layouts/MainLayout.astro section: nodeOperator date: Last Modified title: "Configuring Chainlink Nodes" -permalink: "docs/chainlink-nodes/config/v1_7_1/" --- -[//]: # "Documentation generated from docs.toml - DO NOT EDIT." +import { Aside } from "@components" +[//]: # (Documentation generated from docs.toml - DO NOT EDIT.) ## Table of contents @@ -75,7 +75,7 @@ ExplorerURL is the websocket URL for the node to push stats to. ### InsecureFastScrypt -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml InsecureFastScrypt = false # Default @@ -280,7 +280,7 @@ Set to `0` to disable periodic backups. ## Database.Listener -⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + ```toml [Database.Listener] @@ -317,7 +317,7 @@ FallbackPollInterval controls how often clients should manually poll as a fallba ## Database.Lock -⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + ```toml [Database.Lock] @@ -598,7 +598,7 @@ Usually this will be the same as the URL/IP and port you use to connect to the C ### HTTPWriteTimeout -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml HTTPWriteTimeout = '10s' # Default @@ -816,7 +816,7 @@ ReaperThreshold determines the age limit for job runs. Completed job runs older ### ResultWriteQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml ResultWriteQueueDepth = 100 # Default @@ -834,7 +834,7 @@ SimulateTransactions = false # Default ### DefaultTransactionQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DefaultTransactionQueueDepth = 1 # Default @@ -1011,7 +1011,7 @@ if one doesn't exist. Recommended values are between two and five minutes. ### DefaultTransactionQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DefaultTransactionQueueDepth = 1 # Default @@ -1157,7 +1157,7 @@ misconfiguring it. ### DHTLookupInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DHTLookupInterval = 10 # Default @@ -1187,7 +1187,7 @@ ListenPort is the port to listen on. If left blank, the node randomly selects a ### NewStreamTimeout -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml NewStreamTimeout = '10s' # Default @@ -1209,7 +1209,7 @@ PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the firs ### PeerstoreWriteInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml PeerstoreWriteInterval = '5m' # Default @@ -1288,7 +1288,7 @@ UpkeepCheckGasPriceEnabled = false # Default ### DefaultTransactionQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DefaultTransactionQueueDepth = 1 # Default @@ -1322,7 +1322,7 @@ BaseFeeBufferPercent specifies the percentage to add to the base fee used for ch ### MaximumGracePeriod -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml MaximumGracePeriod = 100 # Default @@ -1332,7 +1332,7 @@ MaximumGracePeriod is the maximum number of blocks that a keeper will wait after ### RegistryCheckGasOverhead -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistryCheckGasOverhead = '200000' # Default @@ -1342,7 +1342,7 @@ RegistryCheckGasOverhead is the amount of extra gas to provide checkUpkeep() cal ### RegistryPerformGasOverhead -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistryPerformGasOverhead = '150000' # Default @@ -1352,7 +1352,7 @@ RegistryPerformGasOverhead is the amount of extra gas to provide performUpkeep() ### RegistrySyncInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistrySyncInterval = '30m' # Default @@ -1362,7 +1362,7 @@ RegistrySyncInterval is the interval in which the RegistrySynchronizer performs ### RegistrySyncUpkeepQueueSize -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistrySyncUpkeepQueueSize = 10 # Default @@ -1388,7 +1388,7 @@ TurnFlagEnabled enables a new algorithm for how keepers take turns. ### UpkeepCheckGasPriceEnabled -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml UpkeepCheckGasPriceEnabled = false # Default @@ -1526,7 +1526,7 @@ Release = 'v1.2.3' # Example ### Debug -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml Debug = false # Default @@ -1562,7 +1562,7 @@ Release overrides the Sentry release to the given value. Otherwise uses the comp EVM defaults depend on ChainID: -
Ethereum Mainnet (1)

+### Ethereum Mainnet (1) ```toml FinalityDepth = 50 @@ -1626,9 +1626,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Ropsten (3)

+### Ethereum Ropsten (3) ```toml FinalityDepth = 50 @@ -1691,9 +1689,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Rinkeby (4)

+### Ethereum Rinkeby (4) ```toml FinalityDepth = 50 @@ -1756,9 +1752,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Goerli (5)

+### Ethereum Goerli (5) ```toml FinalityDepth = 50 @@ -1821,9 +1815,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Optimism Mainnet (10)

+### Optimism Mainnet (10) ```toml ChainType = 'optimism' @@ -1887,9 +1879,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
RSK Mainnet (30)

+### RSK Mainnet (30) ```toml FinalityDepth = 50 @@ -1952,9 +1942,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
RSK Testnet (31)

+### RSK Testnet (31) ```toml FinalityDepth = 50 @@ -2017,9 +2005,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Kovan (42)

+### Ethereum Kovan (42) ```toml FinalityDepth = 50 @@ -2083,9 +2069,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
BSC Mainnet (56)

+### BSC Mainnet (56) ```toml FinalityDepth = 50 @@ -2148,9 +2132,7 @@ DatabaseTimeout = '2s' ObservationGracePeriod = '500ms' ``` -

- -
OKX Testnet (65)

+### OKX Testnet (65) ```toml FinalityDepth = 50 @@ -2212,9 +2194,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
OKX Mainnet (66)

+### OKX Mainnet (66) ```toml FinalityDepth = 50 @@ -2276,9 +2256,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Optimism Kovan (69)

+### Optimism Kovan (69) ```toml ChainType = 'optimism' @@ -2342,9 +2320,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
xDai Mainnet (100)

+### xDai Mainnet (100) ```toml ChainType = 'xdai' @@ -2408,9 +2384,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Heco Mainnet (128)

+### Heco Mainnet (128) ```toml FinalityDepth = 50 @@ -2473,9 +2447,7 @@ DatabaseTimeout = '2s' ObservationGracePeriod = '500ms' ``` -

- -
Polygon Mainnet (137)

+### Polygon Mainnet (137) ```toml FinalityDepth = 500 @@ -2538,9 +2510,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Fantom Mainnet (250)

+### Fantom Mainnet (250) ```toml FinalityDepth = 50 @@ -2603,9 +2573,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Metis Rinkeby (588)

+### Metis Rinkeby (588) ```toml ChainType = 'metis' @@ -2668,9 +2636,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Metis Mainnet (1088)

+### Metis Mainnet (1088) ```toml ChainType = 'metis' @@ -2733,9 +2699,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Fantom Testnet (4002)

+### Fantom Testnet (4002) ```toml FinalityDepth = 50 @@ -2798,9 +2762,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Arbitrum Mainnet (42161)

+### Arbitrum Mainnet (42161) ```toml ChainType = 'arbitrum' @@ -2864,9 +2826,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Avalanche Fuji (43113)

+### Avalanche Fuji (43113) ```toml FinalityDepth = 1 @@ -2929,9 +2889,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Avalanche Mainnet (43114)

+### Avalanche Mainnet (43114) ```toml FinalityDepth = 1 @@ -2994,9 +2952,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Polygon Mumbai (80001)

+### Polygon Mumbai (80001) ```toml FinalityDepth = 500 @@ -3059,9 +3015,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Arbitrum Rinkeby (421611)

+### Arbitrum Rinkeby (421611) ```toml ChainType = 'arbitrum' @@ -3125,9 +3079,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Sepolia (11155111)

+### Ethereum Sepolia (11155111) ```toml FinalityDepth = 50 @@ -3190,9 +3142,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Harmony Mainnet (1666600000)

+### Harmony Mainnet (1666600000) ```toml FinalityDepth = 50 @@ -3255,9 +3205,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Harmony Testnet (1666700000)

+### Harmony Testnet (1666700000) ```toml FinalityDepth = 50 @@ -3320,8 +3268,6 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- ### ChainID ```toml @@ -3340,7 +3286,7 @@ Enabled enables this chain. ### BlockBackfillDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml BlockBackfillDepth = 10 # Default @@ -3393,7 +3339,7 @@ A re-org occurs at height 47 starting at block 41, transaction is NOT marked for ### FlagsContractAddress -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example @@ -3411,7 +3357,7 @@ LinkContractAddress is the canonical ERC-677 LINK token contract address on the ### LogBackfillBatchSize -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml LogBackfillBatchSize = 100 # Default @@ -3421,7 +3367,7 @@ LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill ### LogPollInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml LogPollInterval = '15s' # Default @@ -3545,7 +3491,7 @@ Enabled balance monitoring for all keys. ### BlockDelay -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml BlockDelay = 1 # Default @@ -3866,7 +3812,7 @@ BlockHistorySize controls the number of past blocks to keep in memory to use as ### EIP1559FeeCapBufferBlocks -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml EIP1559FeeCapBufferBlocks = 13 # Example @@ -3936,7 +3882,7 @@ for the head tracker before we start dropping heads to keep up. ### SamplingInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml SamplingInterval = '1s' # Default diff --git a/src/pages/chainlink-nodes/v1/config/v1_8_0.mdx b/src/pages/chainlink-nodes/v1/config/v1_8_0.mdx index 8d09f510de4..8726bb464c5 100644 --- a/src/pages/chainlink-nodes/v1/config/v1_8_0.mdx +++ b/src/pages/chainlink-nodes/v1/config/v1_8_0.mdx @@ -3,9 +3,11 @@ layout: ../../../../layouts/MainLayout.astro section: nodeOperator date: Last Modified title: "Configuring Chainlink Nodes" -permalink: "docs/chainlink-nodes/config/v1_8_0/" --- +import { Aside } from "@components" +[//]: # (Documentation generated from docs.toml - DO NOT EDIT.) + ## Table of contents - [Global](#Global) @@ -63,7 +65,7 @@ ExplorerURL is the websocket URL for the node to push stats to. ### InsecureFastScrypt -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml InsecureFastScrypt = false # Default @@ -240,7 +242,7 @@ Set to `0` to disable periodic backups. ## Database.Listener -⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + ```toml [Database.Listener] @@ -277,7 +279,7 @@ FallbackPollInterval controls how often clients should manually poll as a fallba ## Database.Lock -⚠️ **_ADVANCED_**: _Do not change these settings unless you know what you are doing._ + ```toml [Database.Lock] @@ -518,7 +520,7 @@ Usually this will be the same as the URL/IP and port you use to connect to the C ### HTTPWriteTimeout -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml HTTPWriteTimeout = '10s' # Default @@ -744,7 +746,7 @@ ReaperThreshold determines the age limit for job runs. Completed job runs older ### ResultWriteQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml ResultWriteQueueDepth = 100 # Default @@ -762,7 +764,7 @@ SimulateTransactions = false # Default ### DefaultTransactionQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DefaultTransactionQueueDepth = 1 # Default @@ -957,7 +959,7 @@ if one doesn't exist. Recommended values are between two and five minutes. ### DefaultTransactionQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DefaultTransactionQueueDepth = 1 # Default @@ -1103,7 +1105,7 @@ misconfiguring it. ### DHTLookupInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DHTLookupInterval = 10 # Default @@ -1133,7 +1135,7 @@ ListenPort is the port to listen on. If left blank, the node randomly selects a ### NewStreamTimeout -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml NewStreamTimeout = '10s' # Default @@ -1155,7 +1157,7 @@ PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the firs ### PeerstoreWriteInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml PeerstoreWriteInterval = '5m' # Default @@ -1234,7 +1236,7 @@ UpkeepCheckGasPriceEnabled = false # Default ### DefaultTransactionQueueDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml DefaultTransactionQueueDepth = 1 # Default @@ -1268,7 +1270,7 @@ BaseFeeBufferPercent specifies the percentage to add to the base fee used for ch ### MaximumGracePeriod -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml MaximumGracePeriod = 100 # Default @@ -1278,7 +1280,7 @@ MaximumGracePeriod is the maximum number of blocks that a keeper will wait after ### RegistryCheckGasOverhead -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistryCheckGasOverhead = 200_000 # Default @@ -1288,7 +1290,7 @@ RegistryCheckGasOverhead is the amount of extra gas to provide checkUpkeep() cal ### RegistryPerformGasOverhead -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistryPerformGasOverhead = 150_000 # Default @@ -1298,7 +1300,7 @@ RegistryPerformGasOverhead is the amount of extra gas to provide performUpkeep() ### RegistrySyncInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistrySyncInterval = '30m' # Default @@ -1308,7 +1310,7 @@ RegistrySyncInterval is the interval in which the RegistrySynchronizer performs ### RegistrySyncUpkeepQueueSize -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml RegistrySyncUpkeepQueueSize = 10 # Default @@ -1334,7 +1336,7 @@ TurnFlagEnabled enables a new algorithm for how keepers take turns. ### UpkeepCheckGasPriceEnabled -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml UpkeepCheckGasPriceEnabled = false # Default @@ -1472,7 +1474,7 @@ Release = 'v1.2.3' # Example ### Debug -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml Debug = false # Default @@ -1508,7 +1510,7 @@ Release overrides the Sentry release to the given value. Otherwise uses the comp EVM defaults depend on ChainID: -
Ethereum Mainnet (1)

+### Ethereum Mainnet (1) ```toml FinalityDepth = 50 @@ -1573,9 +1575,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Ropsten (3)

+### Ethereum Ropsten (3) ```toml FinalityDepth = 50 @@ -1639,9 +1639,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Rinkeby (4)

+### Ethereum Rinkeby (4) ```toml FinalityDepth = 50 @@ -1705,9 +1703,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Goerli (5)

+### Ethereum Goerli (5) ```toml FinalityDepth = 50 @@ -1771,9 +1767,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Optimism Mainnet (10)

+### Optimism Mainnet (10) ```toml ChainType = 'optimism' @@ -1838,9 +1832,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
RSK Mainnet (30)

+### RSK Mainnet (30) ```toml FinalityDepth = 50 @@ -1904,9 +1896,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
RSK Testnet (31)

+### RSK Testnet (31) ```toml FinalityDepth = 50 @@ -1970,9 +1960,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Kovan (42)

+### Ethereum Kovan (42) ```toml FinalityDepth = 50 @@ -2037,9 +2025,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
BSC Mainnet (56)

+### BSC Mainnet (56) ```toml FinalityDepth = 50 @@ -2103,9 +2089,7 @@ DatabaseTimeout = '2s' ObservationGracePeriod = '500ms' ``` -

- -
OKX Testnet (65)

+### OKX Testnet (65) ```toml FinalityDepth = 50 @@ -2168,9 +2152,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
OKX Mainnet (66)

+### OKX Mainnet (66) ```toml FinalityDepth = 50 @@ -2233,9 +2215,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Optimism Kovan (69)

+### Optimism Kovan (69) ```toml ChainType = 'optimism' @@ -2300,9 +2280,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
xDai Mainnet (100)

+### xDai Mainnet (100) ```toml ChainType = 'xdai' @@ -2367,9 +2345,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Heco Mainnet (128)

+### Heco Mainnet (128) ```toml FinalityDepth = 50 @@ -2433,9 +2409,7 @@ DatabaseTimeout = '2s' ObservationGracePeriod = '500ms' ``` -

- -
Polygon Mainnet (137)

+### Polygon Mainnet (137) ```toml FinalityDepth = 500 @@ -2499,9 +2473,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Fantom Mainnet (250)

+### Fantom Mainnet (250) ```toml FinalityDepth = 50 @@ -2565,9 +2537,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Optimism Goerli (420)

+### Optimism Goerli (420) ```toml ChainType = 'optimism' @@ -2632,9 +2602,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Metis Rinkeby (588)

+### Metis Rinkeby (588) ```toml ChainType = 'metis' @@ -2698,9 +2666,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Metis Mainnet (1088)

+### Metis Mainnet (1088) ```toml ChainType = 'metis' @@ -2764,9 +2730,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Simulated (1337)

+### Simulated (1337) ```toml FinalityDepth = 1 @@ -2829,9 +2793,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Fantom Testnet (4002)

+### Fantom Testnet (4002) ```toml FinalityDepth = 50 @@ -2895,9 +2857,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Arbitrum Mainnet (42161)

+### Arbitrum Mainnet (42161) ```toml ChainType = 'arbitrum' @@ -2962,9 +2922,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Avalanche Fuji (43113)

+### Avalanche Fuji (43113) ```toml FinalityDepth = 1 @@ -3028,9 +2986,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Avalanche Mainnet (43114)

+### Avalanche Mainnet (43114) ```toml FinalityDepth = 1 @@ -3094,9 +3050,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Polygon Mumbai (80001)

+### Polygon Mumbai (80001) ```toml FinalityDepth = 500 @@ -3160,9 +3114,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Arbitrum Rinkeby (421611)

+### Arbitrum Rinkeby (421611) ```toml ChainType = 'arbitrum' @@ -3227,9 +3179,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Arbitrum Goerli (421613)

+### Arbitrum Goerli (421613) ```toml ChainType = 'arbitrum' @@ -3293,9 +3243,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Ethereum Sepolia (11155111)

+### Ethereum Sepolia (11155111) ```toml FinalityDepth = 50 @@ -3359,9 +3307,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Harmony Mainnet (1666600000)

+### Harmony Mainnet (1666600000) ```toml FinalityDepth = 50 @@ -3425,9 +3371,7 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- -
Harmony Testnet (1666700000)

+### Harmony Testnet (1666700000) ```toml FinalityDepth = 50 @@ -3491,8 +3435,6 @@ DatabaseTimeout = '10s' ObservationGracePeriod = '1s' ``` -

- ### ChainID ```toml @@ -3511,7 +3453,7 @@ Enabled enables this chain. ### BlockBackfillDepth -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml BlockBackfillDepth = 10 # Default @@ -3564,7 +3506,7 @@ A re-org occurs at height 47 starting at block 41, transaction is NOT marked for ### FlagsContractAddress -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example @@ -3582,7 +3524,7 @@ LinkContractAddress is the canonical ERC-677 LINK token contract address on the ### LogBackfillBatchSize -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml LogBackfillBatchSize = 100 # Default @@ -3592,7 +3534,7 @@ LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill ### LogPollInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml LogPollInterval = '15s' # Default @@ -3716,7 +3658,7 @@ Enabled balance monitoring for all keys. ### BlockDelay -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml BlockDelay = 1 # Default @@ -4037,7 +3979,7 @@ BlockHistorySize controls the number of past blocks to keep in memory to use as ### EIP1559FeeCapBufferBlocks -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml EIP1559FeeCapBufferBlocks = 13 # Example @@ -4107,7 +4049,7 @@ for the head tracker before we start dropping heads to keep up. ### SamplingInterval -⚠️ **_ADVANCED_**: _Do not change this setting unless you know what you are doing._ + ```toml SamplingInterval = '1s' # Default diff --git a/src/pages/chainlink-nodes/v1/config/v1_8_1.mdx b/src/pages/chainlink-nodes/v1/config/v1_8_1.mdx new file mode 100644 index 00000000000..c05c556561a --- /dev/null +++ b/src/pages/chainlink-nodes/v1/config/v1_8_1.mdx @@ -0,0 +1,4539 @@ +--- +layout: ../../../../layouts/MainLayout.astro +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +--- + +import { Aside } from "@components" +[//]: # (Documentation generated from docs.toml - DO NOT EDIT.) + +## Table of contents + +- [Global](#Global) +- [Feature](#Feature) +- [Database](#Database) + - [Backup](#Database-Backup) + - [Listener](#Database-Listener) + - [Lock](#Database-Lock) +- [TelemetryIngress](#TelemetryIngress) +- [Log](#Log) +- [WebServer](#WebServer) + - [RateLimit](#WebServer-RateLimit) + - [MFA](#WebServer-MFA) + - [TLS](#WebServer-TLS) +- [JobPipeline](#JobPipeline) +- [FluxMonitor](#FluxMonitor) +- [OCR2](#OCR2) +- [OCR](#OCR) +- [P2P](#P2P) + - [V1](#P2P-V1) + - [V2](#P2P-V2) +- [Keeper](#Keeper) +- [AutoPprof](#AutoPprof) +- [Sentry](#Sentry) +- [EVM](#EVM) + - [BalanceMonitor](#EVM-BalanceMonitor) + - [GasEstimator](#EVM-GasEstimator) + - [BlockHistory](#EVM-GasEstimator-BlockHistory) + - [HeadTracker](#EVM-HeadTracker) + - [KeySpecific](#EVM-KeySpecific) + - [NodePool](#EVM-NodePool) + - [OCR](#EVM-OCR) + - [Nodes](#EVM-Nodes) +- [Solana](#Solana) + - [Nodes](#Solana-Nodes) +- [Terra](#Terra) + - [Nodes](#Terra-Nodes) + +## Global + +```toml +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL for the node to push stats to. + +### InsecureFastScrypt + + + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = false # Default +LogPoller = false # Default +UICSAKeys = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = false # Default +``` + +FeedsManager enables the experimental feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### UICSAKeys + +```toml +UICSAKeys = false # Default +``` + +UICSAKeys enables CSA Keys in the UI. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +MigrateOnStartup = true # Default +ORMMaxIdleConns = 10 # Default +ORMMaxOpenConns = 20 # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for queries to idle in transaction before timing out. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed for a query stuck waiting to take a lock before timing out. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +### ORMMaxIdleConns + +```toml +ORMMaxIdleConns = 10 # Default +``` + +ORMMaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### ORMMaxOpenConns + +```toml +ORMMaxOpenConns = 20 # Default +``` + +ORMMaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `$ROOT/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + + + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + + + +```toml +[Database.Lock] +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. + +Because of the complications with advisory locks, Chainlink nodes with v2.0 and later only support `lease` locking mode. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +This setting applies only if `Mode` is set to enable lease locking. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +This setting applies only if Mode is set to enable lease locking. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Default +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Default +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## Log + +```toml +[Log] +DatabaseQueries = false # Default +JSONConsole = false # Default +FileDir = '/my/log/directory' # Example +FileMaxSize = '5120mb' # Default +FileMaxAgeDays = 0 # Default +FileMaxBackups = 1 # Default +UnixTS = false # Default +``` + +### DatabaseQueries + +```toml +DatabaseQueries = false # Default +``` + +DatabaseQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### FileDir + +```toml +FileDir = '/my/log/directory' # Example +``` + +FileDir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### FileMaxSize + +```toml +FileMaxSize = '5120mb' # Default +``` + +FileMaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### FileMaxAgeDays + +```toml +FileMaxAgeDays = 0 # Default +``` + +FileMaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### FileMaxBackups + +```toml +FileMaxBackups = 1 # Default +``` + +FileMaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `FileMaxAgeDays` variable can still cause them to get deleted. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +SessionReaperExpiration = '240h' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + + + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +### SessionReaperExpiration + +```toml +SessionReaperExpiration = '240h' # Default +``` + +SessionReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 42 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 42 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '/home/$USER/.chainlink/tls/server.crt' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '/home/$USER/.chainlink/tls/server.crt' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +## JobPipeline + +```toml +[JobPipeline] +HTTPRequestMaxSize = '32768' # Default +DefaultHTTPRequestTimeout = '15s' # Default +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### HTTPRequestMaxSize + +```toml +HTTPRequestMaxSize = '32768' # Default +``` + +HTTPRequestMaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +### DefaultHTTPRequestTimeout + +```toml +DefaultHTTPRequestTimeout = '15s' # Default +``` + +DefaultHTTPRequestTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + + + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +Enabled = true # Default +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables OCR2 jobs. + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +## OCR + +```toml +[OCR] +Enabled = true # Default +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +This section applies only if you are running off-chain reporting jobs. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables OCR jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +PeerstoreWriteInterval = '5m' # Default +``` + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivityBootstrapCheckInterval = '20s' # Default +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively# DefaultBootstrapPeers is the default set of bootstrap peers. +cheap. We set this to 1 minute during our test.DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + + + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + + + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### PeerstoreWriteInterval + + + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in host:port form as accepted by net.Dial. The addresses should be reachable by peers of interest. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaximumGracePeriod = 100 # Default +RegistryCheckGasOverhead = 200_000 # Default +RegistryPerformGasOverhead = 150_000 # Default +RegistrySyncInterval = '30m' # Default +RegistrySyncUpkeepQueueSize = 10 # Default +TurnLookBack = 1000 # Default +TurnFlagEnabled = false # Default +UpkeepCheckGasPriceEnabled = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaximumGracePeriod + + + +```toml +MaximumGracePeriod = 100 # Default +``` + +MaximumGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### RegistryCheckGasOverhead + + + +```toml +RegistryCheckGasOverhead = 200_000 # Default +``` + +RegistryCheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### RegistryPerformGasOverhead + + + +```toml +RegistryPerformGasOverhead = 150_000 # Default +``` + +RegistryPerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### RegistrySyncInterval + + + +```toml +RegistrySyncInterval = '30m' # Default +``` + +RegistrySyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### RegistrySyncUpkeepQueueSize + + + +```toml +RegistrySyncUpkeepQueueSize = 10 # Default +``` + +RegistrySyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +### TurnLookBack + +```toml +TurnLookBack = 1000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +### TurnFlagEnabled + +```toml +TurnFlagEnabled = false # Default +``` + +TurnFlagEnabled enables a new algorithm for how keepers take turns. + +### UpkeepCheckGasPriceEnabled + + + +```toml +UpkeepCheckGasPriceEnabled = false # Default +``` + +UpkeepCheckGasPriceEnabled includes gas price in calls to `checkUpkeep()` when set to `true`. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'prod' # Default +Release = 'v1.2.3' # Example +``` + +### Debug + + + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'prod' # Default +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## EVM + +EVM defaults depend on ChainID: + +### Ethereum Mainnet (1) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Ethereum Ropsten (3) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Ethereum Rinkeby (4) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Ethereum Goerli (5) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Optimism Mainnet (10) + +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### RSK Mainnet (30) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### RSK Testnet (31) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Ethereum Kovan (42) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### BSC Mainnet (56) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' +``` + +### OKX Testnet (65) + +```toml +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### OKX Mainnet (66) + +```toml +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Optimism Kovan (69) + +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '30m0s' +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### xDai Mainnet (100) + +```toml +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 100 +LogPollInterval = '5s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Heco Mainnet (128) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' +``` + +### Polygon Mainnet (137) + +```toml +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 5000 +MinIncomingConfirmations = 5 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 13 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '200 micro' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 10 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Fantom Mainnet (250) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Optimism Goerli (420) + +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0xdc2CC710e42857672E7907CF474a69B63B93089f' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '30m0s' +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Metis Rinkeby (588) + +```toml +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Metis Mainnet (1088) + +```toml +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Simulated (1337) + +```toml +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '100' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '0s' +TxResendAfterThreshold = '0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 0 + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 10 +MaxBufferSize = 100 +SamplingInterval = '0s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Fantom Testnet (4002) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 2 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Arbitrum Mainnet (42161) + +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '1 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Avalanche Fuji (43113) + +```toml +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '1 micro' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Avalanche Mainnet (43114) + +```toml +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '1 micro' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 2 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Polygon Mumbai (80001) + +```toml +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 5000 +MinIncomingConfirmations = 5 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 13 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 10 +BlockHistorySize = 24 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Arbitrum Rinkeby (421611) + +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '1 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Arbitrum Goerli (421613) + +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '1 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 0 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Ethereum Sepolia (11155111) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0xb227f007804c16546Bd054dfED2E7A1fD5437678' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 4 +TransactionPercentile = 50 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '1m0s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '3m0s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Harmony Mainnet (1666600000) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Harmony Testnet (1666700000) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +RPCDefaultBatchSize = 100 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true +BlockDelay = 1 + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockDelay = 1 +BlockHistorySize = 8 +TransactionPercentile = 60 + + +[HeadTracker] +BlockEmissionIdleWarningThreshold = '15s' +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +NoNewHeadsThreshold = '30s' +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockBackfillDepth + + + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'Optimism' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + + + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + + + +```toml +LogBackfillBatchSize = 100 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + + + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### MaxInFlightTransactions + +```toml +MaxInFlightTransactions = 16 # Default +``` + +MaxInFlightTransactions controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueuedTransactions + +```toml +MaxQueuedTransactions = 250 # Default +``` + +MaxQueuedTransactions is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### MinimumContractPayment + +```toml +MinimumContractPayment = '10000000000000 juels' # Default +``` + +MinimumContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 100 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### TxReaperInterval + +```toml +TxReaperInterval = '1h' # Default +``` + +TxReaperInterval controls how often the EthTx reaper will run. + +### TxReaperThreshold + +```toml +TxReaperThreshold = '168h' # Default +``` + +TxReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### TxResendAfterThreshold + +```toml +TxResendAfterThreshold = '1m' # Default +``` + +TxResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +### UseForwarders + +```toml +UseForwarders = false # Default +``` + +UseForwarders enables or disables sending transactions through forwarder contracts. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +BlockDelay = 1 # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +### BlockDelay + + + +```toml +BlockDelay = 1 # Default +``` + +BlockDelay is the number of blocks that the balance monitor trails behind head. This is required when load balancing +across multiple nodes announce a new head, then route a request to a different node which does not have this head yet. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '100 micro' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitMax = 500_000 # Default +LimitOCRJobType = 100_000 # Example +LimitDRJobType = 100_000 # Example +LimitVRFJobType = 100_000 # Example +LimitFMJobType = 100_000 # Example +LimitKeeperJobType = 100_000 # Example +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 10 # Default +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMinimum = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `L2Suggested` + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '100 micro' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitMax + +```toml +LimitMax = 500_000 # Default +``` + +LimitMax sets a maximum for _estimated_ gas limits. This currently only applies to `Arbitrum` `GasEstimatorMode`. + +### LimitOCRJobType + +```toml +LimitOCRJobType = 100_000 # Example +``` + +LimitOCRJobType overrides LimitDefault for OCR jobs. + +### LimitDRJobType + +```toml +LimitDRJobType = 100_000 # Example +``` + +LimitDRJobType overrides LimitDefault for Direct Request jobs. + +### LimitVRFJobType + +```toml +LimitVRFJobType = 100_000 # Example +``` + +LimitVRFJobType overrides LimitDefault for VRF jobs. + +### LimitFMJobType + +```toml +LimitFMJobType = 100_000 # Example +``` + +LimitFMJobType overrides LimitDefault for Flux Monitor jobs. + +### LimitKeeperJobType + +```toml +LimitKeeperJobType = 100_000 # Example +``` + +LimitKeeperJobType overrides LimitDefault for Keeper jobs. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes Optimism L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 10 # Default +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=MaxGasPriceWei` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=MaxGasPriceWei` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap=current block base fee * (1.125 ^ N)` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMinWei` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMaxWei` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMinimum + +```toml +TipCapMinimum = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 4 # Default +BlockDelay = 1 # Default +BlockHistorySize = 8 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 4 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockDelay + +```toml +BlockDelay = 1 # Default +``` + +BlockDelay controls the number of blocks that the block history estimator trails behind head. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### EIP1559FeeCapBufferBlocks + + + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +BlockEmissionIdleWarningThreshold = '1m' # Default +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +### BlockEmissionIdleWarningThreshold + +```toml +BlockEmissionIdleWarningThreshold = '1m' # Default +``` + +BlockEmissionIdleWarningThreshold will cause Chainlink to log warnings if this duration is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + + + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMaxWei. + +## EVM.NodePool + +```toml +[EVM.NodePool] +NoNewHeadsThreshold = '3m' # Default +PollFailureThreshold = 3 # Default +PollInterval = '10s' # Default +SelectionMode = 'HighestHead' # Default +``` + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +Set to zero to disable out-of-sync checking. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 3 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +### SelectionMode + +```toml +SelectionMode = 'HighestHead' # Default +``` + +SelectionMode controls node selection strategy: HighestHead or RoundRobin. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +ObservationTimeout = '1m' # Example +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +### ObservationTimeout + +```toml +ObservationTimeout = '1m' # Example +``` + +ObservationTimeout sets `OCR.ObservationTimeout` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Recommended for primary nodes. Required for `SendOnly`. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1h' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1h' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Terra + +```toml +[[Terra]] +ChainID = 'Bombay-12' # Example +Enabled = true # Default +BlockRate = '6s' # Default +BlocksUntilTxTimeout = 30 # Default +ConfirmPollPeriod = '1s' # Default +FallbackGasPriceULuna = '0.015' # Default +FCDURL = 'http://terra.com' # Example +GasLimitMultiplier = '1.5' # Default +MaxMsgsPerBatch = 100 # Default +OCR2CachePollPeriod = '4s' # Default +OCR2CacheTTL = '1m' # Default +TxMsgTimeout = '10m' # Default +``` + +### ChainID + +```toml +ChainID = 'Bombay-12' # Example +``` + +ChainID is the Terra chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockRate + +```toml +BlockRate = '6s' # Default +``` + +BlockRate is the average time between blocks. + +### BlocksUntilTxTimeout + +```toml +BlocksUntilTxTimeout = 30 # Default +``` + +BlocksUntilTxTimeout is the number of blocks to wait before giving up on the tx getting confirmed. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '1s' # Default +``` + +ConfirmPollPeriod sets how often check for tx confirmation. + +### FallbackGasPriceULuna + +```toml +FallbackGasPriceULuna = '0.015' # Default +``` + +FallbackGasPriceULuna sets a fallback gas price to use when the estimator is not available. + +### FCDURL + +```toml +FCDURL = 'http://terra.com' # Example +``` + +FCDURL sets the FCD URL. + +### GasLimitMultiplier + +```toml +GasLimitMultiplier = '1.5' # Default +``` + +GasLimitMultiplier scales the estimated gas limit. + +### MaxMsgsPerBatch + +```toml +MaxMsgsPerBatch = 100 # Default +``` + +MaxMsgsPerBatch limits the numbers of mesages per transaction batch. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '4s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxMsgTimeout + +```toml +TxMsgTimeout = '10m' # Default +``` + +TxMsgTimeout is the maximum age for resending transaction before they expire. + +## Terra.Nodes + +```toml +[[Terra.Nodes]] +Name = 'primary' # Example +TendermintURL = 'http://tender.mint' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### TendermintURL + +```toml +TendermintURL = 'http://tender.mint' # Example +``` + +TendermintURL is the HTTP(S) tendermint endpoint for this node. diff --git a/src/pages/chainlink-nodes/v1/config/v1_9_0.mdx b/src/pages/chainlink-nodes/v1/config/v1_9_0.mdx new file mode 100644 index 00000000000..aee7f1f4117 --- /dev/null +++ b/src/pages/chainlink-nodes/v1/config/v1_9_0.mdx @@ -0,0 +1,4616 @@ +--- +layout: ../../../../layouts/MainLayout.astro +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +--- + +import { Aside } from "@components" +[//]: # (Documentation generated from docs.toml - DO NOT EDIT.) + +## Table of contents + +- [Global](#Global) +- [Feature](#Feature) +- [Database](#Database) + - [Backup](#Database-Backup) + - [Listener](#Database-Listener) + - [Lock](#Database-Lock) +- [TelemetryIngress](#TelemetryIngress) +- [Log](#Log) +- [WebServer](#WebServer) + - [RateLimit](#WebServer-RateLimit) + - [MFA](#WebServer-MFA) + - [TLS](#WebServer-TLS) +- [JobPipeline](#JobPipeline) +- [FluxMonitor](#FluxMonitor) +- [OCR2](#OCR2) +- [OCR](#OCR) +- [P2P](#P2P) + - [V1](#P2P-V1) + - [V2](#P2P-V2) +- [Keeper](#Keeper) +- [AutoPprof](#AutoPprof) +- [Pyroscope](#Pyroscope) +- [Sentry](#Sentry) +- [EVM](#EVM) + - [BalanceMonitor](#EVM-BalanceMonitor) + - [GasEstimator](#EVM-GasEstimator) + - [BlockHistory](#EVM-GasEstimator-BlockHistory) + - [HeadTracker](#EVM-HeadTracker) + - [KeySpecific](#EVM-KeySpecific) + - [NodePool](#EVM-NodePool) + - [OCR](#EVM-OCR) + - [Nodes](#EVM-Nodes) +- [Solana](#Solana) + - [Nodes](#Solana-Nodes) +- [Starknet](#Starknet) + - [Nodes](#Starknet-Nodes) +- [Terra](#Terra) + - [Nodes](#Terra-Nodes) + +## Global + +```toml +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL for the node to push stats to. + +### InsecureFastScrypt + + + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = false # Default +LogPoller = false # Default +UICSAKeys = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = false # Default +``` + +FeedsManager enables the experimental feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### UICSAKeys + +```toml +UICSAKeys = false # Default +``` + +UICSAKeys enables CSA Keys in the UI. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +MigrateOnStartup = true # Default +ORMMaxIdleConns = 10 # Default +ORMMaxOpenConns = 20 # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for queries to idle in transaction before timing out. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed for a query stuck waiting to take a lock before timing out. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +### ORMMaxIdleConns + +```toml +ORMMaxIdleConns = 10 # Default +``` + +ORMMaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### ORMMaxOpenConns + +```toml +ORMMaxOpenConns = 20 # Default +``` + +ORMMaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use cation when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `$ROOT/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + + + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + + + +```toml +[Database.Lock] +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. + +Because of the complications with advisory locks, Chainlink nodes with v2.0 and later only support `lease` locking mode. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +This setting applies only if `Mode` is set to enable lease locking. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +This setting applies only if Mode is set to enable lease locking. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Default +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Default +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## Log + +```toml +[Log] +DatabaseQueries = false # Default +JSONConsole = false # Default +FileDir = '/my/log/directory' # Example +FileMaxSize = '5120mb' # Default +FileMaxAgeDays = 0 # Default +FileMaxBackups = 1 # Default +UnixTS = false # Default +``` + +### DatabaseQueries + +```toml +DatabaseQueries = false # Default +``` + +DatabaseQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### FileDir + +```toml +FileDir = '/my/log/directory' # Example +``` + +FileDir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### FileMaxSize + +```toml +FileMaxSize = '5120mb' # Default +``` + +FileMaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### FileMaxAgeDays + +```toml +FileMaxAgeDays = 0 # Default +``` + +FileMaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### FileMaxBackups + +```toml +FileMaxBackups = 1 # Default +``` + +FileMaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `FileMaxAgeDays` variable can still cause them to get deleted. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +SessionReaperExpiration = '240h' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + + + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +### SessionReaperExpiration + +```toml +SessionReaperExpiration = '240h' # Default +``` + +SessionReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 42 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 42 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '/home/$USER/.chainlink/tls/server.crt' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '/home/$USER/.chainlink/tls/server.crt' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +## JobPipeline + +```toml +[JobPipeline] +HTTPRequestMaxSize = '32768' # Default +DefaultHTTPRequestTimeout = '15s' # Default +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### HTTPRequestMaxSize + +```toml +HTTPRequestMaxSize = '32768' # Default +``` + +HTTPRequestMaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +### DefaultHTTPRequestTimeout + +```toml +DefaultHTTPRequestTimeout = '15s' # Default +``` + +DefaultHTTPRequestTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + + + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +Enabled = true # Default +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables OCR2 jobs. + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +## OCR + +```toml +[OCR] +Enabled = true # Default +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +This section applies only if you are running off-chain reporting jobs. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables OCR jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +PeerstoreWriteInterval = '5m' # Default +``` + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivityBootstrapCheckInterval = '20s' # Default +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively# DefaultBootstrapPeers is the default set of bootstrap peers. +cheap. We set this to 1 minute during our test.DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + + + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + + + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### PeerstoreWriteInterval + + + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in host:port form as accepted by net.Dial. The addresses should be reachable by peers of interest. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaximumGracePeriod = 100 # Default +RegistryCheckGasOverhead = 200_000 # Default +RegistryPerformGasOverhead = 150_000 # Default +RegistrySyncInterval = '30m' # Default +RegistryMaxPerformDataSize = 5_000 # Default +RegistrySyncUpkeepQueueSize = 10 # Default +TurnLookBack = 1000 # Default +TurnFlagEnabled = false # Default +UpkeepCheckGasPriceEnabled = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaximumGracePeriod + + + +```toml +MaximumGracePeriod = 100 # Default +``` + +MaximumGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### RegistryCheckGasOverhead + + + +```toml +RegistryCheckGasOverhead = 200_000 # Default +``` + +RegistryCheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### RegistryPerformGasOverhead + + + +```toml +RegistryPerformGasOverhead = 150_000 # Default +``` + +RegistryPerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### RegistrySyncInterval + + + +```toml +RegistrySyncInterval = '30m' # Default +``` + +RegistrySyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### RegistryMaxPerformDataSize + + + +```toml +RegistryMaxPerformDataSize = 5_000 # Default +``` + +RegistryMaxPerformDataSize is the max size of perform data. + +### RegistrySyncUpkeepQueueSize + + + +```toml +RegistrySyncUpkeepQueueSize = 10 # Default +``` + +RegistrySyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +### TurnLookBack + +```toml +TurnLookBack = 1000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +### TurnFlagEnabled + +```toml +TurnFlagEnabled = false # Default +``` + +TurnFlagEnabled enables a new algorithm for how keepers take turns. + +### UpkeepCheckGasPriceEnabled + + + +```toml +UpkeepCheckGasPriceEnabled = false # Default +``` + +UpkeepCheckGasPriceEnabled includes gas price in calls to `checkUpkeep()` when set to `true`. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Pyroscope + +```toml +[Pyroscope] +ServerAddress = 'http://localhost:4040' # Example +AuthToken = 'randomly-oauth-generated-token' # Example +Environment = 'mainnet' # Default +``` + +### ServerAddress + +```toml +ServerAddress = 'http://localhost:4040' # Example +``` + +ServerAddress sets the address that will receive the profile logs. It enables the profiling service. + +### AuthToken + +```toml +AuthToken = 'randomly-oauth-generated-token' # Example +``` + +AuthToken sets the needed Auth Token on Server Addresses that require an Auth Token. + +### Environment + +```toml +Environment = 'mainnet' # Default +``` + +Environment sets the target environment tag in which profiles will be added to. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'prod' # Default +Release = 'v1.2.3' # Example +``` + +### Debug + + + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'prod' # Default +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## EVM + +EVM defaults depend on ChainID: + +### Ethereum Mainnet (1) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Ethereum Ropsten (3) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Ethereum Rinkeby (4) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Ethereum Goerli (5) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Optimism Mainnet (10) + +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### RSK Mainnet (30) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### RSK Testnet (31) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Ethereum Kovan (42) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### BSC Mainnet (56) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' +``` + +### OKX Testnet (65) + +```toml +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### OKX Mainnet (66) + +```toml +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Optimism Kovan (69) + +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### xDai Mainnet (100) + +```toml +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 100 +LogPollInterval = '5s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Heco Mainnet (128) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' +``` + +### Polygon Mainnet (137) + +```toml +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 5000 +MinIncomingConfirmations = 5 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '200 micro' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Fantom Mainnet (250) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Optimism Goerli (420) + +```toml +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0xdc2CC710e42857672E7907CF474a69B63B93089f' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '15s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Metis Rinkeby (588) + +```toml +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Metis Mainnet (1088) + +```toml +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Simulated (1337) + +```toml +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '100' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '0s' +TxResendAfterThreshold = '0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 micro' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 100 +SamplingInterval = '0s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Fantom Testnet (4002) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Arbitrum Mainnet (42161) + +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '1 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Avalanche Fuji (43113) + +```toml +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '1 micro' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Avalanche Mainnet (43114) + +```toml +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '1 micro' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Polygon Mumbai (80001) + +```toml +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 5000 +MinIncomingConfirmations = 5 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '200 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Arbitrum Rinkeby (421611) + +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '1 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Arbitrum Goerli (421613) + +```toml +ChainType = 'arbitrum' +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '1 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Ethereum Sepolia (11155111) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0xb227f007804c16546Bd054dfED2E7A1fD5437678' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 3 +MinimumContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Harmony Mainnet (1666600000) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### Harmony Testnet (1666700000) + +```toml +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +MaxInFlightTransactions = 16 +MaxQueuedTransactions = 250 +MinIncomingConfirmations = 1 +MinimumContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 +TxReaperInterval = '1h0m0s' +TxReaperThreshold = '168h0m0s' +TxResendAfterThreshold = '1m0s' +UseForwarders = false + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '100 micro' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMinimum = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' +``` + +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockBackfillDepth + + + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'Optimism' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + + + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + + + +```toml +LogBackfillBatchSize = 100 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + + + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### MaxInFlightTransactions + +```toml +MaxInFlightTransactions = 16 # Default +``` + +MaxInFlightTransactions controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueuedTransactions + +```toml +MaxQueuedTransactions = 250 # Default +``` + +MaxQueuedTransactions is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### MinimumContractPayment + +```toml +MinimumContractPayment = '10000000000000 juels' # Default +``` + +MinimumContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before `NodePool` marks rpc endpoints as +out-of-sync, and `HeadTracker` logs warnings. + +Set to zero to disable out-of-sync checking. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 100 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### RPCBlockQueryDelay + + + +```toml +RPCBlockQueryDelay = 1 # Default +``` + +RPCBlockQueryDelay controls the number of blocks to trail behind head in the block history estimator and balance monitor. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +### TxReaperInterval + +```toml +TxReaperInterval = '1h' # Default +``` + +TxReaperInterval controls how often the EthTx reaper will run. + +### TxReaperThreshold + +```toml +TxReaperThreshold = '168h' # Default +``` + +TxReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### TxResendAfterThreshold + +```toml +TxResendAfterThreshold = '1m' # Default +``` + +TxResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +### UseForwarders + +```toml +UseForwarders = false # Default +``` + +UseForwarders enables or disables sending transactions through forwarder contracts. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '100 micro' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitMax = 500_000 # Default +LimitOCRJobType = 100_000 # Example +LimitDRJobType = 100_000 # Example +LimitVRFJobType = 100_000 # Example +LimitFMJobType = 100_000 # Example +LimitKeeperJobType = 100_000 # Example +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 10 # Default +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMinimum = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `L2Suggested` + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '100 micro' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitMax + +```toml +LimitMax = 500_000 # Default +``` + +LimitMax sets a maximum for _estimated_ gas limits. This currently only applies to `Arbitrum` `GasEstimatorMode`. + +### LimitOCRJobType + +```toml +LimitOCRJobType = 100_000 # Example +``` + +LimitOCRJobType overrides LimitDefault for OCR jobs. + +### LimitDRJobType + +```toml +LimitDRJobType = 100_000 # Example +``` + +LimitDRJobType overrides LimitDefault for Direct Request jobs. + +### LimitVRFJobType + +```toml +LimitVRFJobType = 100_000 # Example +``` + +LimitVRFJobType overrides LimitDefault for VRF jobs. + +### LimitFMJobType + +```toml +LimitFMJobType = 100_000 # Example +``` + +LimitFMJobType overrides LimitDefault for Flux Monitor jobs. + +### LimitKeeperJobType + +```toml +LimitKeeperJobType = 100_000 # Example +``` + +LimitKeeperJobType overrides LimitDefault for Keeper jobs. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes Optimism L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 10 # Default +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=MaxGasPriceWei` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=MaxGasPriceWei` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap=current block base fee * (1.125 ^ N)` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMinWei` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMaxWei` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMinimum + +```toml +TipCapMinimum = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 4 # Default +BlockHistorySize = 8 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 4 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### EIP1559FeeCapBufferBlocks + + + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +The head tracker continually listens for new heads from the chain. + +In addition to these settings, it log warnings if `EVM.NoNewHeadsThreshold` is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + + + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMaxWei. + +## EVM.NodePool + +```toml +[EVM.NodePool] +PollFailureThreshold = 3 # Default +PollInterval = '10s' # Default +SelectionMode = 'HighestHead' # Default +``` + +The node pool manages multiple RPC endpoints. + +In addition to these settings, `EVM.NoNewHeadsThreshold` controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 3 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +### SelectionMode + +```toml +SelectionMode = 'HighestHead' # Default +``` + +SelectionMode controls node selection strategy: HighestHead or RoundRobin. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +ObservationTimeout = '1m' # Example +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +### ObservationTimeout + +```toml +ObservationTimeout = '1m' # Example +``` + +ObservationTimeout sets `OCR.ObservationTimeout` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Recommended for primary nodes. Required for `SendOnly`. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1h' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1h' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Starknet + +```toml +[[Starknet]] +ChainID = 'foobar' # Example +Enabled = true # Default +OCR2CachePollPeriod = '5s' # Default +OCR2CacheTTL = '1m' # Default +RequestTimeout = '10s' # Default +TxTimeout = '1m' # Default +TxSendFrequency = '5s' # Default +TxMaxBatchSize = 100 # Default +``` + +### ChainID + +```toml +ChainID = 'foobar' # Example +``` + +ChainID is the Starknet chain ID. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '5s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### RequestTimeout + +```toml +RequestTimeout = '10s' # Default +``` + +RequestTimeout is the RPC client timeout. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxSendFrequency + +```toml +TxSendFrequency = '5s' # Default +``` + +TxSendFrequency is how often to broadcast batches of txes. + +### TxMaxBatchSize + +```toml +TxMaxBatchSize = 100 # Default +``` + +TxMaxBatchSize limits the size of tx batches. + +## Starknet.Nodes + +```toml +[[Starknet.Nodes]] +Name = 'primary' # Example +URL = 'http://stark.node' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://stark.node' # Example +``` + +URL is the base HTTP(S) endpoint for this node. + +## Terra + +```toml +[[Terra]] +ChainID = 'Bombay-12' # Example +Enabled = true # Default +BlockRate = '6s' # Default +BlocksUntilTxTimeout = 30 # Default +ConfirmPollPeriod = '1s' # Default +FallbackGasPriceULuna = '0.015' # Default +FCDURL = 'http://terra.com' # Example +GasLimitMultiplier = '1.5' # Default +MaxMsgsPerBatch = 100 # Default +OCR2CachePollPeriod = '4s' # Default +OCR2CacheTTL = '1m' # Default +TxMsgTimeout = '10m' # Default +``` + +### ChainID + +```toml +ChainID = 'Bombay-12' # Example +``` + +ChainID is the Terra chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockRate + +```toml +BlockRate = '6s' # Default +``` + +BlockRate is the average time between blocks. + +### BlocksUntilTxTimeout + +```toml +BlocksUntilTxTimeout = 30 # Default +``` + +BlocksUntilTxTimeout is the number of blocks to wait before giving up on the tx getting confirmed. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '1s' # Default +``` + +ConfirmPollPeriod sets how often check for tx confirmation. + +### FallbackGasPriceULuna + +```toml +FallbackGasPriceULuna = '0.015' # Default +``` + +FallbackGasPriceULuna sets a fallback gas price to use when the estimator is not available. + +### FCDURL + +```toml +FCDURL = 'http://terra.com' # Example +``` + +FCDURL sets the FCD URL. + +### GasLimitMultiplier + +```toml +GasLimitMultiplier = '1.5' # Default +``` + +GasLimitMultiplier scales the estimated gas limit. + +### MaxMsgsPerBatch + +```toml +MaxMsgsPerBatch = 100 # Default +``` + +MaxMsgsPerBatch limits the numbers of mesages per transaction batch. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '4s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxMsgTimeout + +```toml +TxMsgTimeout = '10m' # Default +``` + +TxMsgTimeout is the maximum age for resending transaction before they expire. + +## Terra.Nodes + +```toml +[[Terra.Nodes]] +Name = 'primary' # Example +TendermintURL = 'http://tender.mint' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### TendermintURL + +```toml +TendermintURL = 'http://tender.mint' # Example +``` + +TendermintURL is the HTTP(S) tendermint endpoint for this node. diff --git a/src/pages/chainlink-nodes/v2/config/index.mdx b/src/pages/chainlink-nodes/v2/config/index.mdx new file mode 100644 index 00000000000..12dafb8649a --- /dev/null +++ b/src/pages/chainlink-nodes/v2/config/index.mdx @@ -0,0 +1,29 @@ +--- +layout: ../../../../layouts/MainLayout.astro +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +--- + +**Topics** + +- [v2.3.0](/chainlink-nodes/v2/config/v2_3_0) +- [v2.2.0](/chainlink-nodes/v2/config/v2_2_0) +- [v2.1.0](/chainlink-nodes/v2/config/v2_1_0) +- [v2.0.0](/chainlink-nodes/v2/config/v2_0_0) +- [v2.3.0](/chainlink-nodes/v2/config/v2_3_0) +- [v2.2.0](/chainlink-nodes/v2/config/v2_2_0) +- [v2.1.0](/chainlink-nodes/v2/config/v2_1_0) +- [v2.0.0](/chainlink-nodes/v2/config/v2_0_0) +- [v2.3.0](/chainlink-nodes/v2/config/v2_3_0) +- [v2.2.0](/chainlink-nodes/v2/config/v2_2_0) +- [v2.1.0](/chainlink-nodes/v2/config/v2_1_0) +- [v2.0.0](/chainlink-nodes/v2/config/v2_0_0) +- [v2.3.0](/chainlink-nodes/v2/config/v2_3_0) +- [v2.2.0](/chainlink-nodes/v2/config/v2_2_0) +- [v2.1.0](/chainlink-nodes/v2/config/v2_1_0) +- [v2.0.0](/chainlink-nodes/v2/config/v2_0_0) +- [v2.3.0](/chainlink-nodes/v2/config/v2_3_0) +- [v2.2.0](/chainlink-nodes/v2/config/v2_2_0) +- [v2.1.0](/chainlink-nodes/v2/config/v2_1_0) +- [v2.0.0](/chainlink-nodes/v2/config/v2_0_0) diff --git a/src/pages/chainlink-nodes/v2/config/v2_0_0.mdx b/src/pages/chainlink-nodes/v2/config/v2_0_0.mdx new file mode 100644 index 00000000000..8861484c093 --- /dev/null +++ b/src/pages/chainlink-nodes/v2/config/v2_0_0.mdx @@ -0,0 +1,5394 @@ +--- +layout: ../../../../layouts/MainLayout.astro +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +--- + +import { Aside } from "@components" + +This document describes the TOML format for configuration. + +See also [SECRETS.md](SECRETS.md) + +## Example + +```toml +Log.Level = 'debug' + +[[EVM]] +ChainID = '1' # Required + +[[EVM.Nodes]] +Name = 'fake' # Required +WSURL = 'wss://foo.bar/ws' +HTTPURL = 'https://foo.bar' # Required +``` + +## Global + +```toml +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL used by the node to push stats. This variable is required to deliver telemetry. + +### InsecureFastScrypt + + + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = true # Default +LogPoller = false # Default +UICSAKeys = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = true # Default +``` + +FeedsManager enables the feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### UICSAKeys + +```toml +UICSAKeys = false # Default +``` + +UICSAKeys enables CSA Keys in the UI. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +LogQueries = false # Default +MaxIdleConns = 10 # Default +MaxOpenConns = 20 # Default +MigrateOnStartup = true # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for a transaction to be open and idle before timing out. See Postgres `idle_in_transaction_session_timeout` for more details. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed to wait for database lock of any kind before timing out. See Postgres `lock_timeout` for more details. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### LogQueries + +```toml +LogQueries = false # Default +``` + +LogQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### MaxIdleConns + +```toml +MaxIdleConns = 10 # Default +``` + +MaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use caution when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MaxOpenConns + +```toml +MaxOpenConns = 20 # Default +``` + +MaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use caution when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `'Dir'/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + + + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + + + +```toml +[Database.Lock] +Enabled = true # Default +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. + +Because of the complications with advisory locks, Chainlink nodes with v2.0 and later only support `lease` locking mode. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables the database lock. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Example +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Example +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## AuditLogger + +```toml +[AuditLogger] +Enabled = false # Default +ForwardToUrl = 'http://localhost:9898' # Example +JsonWrapperKey = 'event' # Example +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled determines if this logger should be configured at all + +### ForwardToUrl + +```toml +ForwardToUrl = 'http://localhost:9898' # Example +``` + +ForwardToUrl is where you want to forward logs to + +### JsonWrapperKey + +```toml +JsonWrapperKey = 'event' # Example +``` + +JsonWrapperKey if set wraps the map of data under another single key to make parsing easier + +### Headers + +```toml +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +Headers is the set of headers you wish to pass along with each request + +## Log + +```toml +[Log] +Level = 'info' # Default +JSONConsole = false # Default +UnixTS = false # Default +``` + +### Level + +```toml +Level = 'info' # Default +``` + +Level determines both what is printed on the screen and what is written to the log file. + +The available levels are: + +- "debug": Useful for forensic debugging of issues. +- "info": High-level informational messages. (default) +- "warn": A mild error occurred that might require non-urgent action. Check these warnings semi-regularly to see if any of them require attention. These warnings usually happen due to factors outside of the control of the node operator. Examples: Unexpected responses from a remote API or misleading networking errors. +- "error": An unexpected error occurred during the regular operation of a well-maintained node. Node operators might need to take action to remedy this error. Check these regularly to see if any of them require attention. Examples: Use of deprecated configuration options or incorrectly configured settings that cause a job to fail. +- "crit": A critical error occurred. The node might be unable to function. Node operators should take immediate action to fix these errors. Examples: The node could not boot because a network socket could not be opened or the database became inaccessible. +- "panic": An exceptional error occurred that could not be handled. If the node is unresponsive, node operators should try to restart their nodes and notify the Chainlink team of a potential bug. +- "fatal": The node encountered an unrecoverable problem and had to exit. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## Log.File + +```toml +[Log.File] +Dir = '/my/log/directory' # Example +MaxSize = '5120mb' # Default +MaxAgeDays = 0 # Default +MaxBackups = 1 # Default +``` + +### Dir + +```toml +Dir = '/my/log/directory' # Example +``` + +Dir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### MaxSize + +```toml +MaxSize = '5120mb' # Default +``` + +MaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### MaxAgeDays + +```toml +MaxAgeDays = 0 # Default +``` + +MaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### MaxBackups + +```toml +MaxBackups = 1 # Default +``` + +MaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `MaxAgeDays` variable can still cause them to get deleted. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeCacheTTL = '0s' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +SessionReaperExpiration = '240h' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeCacheTTL + +```toml +BridgeCacheTTL = '0s' # Default +``` + +BridgeCacheTTL controls the cache TTL for all bridge tasks to use old values in newer observations in case of intermittent failure. It's disabled by default. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + + + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +### SessionReaperExpiration + +```toml +SessionReaperExpiration = '240h' # Default +``` + +SessionReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 1000 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 1000 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '~/.cl/certs' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '~/.cl/certs' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +## JobPipeline + +```toml +[JobPipeline] +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +MaxSuccessfulRuns = 10000 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### MaxSuccessfulRuns + +```toml +MaxSuccessfulRuns = 10000 # Default +``` + +MaxSuccessfulRuns caps the number of completed successful runs per pipeline +spec in the database. You can set it to zero as a performance optimisation; +this will avoid saving any successful run. + +Note this is not a hard cap, it can drift slightly larger than this but not +by more than 5% or so. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + + + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## JobPipeline.HTTPRequest + +```toml +[JobPipeline.HTTPRequest] +DefaultTimeout = '15s' # Default +MaxSize = '32768' # Default +``` + +### DefaultTimeout + +```toml +DefaultTimeout = '15s' # Default +``` + +DefaultTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### MaxSize + +```toml +MaxSize = '32768' # Default +``` + +MaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +Enabled = false # Default +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +CaptureEATelemetry = false # Default +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR2 jobs. + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +### CaptureEATelemetry + +```toml +CaptureEATelemetry = false # Default +``` + +CaptureEATelemetry toggles collecting extra information from External Adaptares + +## OCR + +```toml +[OCR] +Enabled = false # Default +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +CaptureEATelemetry = false # Default +``` + +This section applies only if you are running off-chain reporting jobs. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +### CaptureEATelemetry + +```toml +CaptureEATelemetry = false # Default +``` + +CaptureEATelemetry toggles collecting extra information from External Adaptares + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +Enabled = true # Default +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerstoreWriteInterval = '5m' # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables P2P V1. + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivity +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively +cheap. We set this to 1 minute during our test. + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + + + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + + + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerstoreWriteInterval + + + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +Enabled = false # Default +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables P2P V2. +Note: V1.Enabled is true by default, so it must be set false in order to run V2 only. + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in `host:port` form as accepted by the TCP version of Go’s `net.Dial`. +The addresses should be reachable by other nodes on the network. When attempting to connect to another node, +a node will attempt to dial all of the other node’s AnnounceAddresses in round-robin fashion. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +Oracle nodes typically only know each other’s PeerIDs, but not their hostnames, IP addresses, or ports. +DefaultBootstrappers are special nodes that help other nodes discover each other’s `AnnounceAddresses` so they can communicate. +Nodes continuously attempt to connect to bootstrappers configured in here. When a node wants to connect to another node +(which it knows only by PeerID, but not by address), it discovers the other node’s AnnounceAddresses from communications +received from its DefaultBootstrappers or other discovered nodes. To facilitate discovery, +nodes will regularly broadcast signed announcements containing their PeerID and AnnounceAddresses. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, +but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaxGracePeriod = 100 # Default +TurnLookBack = 1_000 # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + + + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + + + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + + + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaxGracePeriod + + + +```toml +MaxGracePeriod = 100 # Default +``` + +MaxGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### TurnLookBack + +```toml +TurnLookBack = 1_000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +## Keeper.Registry + +```toml +[Keeper.Registry] +CheckGasOverhead = 200_000 # Default +PerformGasOverhead = 300_000 # Default +SyncInterval = '30m' # Default +MaxPerformDataSize = 5_000 # Default +SyncUpkeepQueueSize = 10 # Default +``` + +### CheckGasOverhead + + + +```toml +CheckGasOverhead = 200_000 # Default +``` + +CheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### PerformGasOverhead + + + +```toml +PerformGasOverhead = 300_000 # Default +``` + +PerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### SyncInterval + + + +```toml +SyncInterval = '30m' # Default +``` + +SyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### MaxPerformDataSize + + + +```toml +MaxPerformDataSize = 5_000 # Default +``` + +MaxPerformDataSize is the max size of perform data. + +### SyncUpkeepQueueSize + + + +```toml +SyncUpkeepQueueSize = 10 # Default +``` + +SyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Pyroscope + +```toml +[Pyroscope] +ServerAddress = 'http://localhost:4040' # Example +Environment = 'mainnet' # Default +``` + +### ServerAddress + +```toml +ServerAddress = 'http://localhost:4040' # Example +``` + +ServerAddress sets the address that will receive the profile logs. It enables the profiling service. + +### Environment + +```toml +Environment = 'mainnet' # Default +``` + +Environment sets the target environment tag in which profiles will be added to. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'my-custom-env' # Example +Release = 'v1.2.3' # Example +``` + +### Debug + + + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'my-custom-env' # Example +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## EVM + +EVM defaults depend on ChainID: + +### Ethereum Mainnet (1) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Ropsten (3) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Rinkeby (4) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Goerli (5) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Mainnet (10) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### RSK Mainnet (30) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### RSK Testnet (31) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Kovan (42) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### BSC Mainnet (56) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Testnet (65) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Mainnet (66) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Kovan (69) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### xDai Mainnet (100) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 100 +LogPollInterval = '5s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Heco Mainnet (128) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mainnet (137) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Mainnet (250) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 3800000 +``` + +### Optimism Goerli (420) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimismBedrock' +FinalityDepth = 200 +LinkContractAddress = '0xdc2CC710e42857672E7907CF474a69B63B93089f' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '1m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '30s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 wei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 300 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### Metis Rinkeby (588) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Klaytn Testnet (1001) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Metis Mainnet (1088) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Simulated (1337) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '100' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '0s' +ResendAfterThreshold = '0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 100 +SamplingInterval = '0s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Testnet (4002) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 3800000 +``` + +### Klaytn Mainnet (8217) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Mainnet (42161) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Fuji (43113) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Mainnet (43114) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mumbai (80001) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Rinkeby (421611) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Goerli (421613) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xd14838A68E8AFBAdE5efb411d5871ea0011AFd28' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Sepolia (11155111) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xb227f007804c16546Bd054dfED2E7A1fD5437678' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Mainnet (1666600000) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Testnet (1666700000) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### AutoCreateKey + +```toml +AutoCreateKey = true # Default +``` + +AutoCreateKey, if set to true, will ensure that there is always at least one transmit key for the given chain. + +### BlockBackfillDepth + + + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'Optimism' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + + + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + + + +```toml +LogBackfillBatchSize = 100 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + + + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### LogKeepBlocksDepth + + + +```toml +LogKeepBlocksDepth = 100000 # Default +``` + +LogKeepBlocksDepth works in conjunction with Feature.LogPoller. Controls how many blocks the poller will keep, must be greater than FinalityDepth+1. + +### MinContractPayment + +```toml +MinContractPayment = '10000000000000 juels' # Default +``` + +MinContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before `NodePool` marks rpc endpoints as +out-of-sync, and `HeadTracker` logs warnings. + +Set to zero to disable out-of-sync checking. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 100 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### RPCBlockQueryDelay + + + +```toml +RPCBlockQueryDelay = 1 # Default +``` + +RPCBlockQueryDelay controls the number of blocks to trail behind head in the block history estimator and balance monitor. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +## EVM.Transactions + +```toml +[EVM.Transactions] +ForwardersEnabled = false # Default +MaxInFlight = 16 # Default +MaxQueued = 250 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '168h' # Default +ResendAfterThreshold = '1m' # Default +``` + +### ForwardersEnabled + +```toml +ForwardersEnabled = false # Default +``` + +ForwardersEnabled enables or disables sending transactions through forwarder contracts. + +### MaxInFlight + +```toml +MaxInFlight = 16 # Default +``` + +MaxInFlight controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueued + +```toml +MaxQueued = 250 # Default +``` + +MaxQueued is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the EthTx reaper will run. + +### ReaperThreshold + +```toml +ReaperThreshold = '168h' # Default +``` + +ReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### ResendAfterThreshold + +```toml +ResendAfterThreshold = '1m' # Default +``` + +ResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitMax = 500_000 # Default +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 10 # Default +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMin = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `Optimism2`/`L2Suggested` is a special mode only for use with Optimism and Metis blockchains. This mode will use the gas price suggested by the rpc endpoint via `eth_gasPrice`. +- `Arbitrum` is a special mode only for use with Arbitrum blockchains. It uses the suggested gas price (up to `ETH_MAX_GAS_PRICE_WEI`, with `1000 gwei` default) as well as an estimated gas limit (up to `ETH_GAS_LIMIT_MAX`, with `1,000,000,000` default). + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. +This applies to both legacy and EIP1559 transactions. +Note that it is impossible to disable the maximum limit. Setting this value to zero will prevent paying anything for any transaction (which can be useful in some rare cases). +Most chains by default have the maximum set to 2\*\*256-1 Wei which is the maximum allowed gas price on EVM-compatible chains, and is so large it may as well be unlimited. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitMax + +```toml +LimitMax = 500_000 # Default +``` + +LimitMax sets a maximum for _estimated_ gas limits. This currently only applies to `Arbitrum` `GasEstimatorMode`. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes Optimism L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 10 # Default +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap = ( current block base fee * (1.125 ^ N) + tipcap )` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMin` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMax` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMin + +```toml +TipCapMin = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.LimitJobType + +```toml +[EVM.GasEstimator.LimitJobType] +OCR = 100_000 # Example +DR = 100_000 # Example +VRF = 100_000 # Example +FM = 100_000 # Example +Keeper = 100_000 # Example +``` + +### OCR + +```toml +OCR = 100_000 # Example +``` + +OCR overrides LimitDefault for OCR jobs. + +### DR + +```toml +DR = 100_000 # Example +``` + +DR overrides LimitDefault for Direct Request jobs. + +### VRF + +```toml +VRF = 100_000 # Example +``` + +VRF overrides LimitDefault for VRF jobs. + +### FM + +```toml +FM = 100_000 # Example +``` + +FM overrides LimitDefault for Flux Monitor jobs. + +### Keeper + +```toml +Keeper = 100_000 # Example +``` + +Keeper overrides LimitDefault for Keeper jobs. + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 4 # Default +BlockHistorySize = 8 # Default +CheckInclusionBlocks = 12 # Default +CheckInclusionPercentile = 90 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 4 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### CheckInclusionBlocks + +```toml +CheckInclusionBlocks = 12 # Default +``` + +CheckInclusionBlocks is the number of recent blocks to use to detect if there is a transaction propagation/connectivity issue, and to prevent bumping in these cases. +This can help avoid the situation where RPC nodes are not propagating transactions for some non-price-related reason (e.g. go-ethereum bug, networking issue etc) and bumping gas would not help. + +Set to zero to disable connectivity checking completely. + +### CheckInclusionPercentile + +```toml +CheckInclusionPercentile = 90 # Default +``` + +CheckInclusionPercentile controls the percentile that a transaction must have been higher than for all the blocks in the inclusion check window in order to register as a connectivity issue. + +For example, if CheckInclusionBlocks=12 and CheckInclusionPercentile=90 then further bumping will be prevented for any transaction with any attempt that has a higher price than the 90th percentile for the most recent 12 blocks. + +### EIP1559FeeCapBufferBlocks + + + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +The head tracker continually listens for new heads from the chain. + +In addition to these settings, it log warnings if `EVM.NoNewHeadsThreshold` is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + + + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMax. + +## EVM.NodePool + +```toml +[EVM.NodePool] +PollFailureThreshold = 5 # Default +PollInterval = '10s' # Default +SelectionMode = 'HighestHead' # Default +SyncThreshold = 5 # Default +``` + +The node pool manages multiple RPC endpoints. + +In addition to these settings, `EVM.NoNewHeadsThreshold` controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 5 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +### SelectionMode + +```toml +SelectionMode = 'HighestHead' # Default +``` + +SelectionMode controls node selection strategy: + +- HighestHead: use the node with the highest head number +- RoundRobin: rotate through nodes, per-request +- TotalDifficulty: use the node with the greatest total difficulty + +### SyncThreshold + +```toml +SyncThreshold = 5 # Default +``` + +SyncThreshold controls how far a node may lag behind the best node before being marked out-of-sync. +Depending on `SelectionMode`, this represents a difference in the number of blocks (`HighestHead`, `RoundRobin`), or total difficulty (`TotalDifficulty`). + +Set to 0 to disable this check. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Required for all nodes. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +## EVM.OCR2.Automation + +```toml +[EVM.OCR2.Automation] +GasLimit = 5300000 # Default +``` + +### GasLimit + +```toml +GasLimit = 5300000 # Default +``` + +GasLimit controls the gas limit for transmit transactions from ocr2automation job. + +## Cosmos + +```toml +[[Cosmos]] +ChainID = 'Malaga-420' # Example +Enabled = true # Default +BlockRate = '6s' # Default +BlocksUntilTxTimeout = 30 # Default +ConfirmPollPeriod = '1s' # Default +FallbackGasPriceUAtom = '0.015' # Default +FCDURL = 'http://cosmos.com' # Example +GasLimitMultiplier = '1.5' # Default +MaxMsgsPerBatch = 100 # Default +OCR2CachePollPeriod = '4s' # Default +OCR2CacheTTL = '1m' # Default +TxMsgTimeout = '10m' # Default +``` + +### ChainID + +```toml +ChainID = 'Malaga-420' # Example +``` + +ChainID is the Cosmos chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockRate + +```toml +BlockRate = '6s' # Default +``` + +BlockRate is the average time between blocks. + +### BlocksUntilTxTimeout + +```toml +BlocksUntilTxTimeout = 30 # Default +``` + +BlocksUntilTxTimeout is the number of blocks to wait before giving up on the tx getting confirmed. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '1s' # Default +``` + +ConfirmPollPeriod sets how often check for tx confirmation. + +### FallbackGasPriceUAtom + +```toml +FallbackGasPriceUAtom = '0.015' # Default +``` + +FallbackGasPriceUAtom sets a fallback gas price to use when the estimator is not available. + +### FCDURL + +```toml +FCDURL = 'http://cosmos.com' # Example +``` + +FCDURL sets the FCD (Full Client Daemon) URL. + +### GasLimitMultiplier + +```toml +GasLimitMultiplier = '1.5' # Default +``` + +GasLimitMultiplier scales the estimated gas limit. + +### MaxMsgsPerBatch + +```toml +MaxMsgsPerBatch = 100 # Default +``` + +MaxMsgsPerBatch limits the numbers of mesages per transaction batch. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '4s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxMsgTimeout + +```toml +TxMsgTimeout = '10m' # Default +``` + +TxMsgTimeout is the maximum age for resending transaction before they expire. + +## Cosmos.Nodes + +```toml +[[Cosmos.Nodes]] +Name = 'primary' # Example +TendermintURL = 'http://tender.mint' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### TendermintURL + +```toml +TendermintURL = 'http://tender.mint' # Example +``` + +TendermintURL is the HTTP(S) tendermint endpoint for this node. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1m' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +FeeEstimatorMode = 'fixed' # Default +ComputeUnitPriceMax = 1000 # Default +ComputeUnitPriceMin = 0 # Default +ComputeUnitPriceDefault = 0 # Default +FeeBumpPeriod = '3s' # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +### FeeEstimatorMode + +```toml +FeeEstimatorMode = 'fixed' # Default +``` + +FeeEstimatorMode is the method used to determine the base fee + +### ComputeUnitPriceMax + +```toml +ComputeUnitPriceMax = 1000 # Default +``` + +ComputeUnitPriceMax is the maximum price per compute unit that a transaction can be bumped to + +### ComputeUnitPriceMin + +```toml +ComputeUnitPriceMin = 0 # Default +``` + +ComputeUnitPriceMin is the minimum price per compute unit that transaction can have + +### ComputeUnitPriceDefault + +```toml +ComputeUnitPriceDefault = 0 # Default +``` + +ComputeUnitPriceDefault is the default price per compute unit price, and the starting base fee when FeeEstimatorMode = 'fixed' + +### FeeBumpPeriod + +```toml +FeeBumpPeriod = '3s' # Default +``` + +FeeBumpPeriod is the amount of time before a tx is retried with a fee bump + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Starknet + +```toml +[[Starknet]] +ChainID = 'foobar' # Example +Enabled = true # Default +OCR2CachePollPeriod = '5s' # Default +OCR2CacheTTL = '1m' # Default +RequestTimeout = '10s' # Default +TxTimeout = '1m' # Default +TxSendFrequency = '5s' # Default +TxMaxBatchSize = 100 # Default +``` + +### ChainID + +```toml +ChainID = 'foobar' # Example +``` + +ChainID is the Starknet chain ID. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '5s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### RequestTimeout + +```toml +RequestTimeout = '10s' # Default +``` + +RequestTimeout is the RPC client timeout. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxSendFrequency + +```toml +TxSendFrequency = '5s' # Default +``` + +TxSendFrequency is how often to broadcast batches of txes. + +### TxMaxBatchSize + +```toml +TxMaxBatchSize = 100 # Default +``` + +TxMaxBatchSize limits the size of tx batches. + +## Starknet.Nodes + +```toml +[[Starknet.Nodes]] +Name = 'primary' # Example +URL = 'http://stark.node' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://stark.node' # Example +``` + +URL is the base HTTP(S) endpoint for this node. diff --git a/src/pages/chainlink-nodes/v2/config/v2_1_0.mdx b/src/pages/chainlink-nodes/v2/config/v2_1_0.mdx new file mode 100644 index 00000000000..c10e3f11e2a --- /dev/null +++ b/src/pages/chainlink-nodes/v2/config/v2_1_0.mdx @@ -0,0 +1,5440 @@ +--- +layout: ../../../../layouts/MainLayout.astro +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +--- + +import { Aside } from "@components" + +This document describes the TOML format for configuration. + +See also [SECRETS.md](SECRETS.md) + +## Example + +```toml +Log.Level = 'debug' + +[[EVM]] +ChainID = '1' # Required + +[[EVM.Nodes]] +Name = 'fake' # Required +WSURL = 'wss://foo.bar/ws' +HTTPURL = 'https://foo.bar' # Required +``` + +## Global + +```toml +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL used by the node to push stats. This variable is required to deliver telemetry. + +### InsecureFastScrypt + + + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = true # Default +LogPoller = false # Default +UICSAKeys = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = true # Default +``` + +FeedsManager enables the feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### UICSAKeys + +```toml +UICSAKeys = false # Default +``` + +UICSAKeys enables CSA Keys in the UI. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +LogQueries = false # Default +MaxIdleConns = 10 # Default +MaxOpenConns = 20 # Default +MigrateOnStartup = true # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for a transaction to be open and idle before timing out. See Postgres `idle_in_transaction_session_timeout` for more details. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed to wait for database lock of any kind before timing out. See Postgres `lock_timeout` for more details. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### LogQueries + +```toml +LogQueries = false # Default +``` + +LogQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### MaxIdleConns + +```toml +MaxIdleConns = 10 # Default +``` + +MaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use caution when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MaxOpenConns + +```toml +MaxOpenConns = 20 # Default +``` + +MaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use caution when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `'Dir'/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + + + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + + + +```toml +[Database.Lock] +Enabled = true # Default +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. + +Because of the complications with advisory locks, Chainlink nodes with v2.0 and later only support `lease` locking mode. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables the database lock. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Example +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Example +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## AuditLogger + +```toml +[AuditLogger] +Enabled = false # Default +ForwardToUrl = 'http://localhost:9898' # Example +JsonWrapperKey = 'event' # Example +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled determines if this logger should be configured at all + +### ForwardToUrl + +```toml +ForwardToUrl = 'http://localhost:9898' # Example +``` + +ForwardToUrl is where you want to forward logs to + +### JsonWrapperKey + +```toml +JsonWrapperKey = 'event' # Example +``` + +JsonWrapperKey if set wraps the map of data under another single key to make parsing easier + +### Headers + +```toml +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +Headers is the set of headers you wish to pass along with each request + +## Log + +```toml +[Log] +Level = 'info' # Default +JSONConsole = false # Default +UnixTS = false # Default +``` + +### Level + +```toml +Level = 'info' # Default +``` + +Level determines both what is printed on the screen and what is written to the log file. + +The available levels are: + +- "debug": Useful for forensic debugging of issues. +- "info": High-level informational messages. (default) +- "warn": A mild error occurred that might require non-urgent action. Check these warnings semi-regularly to see if any of them require attention. These warnings usually happen due to factors outside of the control of the node operator. Examples: Unexpected responses from a remote API or misleading networking errors. +- "error": An unexpected error occurred during the regular operation of a well-maintained node. Node operators might need to take action to remedy this error. Check these regularly to see if any of them require attention. Examples: Use of deprecated configuration options or incorrectly configured settings that cause a job to fail. +- "crit": A critical error occurred. The node might be unable to function. Node operators should take immediate action to fix these errors. Examples: The node could not boot because a network socket could not be opened or the database became inaccessible. +- "panic": An exceptional error occurred that could not be handled. If the node is unresponsive, node operators should try to restart their nodes and notify the Chainlink team of a potential bug. +- "fatal": The node encountered an unrecoverable problem and had to exit. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## Log.File + +```toml +[Log.File] +Dir = '/my/log/directory' # Example +MaxSize = '5120mb' # Default +MaxAgeDays = 0 # Default +MaxBackups = 1 # Default +``` + +### Dir + +```toml +Dir = '/my/log/directory' # Example +``` + +Dir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### MaxSize + +```toml +MaxSize = '5120mb' # Default +``` + +MaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### MaxAgeDays + +```toml +MaxAgeDays = 0 # Default +``` + +MaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### MaxBackups + +```toml +MaxBackups = 1 # Default +``` + +MaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `MaxAgeDays` variable can still cause them to get deleted. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeCacheTTL = '0s' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +SessionReaperExpiration = '240h' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeCacheTTL + +```toml +BridgeCacheTTL = '0s' # Default +``` + +BridgeCacheTTL controls the cache TTL for all bridge tasks to use old values in newer observations in case of intermittent failure. It's disabled by default. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + + + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +### SessionReaperExpiration + +```toml +SessionReaperExpiration = '240h' # Default +``` + +SessionReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 1000 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 1000 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '~/.cl/certs' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '~/.cl/certs' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +## JobPipeline + +```toml +[JobPipeline] +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +MaxSuccessfulRuns = 10000 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### MaxSuccessfulRuns + +```toml +MaxSuccessfulRuns = 10000 # Default +``` + +MaxSuccessfulRuns caps the number of completed successful runs per pipeline +spec in the database. You can set it to zero as a performance optimisation; +this will avoid saving any successful run. + +Note this is not a hard cap, it can drift slightly larger than this but not +by more than 5% or so. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + + + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## JobPipeline.HTTPRequest + +```toml +[JobPipeline.HTTPRequest] +DefaultTimeout = '15s' # Default +MaxSize = '32768' # Default +``` + +### DefaultTimeout + +```toml +DefaultTimeout = '15s' # Default +``` + +DefaultTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### MaxSize + +```toml +MaxSize = '32768' # Default +``` + +MaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +Enabled = false # Default +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +CaptureEATelemetry = false # Default +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR2 jobs. + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +### CaptureEATelemetry + +```toml +CaptureEATelemetry = false # Default +``` + +CaptureEATelemetry toggles collecting extra information from External Adaptares + +## OCR + +```toml +[OCR] +Enabled = false # Default +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +CaptureEATelemetry = false # Default +``` + +This section applies only if you are running off-chain reporting jobs. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +### CaptureEATelemetry + +```toml +CaptureEATelemetry = false # Default +``` + +CaptureEATelemetry toggles collecting extra information from External Adaptares + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +Enabled = true # Default +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerstoreWriteInterval = '5m' # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables P2P V1. + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivity +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively +cheap. We set this to 1 minute during our test. + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + + + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + + + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerstoreWriteInterval + + + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +Enabled = false # Default +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables P2P V2. +Note: V1.Enabled is true by default, so it must be set false in order to run V2 only. + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in `host:port` form as accepted by the TCP version of Go’s `net.Dial`. +The addresses should be reachable by other nodes on the network. When attempting to connect to another node, +a node will attempt to dial all of the other node’s AnnounceAddresses in round-robin fashion. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +Oracle nodes typically only know each other’s PeerIDs, but not their hostnames, IP addresses, or ports. +DefaultBootstrappers are special nodes that help other nodes discover each other’s `AnnounceAddresses` so they can communicate. +Nodes continuously attempt to connect to bootstrappers configured in here. When a node wants to connect to another node +(which it knows only by PeerID, but not by address), it discovers the other node’s AnnounceAddresses from communications +received from its DefaultBootstrappers or other discovered nodes. To facilitate discovery, +nodes will regularly broadcast signed announcements containing their PeerID and AnnounceAddresses. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, +but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaxGracePeriod = 100 # Default +TurnLookBack = 1_000 # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + + + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + + + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + + + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaxGracePeriod + + + +```toml +MaxGracePeriod = 100 # Default +``` + +MaxGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### TurnLookBack + +```toml +TurnLookBack = 1_000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +## Keeper.Registry + +```toml +[Keeper.Registry] +CheckGasOverhead = 200_000 # Default +PerformGasOverhead = 300_000 # Default +SyncInterval = '30m' # Default +MaxPerformDataSize = 5_000 # Default +SyncUpkeepQueueSize = 10 # Default +``` + +### CheckGasOverhead + + + +```toml +CheckGasOverhead = 200_000 # Default +``` + +CheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### PerformGasOverhead + + + +```toml +PerformGasOverhead = 300_000 # Default +``` + +PerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### SyncInterval + + + +```toml +SyncInterval = '30m' # Default +``` + +SyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### MaxPerformDataSize + + + +```toml +MaxPerformDataSize = 5_000 # Default +``` + +MaxPerformDataSize is the max size of perform data. + +### SyncUpkeepQueueSize + + + +```toml +SyncUpkeepQueueSize = 10 # Default +``` + +SyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Pyroscope + +```toml +[Pyroscope] +ServerAddress = 'http://localhost:4040' # Example +Environment = 'mainnet' # Default +``` + +### ServerAddress + +```toml +ServerAddress = 'http://localhost:4040' # Example +``` + +ServerAddress sets the address that will receive the profile logs. It enables the profiling service. + +### Environment + +```toml +Environment = 'mainnet' # Default +``` + +Environment sets the target environment tag in which profiles will be added to. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'my-custom-env' # Example +Release = 'v1.2.3' # Example +``` + +### Debug + + + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'my-custom-env' # Example +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## Insecure + +```toml +[Insecure] +DevWebServer = false # Default +OCRDevelopmentMode = false # Default +InfiniteDepthQueries = false # Default +DisableRateLimiting = false # Default +``` + +Insecure config family is only allowed in development builds. + +### DevWebServer + + + +```toml +DevWebServer = false # Default +``` + +DevWebServer skips secure configuration for webserver AllowedHosts, SSL, etc. + +### OCRDevelopmentMode + +```toml +OCRDevelopmentMode = false # Default +``` + +OCRDevelopmentMode run OCR in development mode. + +### InfiniteDepthQueries + +```toml +InfiniteDepthQueries = false # Default +``` + +InfiniteDepthQueries skips graphql query depth limit checks. + +### DisableRateLimiting + +```toml +DisableRateLimiting = false # Default +``` + +DisableRateLimiting skips ratelimiting on asset requests. + +## EVM + +EVM defaults depend on ChainID: + +### Ethereum Mainnet (1) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Ropsten (3) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Rinkeby (4) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Goerli (5) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Mainnet (10) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### RSK Mainnet (30) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### RSK Testnet (31) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 100 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Kovan (42) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### BSC Mainnet (56) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Testnet (65) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Mainnet (66) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Kovan (69) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### xDai Mainnet (100) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 100 +LogPollInterval = '5s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Heco Mainnet (128) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mainnet (137) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Mainnet (250) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 3800000 +``` + +### Optimism Goerli (420) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimismBedrock' +FinalityDepth = 200 +LinkContractAddress = '0xdc2CC710e42857672E7907CF474a69B63B93089f' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '1m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '30s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 wei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 300 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### Metis Rinkeby (588) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Klaytn Testnet (1001) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Metis Mainnet (1088) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Simulated (1337) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '100' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '0s' +ResendAfterThreshold = '0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 100 +SamplingInterval = '0s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Testnet (4002) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 3800000 +``` + +### Klaytn Mainnet (8217) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Mainnet (42161) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Fuji (43113) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Mainnet (43114) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 100 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mumbai (80001) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Rinkeby (421611) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Goerli (421613) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xd14838A68E8AFBAdE5efb411d5871ea0011AFd28' +LogBackfillBatchSize = 100 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Sepolia (11155111) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xb227f007804c16546Bd054dfED2E7A1fD5437678' +LogBackfillBatchSize = 100 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Mainnet (1666600000) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Testnet (1666700000) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 100 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 100 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +BumpTxDepth = 10 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 4 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### AutoCreateKey + +```toml +AutoCreateKey = true # Default +``` + +AutoCreateKey, if set to true, will ensure that there is always at least one transmit key for the given chain. + +### BlockBackfillDepth + + + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'Optimism' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + + + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + + + +```toml +LogBackfillBatchSize = 100 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + + + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### LogKeepBlocksDepth + + + +```toml +LogKeepBlocksDepth = 100000 # Default +``` + +LogKeepBlocksDepth works in conjunction with Feature.LogPoller. Controls how many blocks the poller will keep, must be greater than FinalityDepth+1. + +### MinContractPayment + +```toml +MinContractPayment = '10000000000000 juels' # Default +``` + +MinContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before `NodePool` marks rpc endpoints as +out-of-sync, and `HeadTracker` logs warnings. + +Set to zero to disable out-of-sync checking. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 100 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### RPCBlockQueryDelay + + + +```toml +RPCBlockQueryDelay = 1 # Default +``` + +RPCBlockQueryDelay controls the number of blocks to trail behind head in the block history estimator and balance monitor. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +## EVM.Transactions + +```toml +[EVM.Transactions] +ForwardersEnabled = false # Default +MaxInFlight = 16 # Default +MaxQueued = 250 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '168h' # Default +ResendAfterThreshold = '1m' # Default +``` + +### ForwardersEnabled + +```toml +ForwardersEnabled = false # Default +``` + +ForwardersEnabled enables or disables sending transactions through forwarder contracts. + +### MaxInFlight + +```toml +MaxInFlight = 16 # Default +``` + +MaxInFlight controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueued + +```toml +MaxQueued = 250 # Default +``` + +MaxQueued is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the EthTx reaper will run. + +### ReaperThreshold + +```toml +ReaperThreshold = '168h' # Default +``` + +ReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### ResendAfterThreshold + +```toml +ResendAfterThreshold = '1m' # Default +``` + +ResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitMax = 500_000 # Default +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 10 # Default +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMin = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `Optimism2`/`L2Suggested` is a special mode only for use with Optimism and Metis blockchains. This mode will use the gas price suggested by the rpc endpoint via `eth_gasPrice`. +- `Arbitrum` is a special mode only for use with Arbitrum blockchains. It uses the suggested gas price (up to `ETH_MAX_GAS_PRICE_WEI`, with `1000 gwei` default) as well as an estimated gas limit (up to `ETH_GAS_LIMIT_MAX`, with `1,000,000,000` default). + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. +This applies to both legacy and EIP1559 transactions. +Note that it is impossible to disable the maximum limit. Setting this value to zero will prevent paying anything for any transaction (which can be useful in some rare cases). +Most chains by default have the maximum set to 2\*\*256-1 Wei which is the maximum allowed gas price on EVM-compatible chains, and is so large it may as well be unlimited. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitMax + +```toml +LimitMax = 500_000 # Default +``` + +LimitMax sets a maximum for _estimated_ gas limits. This currently only applies to `Arbitrum` `GasEstimatorMode`. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes Optimism L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 10 # Default +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap = ( current block base fee * (1.125 ^ N) + tipcap )` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMin` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMax` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMin + +```toml +TipCapMin = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.LimitJobType + +```toml +[EVM.GasEstimator.LimitJobType] +OCR = 100_000 # Example +DR = 100_000 # Example +VRF = 100_000 # Example +FM = 100_000 # Example +Keeper = 100_000 # Example +``` + +### OCR + +```toml +OCR = 100_000 # Example +``` + +OCR overrides LimitDefault for OCR jobs. + +### DR + +```toml +DR = 100_000 # Example +``` + +DR overrides LimitDefault for Direct Request jobs. + +### VRF + +```toml +VRF = 100_000 # Example +``` + +VRF overrides LimitDefault for VRF jobs. + +### FM + +```toml +FM = 100_000 # Example +``` + +FM overrides LimitDefault for Flux Monitor jobs. + +### Keeper + +```toml +Keeper = 100_000 # Example +``` + +Keeper overrides LimitDefault for Keeper jobs. + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 4 # Default +BlockHistorySize = 8 # Default +CheckInclusionBlocks = 12 # Default +CheckInclusionPercentile = 90 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 4 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### CheckInclusionBlocks + +```toml +CheckInclusionBlocks = 12 # Default +``` + +CheckInclusionBlocks is the number of recent blocks to use to detect if there is a transaction propagation/connectivity issue, and to prevent bumping in these cases. +This can help avoid the situation where RPC nodes are not propagating transactions for some non-price-related reason (e.g. go-ethereum bug, networking issue etc) and bumping gas would not help. + +Set to zero to disable connectivity checking completely. + +### CheckInclusionPercentile + +```toml +CheckInclusionPercentile = 90 # Default +``` + +CheckInclusionPercentile controls the percentile that a transaction must have been higher than for all the blocks in the inclusion check window in order to register as a connectivity issue. + +For example, if CheckInclusionBlocks=12 and CheckInclusionPercentile=90 then further bumping will be prevented for any transaction with any attempt that has a higher price than the 90th percentile for the most recent 12 blocks. + +### EIP1559FeeCapBufferBlocks + + + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +The head tracker continually listens for new heads from the chain. + +In addition to these settings, it log warnings if `EVM.NoNewHeadsThreshold` is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + + + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMax. + +## EVM.NodePool + +```toml +[EVM.NodePool] +PollFailureThreshold = 5 # Default +PollInterval = '10s' # Default +SelectionMode = 'HighestHead' # Default +SyncThreshold = 5 # Default +``` + +The node pool manages multiple RPC endpoints. + +In addition to these settings, `EVM.NoNewHeadsThreshold` controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 5 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +### SelectionMode + +```toml +SelectionMode = 'HighestHead' # Default +``` + +SelectionMode controls node selection strategy: + +- HighestHead: use the node with the highest head number +- RoundRobin: rotate through nodes, per-request +- TotalDifficulty: use the node with the greatest total difficulty + +### SyncThreshold + +```toml +SyncThreshold = 5 # Default +``` + +SyncThreshold controls how far a node may lag behind the best node before being marked out-of-sync. +Depending on `SelectionMode`, this represents a difference in the number of blocks (`HighestHead`, `RoundRobin`), or total difficulty (`TotalDifficulty`). + +Set to 0 to disable this check. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Required for all nodes. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +## EVM.OCR2.Automation + +```toml +[EVM.OCR2.Automation] +GasLimit = 5300000 # Default +``` + +### GasLimit + +```toml +GasLimit = 5300000 # Default +``` + +GasLimit controls the gas limit for transmit transactions from ocr2automation job. + +## Cosmos + +```toml +[[Cosmos]] +ChainID = 'Malaga-420' # Example +Enabled = true # Default +BlockRate = '6s' # Default +BlocksUntilTxTimeout = 30 # Default +ConfirmPollPeriod = '1s' # Default +FallbackGasPriceUAtom = '0.015' # Default +FCDURL = 'http://cosmos.com' # Example +GasLimitMultiplier = '1.5' # Default +MaxMsgsPerBatch = 100 # Default +OCR2CachePollPeriod = '4s' # Default +OCR2CacheTTL = '1m' # Default +TxMsgTimeout = '10m' # Default +``` + +### ChainID + +```toml +ChainID = 'Malaga-420' # Example +``` + +ChainID is the Cosmos chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockRate + +```toml +BlockRate = '6s' # Default +``` + +BlockRate is the average time between blocks. + +### BlocksUntilTxTimeout + +```toml +BlocksUntilTxTimeout = 30 # Default +``` + +BlocksUntilTxTimeout is the number of blocks to wait before giving up on the tx getting confirmed. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '1s' # Default +``` + +ConfirmPollPeriod sets how often check for tx confirmation. + +### FallbackGasPriceUAtom + +```toml +FallbackGasPriceUAtom = '0.015' # Default +``` + +FallbackGasPriceUAtom sets a fallback gas price to use when the estimator is not available. + +### FCDURL + +```toml +FCDURL = 'http://cosmos.com' # Example +``` + +FCDURL sets the FCD (Full Client Daemon) URL. + +### GasLimitMultiplier + +```toml +GasLimitMultiplier = '1.5' # Default +``` + +GasLimitMultiplier scales the estimated gas limit. + +### MaxMsgsPerBatch + +```toml +MaxMsgsPerBatch = 100 # Default +``` + +MaxMsgsPerBatch limits the numbers of mesages per transaction batch. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '4s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxMsgTimeout + +```toml +TxMsgTimeout = '10m' # Default +``` + +TxMsgTimeout is the maximum age for resending transaction before they expire. + +## Cosmos.Nodes + +```toml +[[Cosmos.Nodes]] +Name = 'primary' # Example +TendermintURL = 'http://tender.mint' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### TendermintURL + +```toml +TendermintURL = 'http://tender.mint' # Example +``` + +TendermintURL is the HTTP(S) tendermint endpoint for this node. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1m' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +FeeEstimatorMode = 'fixed' # Default +ComputeUnitPriceMax = 1000 # Default +ComputeUnitPriceMin = 0 # Default +ComputeUnitPriceDefault = 0 # Default +FeeBumpPeriod = '3s' # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +### FeeEstimatorMode + +```toml +FeeEstimatorMode = 'fixed' # Default +``` + +FeeEstimatorMode is the method used to determine the base fee + +### ComputeUnitPriceMax + +```toml +ComputeUnitPriceMax = 1000 # Default +``` + +ComputeUnitPriceMax is the maximum price per compute unit that a transaction can be bumped to + +### ComputeUnitPriceMin + +```toml +ComputeUnitPriceMin = 0 # Default +``` + +ComputeUnitPriceMin is the minimum price per compute unit that transaction can have + +### ComputeUnitPriceDefault + +```toml +ComputeUnitPriceDefault = 0 # Default +``` + +ComputeUnitPriceDefault is the default price per compute unit price, and the starting base fee when FeeEstimatorMode = 'fixed' + +### FeeBumpPeriod + +```toml +FeeBumpPeriod = '3s' # Default +``` + +FeeBumpPeriod is the amount of time before a tx is retried with a fee bump + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Starknet + +```toml +[[Starknet]] +ChainID = 'foobar' # Example +Enabled = true # Default +OCR2CachePollPeriod = '5s' # Default +OCR2CacheTTL = '1m' # Default +RequestTimeout = '10s' # Default +TxTimeout = '1m' # Default +TxSendFrequency = '5s' # Default +TxMaxBatchSize = 100 # Default +``` + +### ChainID + +```toml +ChainID = 'foobar' # Example +``` + +ChainID is the Starknet chain ID. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '5s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### RequestTimeout + +```toml +RequestTimeout = '10s' # Default +``` + +RequestTimeout is the RPC client timeout. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxSendFrequency + +```toml +TxSendFrequency = '5s' # Default +``` + +TxSendFrequency is how often to broadcast batches of txes. + +### TxMaxBatchSize + +```toml +TxMaxBatchSize = 100 # Default +``` + +TxMaxBatchSize limits the size of tx batches. + +## Starknet.Nodes + +```toml +[[Starknet.Nodes]] +Name = 'primary' # Example +URL = 'http://stark.node' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://stark.node' # Example +``` + +URL is the base HTTP(S) endpoint for this node. diff --git a/src/pages/chainlink-nodes/v2/config/v2_2_0.mdx b/src/pages/chainlink-nodes/v2/config/v2_2_0.mdx new file mode 100644 index 00000000000..5e28ea64b93 --- /dev/null +++ b/src/pages/chainlink-nodes/v2/config/v2_2_0.mdx @@ -0,0 +1,5547 @@ +--- +layout: ../../../../layouts/MainLayout.astro +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +--- + +import { Aside } from "@components" + +This document describes the TOML format for configuration. + +See also [SECRETS.md](SECRETS.md) + +## Example + +```toml +Log.Level = 'debug' + +[[EVM]] +ChainID = '1' # Required + +[[EVM.Nodes]] +Name = 'fake' # Required +WSURL = 'wss://foo.bar/ws' +HTTPURL = 'https://foo.bar' # Required +``` + +## Global + +```toml +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL used by the node to push stats. This variable is required to deliver telemetry. + +### InsecureFastScrypt + + + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = true # Default +LogPoller = false # Default +UICSAKeys = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = true # Default +``` + +FeedsManager enables the feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### UICSAKeys + +```toml +UICSAKeys = false # Default +``` + +UICSAKeys enables CSA Keys in the UI. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +LogQueries = false # Default +MaxIdleConns = 10 # Default +MaxOpenConns = 20 # Default +MigrateOnStartup = true # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for a transaction to be open and idle before timing out. See Postgres `idle_in_transaction_session_timeout` for more details. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed to wait for database lock of any kind before timing out. See Postgres `lock_timeout` for more details. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### LogQueries + +```toml +LogQueries = false # Default +``` + +LogQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### MaxIdleConns + +```toml +MaxIdleConns = 10 # Default +``` + +MaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use caution when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MaxOpenConns + +```toml +MaxOpenConns = 20 # Default +``` + +MaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use caution when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `'Dir'/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + + + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + + + +```toml +[Database.Lock] +Enabled = true # Default +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. + +Because of the complications with advisory locks, Chainlink nodes with v2.0 and later only support `lease` locking mode. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables the database lock. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Example +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Example +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## AuditLogger + +```toml +[AuditLogger] +Enabled = false # Default +ForwardToUrl = 'http://localhost:9898' # Example +JsonWrapperKey = 'event' # Example +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled determines if this logger should be configured at all + +### ForwardToUrl + +```toml +ForwardToUrl = 'http://localhost:9898' # Example +``` + +ForwardToUrl is where you want to forward logs to + +### JsonWrapperKey + +```toml +JsonWrapperKey = 'event' # Example +``` + +JsonWrapperKey if set wraps the map of data under another single key to make parsing easier + +### Headers + +```toml +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +Headers is the set of headers you wish to pass along with each request + +## Log + +```toml +[Log] +Level = 'info' # Default +JSONConsole = false # Default +UnixTS = false # Default +``` + +### Level + +```toml +Level = 'info' # Default +``` + +Level determines both what is printed on the screen and what is written to the log file. + +The available levels are: + +- "debug": Useful for forensic debugging of issues. +- "info": High-level informational messages. (default) +- "warn": A mild error occurred that might require non-urgent action. Check these warnings semi-regularly to see if any of them require attention. These warnings usually happen due to factors outside of the control of the node operator. Examples: Unexpected responses from a remote API or misleading networking errors. +- "error": An unexpected error occurred during the regular operation of a well-maintained node. Node operators might need to take action to remedy this error. Check these regularly to see if any of them require attention. Examples: Use of deprecated configuration options or incorrectly configured settings that cause a job to fail. +- "crit": A critical error occurred. The node might be unable to function. Node operators should take immediate action to fix these errors. Examples: The node could not boot because a network socket could not be opened or the database became inaccessible. +- "panic": An exceptional error occurred that could not be handled. If the node is unresponsive, node operators should try to restart their nodes and notify the Chainlink team of a potential bug. +- "fatal": The node encountered an unrecoverable problem and had to exit. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## Log.File + +```toml +[Log.File] +Dir = '/my/log/directory' # Example +MaxSize = '5120mb' # Default +MaxAgeDays = 0 # Default +MaxBackups = 1 # Default +``` + +### Dir + +```toml +Dir = '/my/log/directory' # Example +``` + +Dir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### MaxSize + +```toml +MaxSize = '5120mb' # Default +``` + +MaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### MaxAgeDays + +```toml +MaxAgeDays = 0 # Default +``` + +MaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### MaxBackups + +```toml +MaxBackups = 1 # Default +``` + +MaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `MaxAgeDays` variable can still cause them to get deleted. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeCacheTTL = '0s' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +SessionReaperExpiration = '240h' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeCacheTTL + +```toml +BridgeCacheTTL = '0s' # Default +``` + +BridgeCacheTTL controls the cache TTL for all bridge tasks to use old values in newer observations in case of intermittent failure. It's disabled by default. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + + + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +### SessionReaperExpiration + +```toml +SessionReaperExpiration = '240h' # Default +``` + +SessionReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 1000 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 1000 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '~/.cl/certs' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '~/.cl/certs' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +## JobPipeline + +```toml +[JobPipeline] +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +MaxSuccessfulRuns = 10000 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### MaxSuccessfulRuns + +```toml +MaxSuccessfulRuns = 10000 # Default +``` + +MaxSuccessfulRuns caps the number of completed successful runs per pipeline +spec in the database. You can set it to zero as a performance optimisation; +this will avoid saving any successful run. + +Note this is not a hard cap, it can drift slightly larger than this but not +by more than 5% or so. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + + + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## JobPipeline.HTTPRequest + +```toml +[JobPipeline.HTTPRequest] +DefaultTimeout = '15s' # Default +MaxSize = '32768' # Default +``` + +### DefaultTimeout + +```toml +DefaultTimeout = '15s' # Default +``` + +DefaultTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### MaxSize + +```toml +MaxSize = '32768' # Default +``` + +MaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +Enabled = false # Default +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +CaptureEATelemetry = false # Default +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR2 jobs. + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +### CaptureEATelemetry + +```toml +CaptureEATelemetry = false # Default +``` + +CaptureEATelemetry toggles collecting extra information from External Adaptares + +## OCR + +```toml +[OCR] +Enabled = false # Default +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +CaptureEATelemetry = false # Default +``` + +This section applies only if you are running off-chain reporting jobs. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +### CaptureEATelemetry + +```toml +CaptureEATelemetry = false # Default +``` + +CaptureEATelemetry toggles collecting extra information from External Adaptares + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +Enabled = true # Default +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerstoreWriteInterval = '5m' # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables P2P V1. + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivity +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively +cheap. We set this to 1 minute during our test. + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + + + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + + + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerstoreWriteInterval + + + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +Enabled = false # Default +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables P2P V2. +Note: V1.Enabled is true by default, so it must be set false in order to run V2 only. + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in `host:port` form as accepted by the TCP version of Go’s `net.Dial`. +The addresses should be reachable by other nodes on the network. When attempting to connect to another node, +a node will attempt to dial all of the other node’s AnnounceAddresses in round-robin fashion. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +Oracle nodes typically only know each other’s PeerIDs, but not their hostnames, IP addresses, or ports. +DefaultBootstrappers are special nodes that help other nodes discover each other’s `AnnounceAddresses` so they can communicate. +Nodes continuously attempt to connect to bootstrappers configured in here. When a node wants to connect to another node +(which it knows only by PeerID, but not by address), it discovers the other node’s AnnounceAddresses from communications +received from its DefaultBootstrappers or other discovered nodes. To facilitate discovery, +nodes will regularly broadcast signed announcements containing their PeerID and AnnounceAddresses. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, +but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaxGracePeriod = 100 # Default +TurnLookBack = 1_000 # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + + + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + + + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + + + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaxGracePeriod + + + +```toml +MaxGracePeriod = 100 # Default +``` + +MaxGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### TurnLookBack + +```toml +TurnLookBack = 1_000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +## Keeper.Registry + +```toml +[Keeper.Registry] +CheckGasOverhead = 200_000 # Default +PerformGasOverhead = 300_000 # Default +SyncInterval = '30m' # Default +MaxPerformDataSize = 5_000 # Default +SyncUpkeepQueueSize = 10 # Default +``` + +### CheckGasOverhead + + + +```toml +CheckGasOverhead = 200_000 # Default +``` + +CheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### PerformGasOverhead + + + +```toml +PerformGasOverhead = 300_000 # Default +``` + +PerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### SyncInterval + + + +```toml +SyncInterval = '30m' # Default +``` + +SyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### MaxPerformDataSize + + + +```toml +MaxPerformDataSize = 5_000 # Default +``` + +MaxPerformDataSize is the max size of perform data. + +### SyncUpkeepQueueSize + + + +```toml +SyncUpkeepQueueSize = 10 # Default +``` + +SyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Pyroscope + +```toml +[Pyroscope] +ServerAddress = 'http://localhost:4040' # Example +Environment = 'mainnet' # Default +``` + +### ServerAddress + +```toml +ServerAddress = 'http://localhost:4040' # Example +``` + +ServerAddress sets the address that will receive the profile logs. It enables the profiling service. + +### Environment + +```toml +Environment = 'mainnet' # Default +``` + +Environment sets the target environment tag in which profiles will be added to. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'my-custom-env' # Example +Release = 'v1.2.3' # Example +``` + +### Debug + + + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'my-custom-env' # Example +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## Insecure + +```toml +[Insecure] +DevWebServer = false # Default +OCRDevelopmentMode = false # Default +InfiniteDepthQueries = false # Default +DisableRateLimiting = false # Default +``` + +Insecure config family is only allowed in development builds. + +### DevWebServer + + + +```toml +DevWebServer = false # Default +``` + +DevWebServer skips secure configuration for webserver AllowedHosts, SSL, etc. + +### OCRDevelopmentMode + +```toml +OCRDevelopmentMode = false # Default +``` + +OCRDevelopmentMode run OCR in development mode. + +### InfiniteDepthQueries + +```toml +InfiniteDepthQueries = false # Default +``` + +InfiniteDepthQueries skips graphql query depth limit checks. + +### DisableRateLimiting + +```toml +DisableRateLimiting = false # Default +``` + +DisableRateLimiting skips ratelimiting on asset requests. + +## EVM + +EVM defaults depend on ChainID: + +### Ethereum Mainnet (1) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Ropsten (3) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Rinkeby (4) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Goerli (5) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Mainnet (10) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### RSK Mainnet (30) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 1000 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### RSK Testnet (31) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 1000 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Kovan (42) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### BSC Mainnet (56) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 1000 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Testnet (65) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Mainnet (66) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Kovan (69) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimism' +FinalityDepth = 1 +LinkContractAddress = '0x4911b761993b9c8c0d14Ba2d86902AF6B0074F5B' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '15s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### xDai Mainnet (100) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 1000 +LogPollInterval = '5s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Heco Mainnet (128) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 1000 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mainnet (137) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Mainnet (250) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 3800000 +``` + +### Optimism Goerli (420) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimismBedrock' +FinalityDepth = 200 +LinkContractAddress = '0xdc2CC710e42857672E7907CF474a69B63B93089f' +LogBackfillBatchSize = 1000 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '1m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '30s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 wei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 300 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### Metis Rinkeby (588) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Klaytn Testnet (1001) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Metis Mainnet (1088) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Simulated (1337) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '100' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '0s' +ResendAfterThreshold = '0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '100 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 100 +SamplingInterval = '0s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Testnet (4002) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 3800000 +``` + +### Klaytn Mainnet (8217) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Mainnet (42161) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Celo Mainnet (42220) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '5s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '1m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 12 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 50 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Fuji (43113) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 1000 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Mainnet (43114) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 1000 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Celo Testnet (44787) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '5s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '1m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 12 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 50 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mumbai (80001) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Rinkeby (421611) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Goerli (421613) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xd14838A68E8AFBAdE5efb411d5871ea0011AFd28' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Sepolia (11155111) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xb227f007804c16546Bd054dfED2E7A1fD5437678' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Mainnet (1666600000) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 1000 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Testnet (1666700000) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 1000 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### AutoCreateKey + +```toml +AutoCreateKey = true # Default +``` + +AutoCreateKey, if set to true, will ensure that there is always at least one transmit key for the given chain. + +### BlockBackfillDepth + + + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'Optimism' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + + + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + + + +```toml +LogBackfillBatchSize = 1000 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + + + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### LogKeepBlocksDepth + + + +```toml +LogKeepBlocksDepth = 100000 # Default +``` + +LogKeepBlocksDepth works in conjunction with Feature.LogPoller. Controls how many blocks the poller will keep, must be greater than FinalityDepth+1. + +### MinContractPayment + +```toml +MinContractPayment = '10000000000000 juels' # Default +``` + +MinContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before `NodePool` marks rpc endpoints as +out-of-sync, and `HeadTracker` logs warnings. + +Set to zero to disable out-of-sync checking. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 250 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### RPCBlockQueryDelay + + + +```toml +RPCBlockQueryDelay = 1 # Default +``` + +RPCBlockQueryDelay controls the number of blocks to trail behind head in the block history estimator and balance monitor. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +## EVM.Transactions + +```toml +[EVM.Transactions] +ForwardersEnabled = false # Default +MaxInFlight = 16 # Default +MaxQueued = 250 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '168h' # Default +ResendAfterThreshold = '1m' # Default +``` + +### ForwardersEnabled + +```toml +ForwardersEnabled = false # Default +``` + +ForwardersEnabled enables or disables sending transactions through forwarder contracts. + +### MaxInFlight + +```toml +MaxInFlight = 16 # Default +``` + +MaxInFlight controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueued + +```toml +MaxQueued = 250 # Default +``` + +MaxQueued is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the EthTx reaper will run. + +### ReaperThreshold + +```toml +ReaperThreshold = '168h' # Default +``` + +ReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### ResendAfterThreshold + +```toml +ResendAfterThreshold = '1m' # Default +``` + +ResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitMax = 500_000 # Default +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 16 # Example +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMin = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `Optimism2`/`L2Suggested` is a special mode only for use with Optimism and Metis blockchains. This mode will use the gas price suggested by the rpc endpoint via `eth_gasPrice`. +- `Arbitrum` is a special mode only for use with Arbitrum blockchains. It uses the suggested gas price (up to `ETH_MAX_GAS_PRICE_WEI`, with `1000 gwei` default) as well as an estimated gas limit (up to `ETH_GAS_LIMIT_MAX`, with `1,000,000,000` default). + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. +This applies to both legacy and EIP1559 transactions. +Note that it is impossible to disable the maximum limit. Setting this value to zero will prevent paying anything for any transaction (which can be useful in some rare cases). +Most chains by default have the maximum set to 2\*\*256-1 Wei which is the maximum allowed gas price on EVM-compatible chains, and is so large it may as well be unlimited. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitMax + +```toml +LimitMax = 500_000 # Default +``` + +LimitMax sets a maximum for _estimated_ gas limits. This currently only applies to `Arbitrum` `GasEstimatorMode`. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes Optimism L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 16 # Example +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). Can not be greater than EVM.Transactions.MaxInFlight. If not set, defaults to EVM.Transactions.MaxInFlight. + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap = ( current block base fee * (1.125 ^ N) + tipcap )` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMin` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMax` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMin + +```toml +TipCapMin = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.LimitJobType + +```toml +[EVM.GasEstimator.LimitJobType] +OCR = 100_000 # Example +DR = 100_000 # Example +VRF = 100_000 # Example +FM = 100_000 # Example +Keeper = 100_000 # Example +``` + +### OCR + +```toml +OCR = 100_000 # Example +``` + +OCR overrides LimitDefault for OCR jobs. + +### DR + +```toml +DR = 100_000 # Example +``` + +DR overrides LimitDefault for Direct Request jobs. + +### VRF + +```toml +VRF = 100_000 # Example +``` + +VRF overrides LimitDefault for VRF jobs. + +### FM + +```toml +FM = 100_000 # Example +``` + +FM overrides LimitDefault for Flux Monitor jobs. + +### Keeper + +```toml +Keeper = 100_000 # Example +``` + +Keeper overrides LimitDefault for Keeper jobs. + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 25 # Default +BlockHistorySize = 8 # Default +CheckInclusionBlocks = 12 # Default +CheckInclusionPercentile = 90 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 25 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### CheckInclusionBlocks + +```toml +CheckInclusionBlocks = 12 # Default +``` + +CheckInclusionBlocks is the number of recent blocks to use to detect if there is a transaction propagation/connectivity issue, and to prevent bumping in these cases. +This can help avoid the situation where RPC nodes are not propagating transactions for some non-price-related reason (e.g. go-ethereum bug, networking issue etc) and bumping gas would not help. + +Set to zero to disable connectivity checking completely. + +### CheckInclusionPercentile + +```toml +CheckInclusionPercentile = 90 # Default +``` + +CheckInclusionPercentile controls the percentile that a transaction must have been higher than for all the blocks in the inclusion check window in order to register as a connectivity issue. + +For example, if CheckInclusionBlocks=12 and CheckInclusionPercentile=90 then further bumping will be prevented for any transaction with any attempt that has a higher price than the 90th percentile for the most recent 12 blocks. + +### EIP1559FeeCapBufferBlocks + + + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +The head tracker continually listens for new heads from the chain. + +In addition to these settings, it log warnings if `EVM.NoNewHeadsThreshold` is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + + + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMax. + +## EVM.NodePool + +```toml +[EVM.NodePool] +PollFailureThreshold = 5 # Default +PollInterval = '10s' # Default +SelectionMode = 'HighestHead' # Default +SyncThreshold = 5 # Default +``` + +The node pool manages multiple RPC endpoints. + +In addition to these settings, `EVM.NoNewHeadsThreshold` controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 5 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +### SelectionMode + +```toml +SelectionMode = 'HighestHead' # Default +``` + +SelectionMode controls node selection strategy: + +- HighestHead: use the node with the highest head number +- RoundRobin: rotate through nodes, per-request +- TotalDifficulty: use the node with the greatest total difficulty + +### SyncThreshold + +```toml +SyncThreshold = 5 # Default +``` + +SyncThreshold controls how far a node may lag behind the best node before being marked out-of-sync. +Depending on `SelectionMode`, this represents a difference in the number of blocks (`HighestHead`, `RoundRobin`), or total difficulty (`TotalDifficulty`). + +Set to 0 to disable this check. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Required for all nodes. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +## EVM.OCR2.Automation + +```toml +[EVM.OCR2.Automation] +GasLimit = 5300000 # Default +``` + +### GasLimit + +```toml +GasLimit = 5300000 # Default +``` + +GasLimit controls the gas limit for transmit transactions from ocr2automation job. + +## Cosmos + +```toml +[[Cosmos]] +ChainID = 'Malaga-420' # Example +Enabled = true # Default +BlockRate = '6s' # Default +BlocksUntilTxTimeout = 30 # Default +ConfirmPollPeriod = '1s' # Default +FallbackGasPriceUAtom = '0.015' # Default +FCDURL = 'http://cosmos.com' # Example +GasLimitMultiplier = '1.5' # Default +MaxMsgsPerBatch = 100 # Default +OCR2CachePollPeriod = '4s' # Default +OCR2CacheTTL = '1m' # Default +TxMsgTimeout = '10m' # Default +``` + +### ChainID + +```toml +ChainID = 'Malaga-420' # Example +``` + +ChainID is the Cosmos chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockRate + +```toml +BlockRate = '6s' # Default +``` + +BlockRate is the average time between blocks. + +### BlocksUntilTxTimeout + +```toml +BlocksUntilTxTimeout = 30 # Default +``` + +BlocksUntilTxTimeout is the number of blocks to wait before giving up on the tx getting confirmed. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '1s' # Default +``` + +ConfirmPollPeriod sets how often check for tx confirmation. + +### FallbackGasPriceUAtom + +```toml +FallbackGasPriceUAtom = '0.015' # Default +``` + +FallbackGasPriceUAtom sets a fallback gas price to use when the estimator is not available. + +### FCDURL + +```toml +FCDURL = 'http://cosmos.com' # Example +``` + +FCDURL sets the FCD (Full Client Daemon) URL. + +### GasLimitMultiplier + +```toml +GasLimitMultiplier = '1.5' # Default +``` + +GasLimitMultiplier scales the estimated gas limit. + +### MaxMsgsPerBatch + +```toml +MaxMsgsPerBatch = 100 # Default +``` + +MaxMsgsPerBatch limits the numbers of mesages per transaction batch. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '4s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxMsgTimeout + +```toml +TxMsgTimeout = '10m' # Default +``` + +TxMsgTimeout is the maximum age for resending transaction before they expire. + +## Cosmos.Nodes + +```toml +[[Cosmos.Nodes]] +Name = 'primary' # Example +TendermintURL = 'http://tender.mint' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### TendermintURL + +```toml +TendermintURL = 'http://tender.mint' # Example +``` + +TendermintURL is the HTTP(S) tendermint endpoint for this node. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1m' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +FeeEstimatorMode = 'fixed' # Default +ComputeUnitPriceMax = 1000 # Default +ComputeUnitPriceMin = 0 # Default +ComputeUnitPriceDefault = 0 # Default +FeeBumpPeriod = '3s' # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +### FeeEstimatorMode + +```toml +FeeEstimatorMode = 'fixed' # Default +``` + +FeeEstimatorMode is the method used to determine the base fee + +### ComputeUnitPriceMax + +```toml +ComputeUnitPriceMax = 1000 # Default +``` + +ComputeUnitPriceMax is the maximum price per compute unit that a transaction can be bumped to + +### ComputeUnitPriceMin + +```toml +ComputeUnitPriceMin = 0 # Default +``` + +ComputeUnitPriceMin is the minimum price per compute unit that transaction can have + +### ComputeUnitPriceDefault + +```toml +ComputeUnitPriceDefault = 0 # Default +``` + +ComputeUnitPriceDefault is the default price per compute unit price, and the starting base fee when FeeEstimatorMode = 'fixed' + +### FeeBumpPeriod + +```toml +FeeBumpPeriod = '3s' # Default +``` + +FeeBumpPeriod is the amount of time before a tx is retried with a fee bump + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Starknet + +```toml +[[Starknet]] +ChainID = 'foobar' # Example +Enabled = true # Default +OCR2CachePollPeriod = '5s' # Default +OCR2CacheTTL = '1m' # Default +RequestTimeout = '10s' # Default +TxTimeout = '10s' # Default +ConfirmationPoll = '5s' # Default +``` + +### ChainID + +```toml +ChainID = 'foobar' # Example +``` + +ChainID is the Starknet chain ID. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '5s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### RequestTimeout + +```toml +RequestTimeout = '10s' # Default +``` + +RequestTimeout is the RPC client timeout. + +### TxTimeout + +```toml +TxTimeout = '10s' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### ConfirmationPoll + +```toml +ConfirmationPoll = '5s' # Default +``` + +ConfirmationPoll is how often to confirmer checks for tx inclusion on chain. + +## Starknet.Nodes + +```toml +[[Starknet.Nodes]] +Name = 'primary' # Example +URL = 'http://stark.node' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://stark.node' # Example +``` + +URL is the base HTTP(S) endpoint for this node. diff --git a/src/pages/chainlink-nodes/v2/config/v2_3_0.mdx b/src/pages/chainlink-nodes/v2/config/v2_3_0.mdx new file mode 100644 index 00000000000..4ddf4255f93 --- /dev/null +++ b/src/pages/chainlink-nodes/v2/config/v2_3_0.mdx @@ -0,0 +1,5714 @@ +--- +layout: ../../../../layouts/MainLayout.astro +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +--- + +import { Aside } from "@components" + +This document describes the TOML format for configuration. + +See also [SECRETS.md](SECRETS.md) + +## Example + +```toml +Log.Level = 'debug' + +[[EVM]] +ChainID = '1' # Required + +[[EVM.Nodes]] +Name = 'fake' # Required +WSURL = 'wss://foo.bar/ws' +HTTPURL = 'https://foo.bar' # Required +``` + +## Global + +```toml +ExplorerURL = 'ws://explorer.url' # Example +InsecureFastScrypt = false # Default +RootDir = '~/.chainlink' # Default +ShutdownGracePeriod = '5s' # Default +``` + +### ExplorerURL + +```toml +ExplorerURL = 'ws://explorer.url' # Example +``` + +ExplorerURL is the websocket URL used by the node to push stats. This variable is required to deliver telemetry. + +### InsecureFastScrypt + + + +```toml +InsecureFastScrypt = false # Default +``` + +InsecureFastScrypt causes all key stores to encrypt using "fast" scrypt params instead. This is insecure and only useful for local testing. DO NOT ENABLE THIS IN PRODUCTION. + +### RootDir + +```toml +RootDir = '~/.chainlink' # Default +``` + +RootDir is the Chainlink node's root directory. This is the default directory for logging, database backups, cookies, and other misc Chainlink node files. Chainlink nodes will always ensure this directory has 700 permissions because it might contain sensitive data. + +### ShutdownGracePeriod + +```toml +ShutdownGracePeriod = '5s' # Default +``` + +ShutdownGracePeriod is the maximum time allowed to shut down gracefully. If exceeded, the node will terminate immediately to avoid being SIGKILLed. + +## Feature + +```toml +[Feature] +FeedsManager = true # Default +LogPoller = false # Default +UICSAKeys = false # Default +``` + +### FeedsManager + +```toml +FeedsManager = true # Default +``` + +FeedsManager enables the feeds manager service. + +### LogPoller + +```toml +LogPoller = false # Default +``` + +LogPoller enables the log poller, an experimental approach to processing logs, required if also using Evm.UseForwarders or OCR2. + +### UICSAKeys + +```toml +UICSAKeys = false # Default +``` + +UICSAKeys enables CSA Keys in the UI. + +## Database + +```toml +[Database] +DefaultIdleInTxSessionTimeout = '1h' # Default +DefaultLockTimeout = '15s' # Default +DefaultQueryTimeout = '10s' # Default +LogQueries = false # Default +MaxIdleConns = 10 # Default +MaxOpenConns = 20 # Default +MigrateOnStartup = true # Default +``` + +### DefaultIdleInTxSessionTimeout + +```toml +DefaultIdleInTxSessionTimeout = '1h' # Default +``` + +DefaultIdleInTxSessionTimeout is the maximum time allowed for a transaction to be open and idle before timing out. See Postgres `idle_in_transaction_session_timeout` for more details. + +### DefaultLockTimeout + +```toml +DefaultLockTimeout = '15s' # Default +``` + +DefaultLockTimeout is the maximum time allowed to wait for database lock of any kind before timing out. See Postgres `lock_timeout` for more details. + +### DefaultQueryTimeout + +```toml +DefaultQueryTimeout = '10s' # Default +``` + +DefaultQueryTimeout is the maximum time allowed for standard queries before timing out. + +### LogQueries + +```toml +LogQueries = false # Default +``` + +LogQueries tells the Chainlink node to log database queries made using the default logger. SQL statements will be logged at `debug` level. Not all statements can be logged. The best way to get a true log of all SQL statements is to enable SQL statement logging on Postgres. + +### MaxIdleConns + +```toml +MaxIdleConns = 10 # Default +``` + +MaxIdleConns configures the maximum number of idle database connections that the Chainlink node will keep open. Think of this as the baseline number of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use caution when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MaxOpenConns + +```toml +MaxOpenConns = 20 # Default +``` + +MaxOpenConns configures the maximum number of database connections that a Chainlink node will have open at any one time. Think of this as the maximum burst upper bound limit of database connections per Chainlink node instance. Increasing this number can help to improve performance under database-heavy workloads. + +Postgres has connection limits, so you must use caution when increasing this value. If you are running several instances of a Chainlink node or another application on a single database server, you might run out of Postgres connection slots if you raise this value too high. + +### MigrateOnStartup + +```toml +MigrateOnStartup = true # Default +``` + +MigrateOnStartup controls whether a Chainlink node will attempt to automatically migrate the database on boot. If you want more control over your database migration process, set this variable to `false` and manually migrate the database using the CLI `migrate` command instead. + +## Database.Backup + +```toml +[Database.Backup] +Mode = 'none' # Default +Dir = 'test/backup/dir' # Example +OnVersionUpgrade = true # Default +Frequency = '1h' # Default +``` + +As a best practice, take regular database backups in case of accidental data loss. This best practice is especially important when you upgrade your Chainlink node to a new version. Chainlink nodes support automated database backups to make this process easier. + +NOTE: Dumps can cause high load and massive database latencies, which will negatively impact the normal functioning of the Chainlink node. For this reason, it is recommended to set a `URL` and point it to a read replica if you enable automatic backups. + +### Mode + +```toml +Mode = 'none' # Default +``` + +Mode sets the type of automatic database backup, which can be one of _none_, `lite`, or `full`. If enabled, the Chainlink node will always dump a backup on every boot before running migrations. Additionally, it will automatically take database backups that overwrite the backup file for the given version at regular intervals if `Frequency` is set to a non-zero interval. + +_none_ - Disables backups. +`lite` - Dumps small tables including configuration and keys that are essential for the node to function, which excludes historical data like job runs, transaction history, etc. +`full` - Dumps the entire database. + +It will write to a file like `'Dir'/backup/cl_backup_.dump`. There is one backup dump file per version of the Chainlink node. If you upgrade the node, it will keep the backup taken right before the upgrade migration so you can restore to an older version if necessary. + +### Dir + +```toml +Dir = 'test/backup/dir' # Example +``` + +Dir sets the directory to use for saving the backup file. Use this if you want to save the backup file in a directory other than the default ROOT directory. + +### OnVersionUpgrade + +```toml +OnVersionUpgrade = true # Default +``` + +OnVersionUpgrade enables automatic backups of the database before running migrations, when you are upgrading to a new version. + +### Frequency + +```toml +Frequency = '1h' # Default +``` + +Frequency sets the interval for database dumps, if set to a positive duration and `Mode` is not _none_. + +Set to `0` to disable periodic backups. + +## Database.Listener + + + +```toml +[Database.Listener] +MaxReconnectDuration = '10m' # Default +MinReconnectInterval = '1m' # Default +FallbackPollInterval = '30s' # Default +``` + +These settings control the postgres event listener. + +### MaxReconnectDuration + +```toml +MaxReconnectDuration = '10m' # Default +``` + +MaxReconnectDuration is the maximum duration to wait between reconnect attempts. + +### MinReconnectInterval + +```toml +MinReconnectInterval = '1m' # Default +``` + +MinReconnectInterval controls the duration to wait before trying to re-establish the database connection after connection loss. After each consecutive failure this interval is doubled, until MaxReconnectInterval is reached. Successfully completing the connection establishment procedure resets the interval back to MinReconnectInterval. + +### FallbackPollInterval + +```toml +FallbackPollInterval = '30s' # Default +``` + +FallbackPollInterval controls how often clients should manually poll as a fallback in case the postgres event was missed/dropped. + +## Database.Lock + + + +```toml +[Database.Lock] +Enabled = true # Default +LeaseDuration = '10s' # Default +LeaseRefreshInterval = '1s' # Default +``` + +Ideally, you should use a container orchestration system like [Kubernetes](https://kubernetes.io/) to ensure that only one Chainlink node instance can ever use a specific Postgres database. However, some node operators do not have the technical capacity to do this. Common use cases run multiple Chainlink node instances in failover mode as recommended by our official documentation. The first instance takes a lock on the database and subsequent instances will wait trying to take this lock in case the first instance fails. + +- If your nodes or applications hold locks open for several hours or days, Postgres is unable to complete internal cleanup tasks. The Postgres maintainers explicitly discourage holding locks open for long periods of time. + +Because of the complications with advisory locks, Chainlink nodes with v2.0 and later only support `lease` locking mode. The `lease` locking mode works using the following process: + +- Node A creates one row in the database with the client ID and updates it once per second. +- Node B spinlocks and checks periodically to see if the client ID is too old. If the client ID is not updated after a period of time, node B assumes that node A failed and takes over. Node B becomes the owner of the row and updates the client ID once per second. +- If node A comes back, it attempts to take out a lease, realizes that the database has been leased to another process, and exits the entire application immediately. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables the database lock. + +### LeaseDuration + +```toml +LeaseDuration = '10s' # Default +``` + +LeaseDuration is how long the lease lock will last before expiring. + +### LeaseRefreshInterval + +```toml +LeaseRefreshInterval = '1s' # Default +``` + +LeaseRefreshInterval determines how often to refresh the lease lock. Also controls how often a standby node will check to see if it can grab the lease. + +## TelemetryIngress + +```toml +[TelemetryIngress] +UniConn = true # Default +Logging = false # Default +ServerPubKey = 'test-pub-key' # Example +URL = 'https://prom.test' # Example +BufferSize = 100 # Default +MaxBatchSize = 50 # Default +SendInterval = '500ms' # Default +SendTimeout = '10s' # Default +UseBatchSend = true # Default +``` + +### UniConn + +```toml +UniConn = true # Default +``` + +UniConn toggles which ws connection style is used. + +### Logging + +```toml +Logging = false # Default +``` + +Logging toggles verbose logging of the raw telemetry messages being sent. + +### ServerPubKey + +```toml +ServerPubKey = 'test-pub-key' # Example +``` + +ServerPubKey is the public key of the telemetry server. + +### URL + +```toml +URL = 'https://prom.test' # Example +``` + +URL is where to send telemetry. + +### BufferSize + +```toml +BufferSize = 100 # Default +``` + +BufferSize is the number of telemetry messages to buffer before dropping new ones. + +### MaxBatchSize + +```toml +MaxBatchSize = 50 # Default +``` + +MaxBatchSize is the maximum number of messages to batch into one telemetry request. + +### SendInterval + +```toml +SendInterval = '500ms' # Default +``` + +SendInterval determines how often batched telemetry is sent to the ingress server. + +### SendTimeout + +```toml +SendTimeout = '10s' # Default +``` + +SendTimeout is the max duration to wait for the request to complete when sending batch telemetry. + +### UseBatchSend + +```toml +UseBatchSend = true # Default +``` + +UseBatchSend toggles sending telemetry to the ingress server using the batch client. + +## AuditLogger + +```toml +[AuditLogger] +Enabled = false # Default +ForwardToUrl = 'http://localhost:9898' # Example +JsonWrapperKey = 'event' # Example +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled determines if this logger should be configured at all + +### ForwardToUrl + +```toml +ForwardToUrl = 'http://localhost:9898' # Example +``` + +ForwardToUrl is where you want to forward logs to + +### JsonWrapperKey + +```toml +JsonWrapperKey = 'event' # Example +``` + +JsonWrapperKey if set wraps the map of data under another single key to make parsing easier + +### Headers + +```toml +Headers = ['Authorization: token', 'X-SomeOther-Header: value with spaces | and a bar+*'] # Example +``` + +Headers is the set of headers you wish to pass along with each request + +## Log + +```toml +[Log] +Level = 'info' # Default +JSONConsole = false # Default +UnixTS = false # Default +``` + +### Level + +```toml +Level = 'info' # Default +``` + +Level determines both what is printed on the screen and what is written to the log file. + +The available levels are: + +- "debug": Useful for forensic debugging of issues. +- "info": High-level informational messages. (default) +- "warn": A mild error occurred that might require non-urgent action. Check these warnings semi-regularly to see if any of them require attention. These warnings usually happen due to factors outside of the control of the node operator. Examples: Unexpected responses from a remote API or misleading networking errors. +- "error": An unexpected error occurred during the regular operation of a well-maintained node. Node operators might need to take action to remedy this error. Check these regularly to see if any of them require attention. Examples: Use of deprecated configuration options or incorrectly configured settings that cause a job to fail. +- "crit": A critical error occurred. The node might be unable to function. Node operators should take immediate action to fix these errors. Examples: The node could not boot because a network socket could not be opened or the database became inaccessible. +- "panic": An exceptional error occurred that could not be handled. If the node is unresponsive, node operators should try to restart their nodes and notify the Chainlink team of a potential bug. +- "fatal": The node encountered an unrecoverable problem and had to exit. + +### JSONConsole + +```toml +JSONConsole = false # Default +``` + +JSONConsole enables JSON logging. Otherwise, the log is saved in a human-friendly console format. + +### UnixTS + +```toml +UnixTS = false # Default +``` + +UnixTS enables legacy unix timestamps. + +Previous versions of Chainlink nodes wrote JSON logs with a unix timestamp. As of v1.1.0 and up, the default has changed to use ISO8601 timestamps for better readability. + +## Log.File + +```toml +[Log.File] +Dir = '/my/log/directory' # Example +MaxSize = '5120mb' # Default +MaxAgeDays = 0 # Default +MaxBackups = 1 # Default +``` + +### Dir + +```toml +Dir = '/my/log/directory' # Example +``` + +Dir sets the log directory. By default, Chainlink nodes write log data to `$ROOT/log.jsonl`. + +### MaxSize + +```toml +MaxSize = '5120mb' # Default +``` + +MaxSize determines the log file's max size in megabytes before file rotation. Having this not set will disable logging to disk. If your disk doesn't have enough disk space, the logging will pause and the application will log errors until space is available again. + +Values must have suffixes with a unit like: `5120mb` (5,120 megabytes). If no unit suffix is provided, the value defaults to `b` (bytes). The list of valid unit suffixes are: + +- b (bytes) +- kb (kilobytes) +- mb (megabytes) +- gb (gigabytes) +- tb (terabytes) + +### MaxAgeDays + +```toml +MaxAgeDays = 0 # Default +``` + +MaxAgeDays determines the log file's max age in days before file rotation. Keeping this config with the default value will not remove log files based on age. + +### MaxBackups + +```toml +MaxBackups = 1 # Default +``` + +MaxBackups determines the maximum number of old log files to retain. Keeping this config with the default value retains all old log files. The `MaxAgeDays` variable can still cause them to get deleted. + +## WebServer + +```toml +[WebServer] +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +BridgeCacheTTL = '0s' # Default +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +HTTPWriteTimeout = '10s' # Default +HTTPPort = 6688 # Default +SecureCookies = true # Default +SessionTimeout = '15m' # Default +SessionReaperExpiration = '240h' # Default +HTTPMaxSize = '32768b' # Default +StartTimeout = '15s' # Default +ListenIP = '0.0.0.0' # Default +``` + +### AllowOrigins + +```toml +AllowOrigins = 'http://localhost:3000,http://localhost:6688' # Default +``` + +AllowOrigins controls the URLs Chainlink nodes emit in the `Allow-Origins` header of its API responses. The setting can be a comma-separated list with no spaces. You might experience CORS issues if this is not set correctly. + +You should set this to the external URL that you use to access the Chainlink UI. + +You can set `AllowOrigins = '*'` to allow the UI to work from any URL, but it is recommended for security reasons to make it explicit instead. + +### BridgeCacheTTL + +```toml +BridgeCacheTTL = '0s' # Default +``` + +BridgeCacheTTL controls the cache TTL for all bridge tasks to use old values in newer observations in case of intermittent failure. It's disabled by default. + +### BridgeResponseURL + +```toml +BridgeResponseURL = 'https://my-chainlink-node.example.com:6688' # Example +``` + +BridgeResponseURL defines the URL for bridges to send a response to. This _must_ be set when using async external adapters. + +Usually this will be the same as the URL/IP and port you use to connect to the Chainlink UI. + +### HTTPWriteTimeout + + + +```toml +HTTPWriteTimeout = '10s' # Default +``` + +HTTPWriteTimeout controls how long the Chainlink node's API server can hold a socket open for writing a response to an HTTP request. Sometimes, this must be increased for pprof. + +### HTTPPort + +```toml +HTTPPort = 6688 # Default +``` + +HTTPPort is the port used for the Chainlink Node API, [CLI](/docs/configuration-variables/#cli-client), and GUI. + +### SecureCookies + +```toml +SecureCookies = true # Default +``` + +SecureCookies requires the use of secure cookies for authentication. Set to false to enable standard HTTP requests along with `TLSPort = 0`. + +### SessionTimeout + +```toml +SessionTimeout = '15m' # Default +``` + +SessionTimeout determines the amount of idle time to elapse before session cookies expire. This signs out GUI users from their sessions. + +### SessionReaperExpiration + +```toml +SessionReaperExpiration = '240h' # Default +``` + +SessionReaperExpiration represents how long an API session lasts before expiring and requiring a new login. + +### HTTPMaxSize + +```toml +HTTPMaxSize = '32768b' # Default +``` + +HTTPMaxSize defines the maximum size for HTTP requests and responses made by the node server. + +### StartTimeout + +```toml +StartTimeout = '15s' # Default +``` + +StartTimeout defines the maximum amount of time the node will wait for a server to start. + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP specifies the IP to bind the HTTP server to + +## WebServer.RateLimit + +```toml +[WebServer.RateLimit] +Authenticated = 1000 # Default +AuthenticatedPeriod = '1m' # Default +Unauthenticated = 5 # Default +UnauthenticatedPeriod = '20s' # Default +``` + +### Authenticated + +```toml +Authenticated = 1000 # Default +``` + +Authenticated defines the threshold to which authenticated requests get limited. More than this many authenticated requests per `AuthenticatedRateLimitPeriod` will be rejected. + +### AuthenticatedPeriod + +```toml +AuthenticatedPeriod = '1m' # Default +``` + +AuthenticatedPeriod defines the period to which authenticated requests get limited. + +### Unauthenticated + +```toml +Unauthenticated = 5 # Default +``` + +Unauthenticated defines the threshold to which authenticated requests get limited. More than this many unauthenticated requests per `UnAuthenticatedRateLimitPeriod` will be rejected. + +### UnauthenticatedPeriod + +```toml +UnauthenticatedPeriod = '20s' # Default +``` + +UnauthenticatedPeriod defines the period to which unauthenticated requests get limited. + +## WebServer.MFA + +```toml +[WebServer.MFA] +RPID = 'localhost' # Example +RPOrigin = 'http://localhost:6688/' # Example +``` + +The Operator UI frontend supports enabling Multi Factor Authentication via Webauthn per account. When enabled, logging in will require the account password and a hardware or OS security key such as Yubikey. To enroll, log in to the operator UI and click the circle purple profile button at the top right and then click **Register MFA Token**. Tap your hardware security key or use the OS public key management feature to enroll a key. Next time you log in, this key will be required to authenticate. + +### RPID + +```toml +RPID = 'localhost' # Example +``` + +RPID is the FQDN of where the Operator UI is served. When serving locally, the value should be `localhost`. + +### RPOrigin + +```toml +RPOrigin = 'http://localhost:6688/' # Example +``` + +RPOrigin is the origin URL where WebAuthn requests initiate, including scheme and port. When serving locally, the value should be `http://localhost:6688/`. + +## WebServer.TLS + +```toml +[WebServer.TLS] +CertPath = '~/.cl/certs' # Example +Host = 'tls-host' # Example +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +HTTPSPort = 6689 # Default +ForceRedirect = false # Default +ListenIP = '0.0.0.0' # Default +``` + +The TLS settings apply only if you want to enable TLS security on your Chainlink node. + +### CertPath + +```toml +CertPath = '~/.cl/certs' # Example +``` + +CertPath is the location of the TLS certificate file. + +### Host + +```toml +Host = 'tls-host' # Example +``` + +Host is the hostname configured for TLS to be used by the Chainlink node. This is useful if you configured a domain name specific for your Chainlink node. + +### KeyPath + +```toml +KeyPath = '/home/$USER/.chainlink/tls/server.key' # Example +``` + +KeyPath is the location of the TLS private key file. + +### HTTPSPort + +```toml +HTTPSPort = 6689 # Default +``` + +HTTPSPort is the port used for HTTPS connections. Set this to `0` to disable HTTPS. Disabling HTTPS also relieves Chainlink nodes of the requirement for a TLS certificate. + +### ForceRedirect + +```toml +ForceRedirect = false # Default +``` + +ForceRedirect forces TLS redirect for unencrypted connections. + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP specifies the IP to bind the HTTPS server to + +## JobPipeline + +```toml +[JobPipeline] +ExternalInitiatorsEnabled = false # Default +MaxRunDuration = '10m' # Default +MaxSuccessfulRuns = 10000 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '24h' # Default +ResultWriteQueueDepth = 100 # Default +``` + +### ExternalInitiatorsEnabled + +```toml +ExternalInitiatorsEnabled = false # Default +``` + +ExternalInitiatorsEnabled enables the External Initiator feature. If disabled, `webhook` jobs can ONLY be initiated by a logged-in user. If enabled, `webhook` jobs can be initiated by a whitelisted external initiator. + +### MaxRunDuration + +```toml +MaxRunDuration = '10m' # Default +``` + +MaxRunDuration is the maximum time allowed for a single job run. If it takes longer, it will exit early and be marked errored. If set to zero, disables the time limit completely. + +### MaxSuccessfulRuns + +```toml +MaxSuccessfulRuns = 10000 # Default +``` + +MaxSuccessfulRuns caps the number of completed successful runs per pipeline +spec in the database. You can set it to zero as a performance optimisation; +this will avoid saving any successful run. + +Note this is not a hard cap, it can drift slightly larger than this but not +by more than 5% or so. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the job pipeline reaper will run to delete completed jobs older than ReaperThreshold, in order to keep database size manageable. + +Set to `0` to disable the periodic reaper. + +### ReaperThreshold + +```toml +ReaperThreshold = '24h' # Default +``` + +ReaperThreshold determines the age limit for job runs. Completed job runs older than this will be automatically purged from the database. + +### ResultWriteQueueDepth + + + +```toml +ResultWriteQueueDepth = 100 # Default +``` + +ResultWriteQueueDepth controls how many writes will be buffered before subsequent writes are dropped, for jobs that write results asynchronously for performance reasons, such as OCR. + +## JobPipeline.HTTPRequest + +```toml +[JobPipeline.HTTPRequest] +DefaultTimeout = '15s' # Default +MaxSize = '32768' # Default +``` + +### DefaultTimeout + +```toml +DefaultTimeout = '15s' # Default +``` + +DefaultTimeout defines the default timeout for HTTP requests made by `http` and `bridge` adapters. + +### MaxSize + +```toml +MaxSize = '32768' # Default +``` + +MaxSize defines the maximum size for HTTP requests and responses made by `http` and `bridge` adapters. + +## FluxMonitor + +```toml +[FluxMonitor] +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Flux Monitor. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for Flux Monitor. + +## OCR2 + +```toml +[OCR2] +Enabled = false # Default +ContractConfirmations = 3 # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +CaptureEATelemetry = false # Default +DefaultTransactionQueueDepth = 1 # Default +SimulateTransactions = false # Default +TraceLogging = false # Default +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR2 jobs. + +### ContractConfirmations + +```toml +ContractConfirmations = 3 # Default +``` + +ContractConfirmations is the number of block confirmations to wait for before enacting an on-chain +configuration change. This value doesn't need to be very high (in +particular, it does not need to protect against malicious re-orgs). +Since configuration changes create some overhead, and mini-reorgs +are fairly common, recommended values are between two and ten. + +Malicious re-orgs are not any more of concern here than they are in +blockchain applications in general: Since nodes check the contract for the +latest config every ContractConfigTrackerPollInterval.Seconds(), they will +come to a common view of the current config within any interval longer than +that, as long as the latest setConfig transaction in the longest chain is +stable. They will thus be able to continue reporting after the poll +interval, unless an adversary is able to repeatedly re-org the transaction +out during every poll interval, which would amount to the capability to +censor any transaction. + +Note that 1 confirmation implies that the transaction/event has been mined in one block. +0 confirmations would imply that the event would be recognised before it has even been mined, which is not currently supported. +e.g. +Current block height: 42 +Changed in block height: 43 +Contract config confirmations: 1 +STILL PENDING + +Current block height: 43 +Changed in block height: 43 +Contract config confirmations: 1 +CONFIRMED + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for# updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout is the timeout for ContractTransmitter.Transmit calls. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout is the timeout for database interactions. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### KeyBundleID + +```toml +KeyBundleID = '7a5f66bbe6594259325bf2b4f5b1a9c900000000000000000000000000000000' # Example +``` + +KeyBundleID is a sha256 hexadecimal hash identifier. + +### CaptureEATelemetry + +```toml +CaptureEATelemetry = false # Default +``` + +CaptureEATelemetry toggles collecting extra information from External Adaptares + +### DefaultTransactionQueueDepth + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR2. Set to 0 to use `SendEvery` strategy instead. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR2. + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## OCR + +```toml +[OCR] +Enabled = false # Default +ObservationTimeout = '5s' # Default +BlockchainTimeout = '20s' # Default +ContractPollInterval = '1m' # Default +ContractSubscribeInterval = '2m' # Default +DefaultTransactionQueueDepth = 1 # Default +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +SimulateTransactions = false # Default +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +CaptureEATelemetry = false # Default +TraceLogging = false # Default +``` + +This section applies only if you are running off-chain reporting jobs. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables OCR jobs. + +### ObservationTimeout + +```toml +ObservationTimeout = '5s' # Default +``` + +ObservationTimeout is the timeout for making observations using the DataSource.Observe method. +(This is necessary because an oracle's operations are serialized, so +blocking forever on an observation would break the oracle.) + +### BlockchainTimeout + +```toml +BlockchainTimeout = '20s' # Default +``` + +BlockchainTimeout is the timeout for blockchain queries (mediated through +ContractConfigTracker and ContractTransmitter). +(This is necessary because an oracle's operations are serialized, so +blocking forever on a chain interaction would break the oracle.) + +### ContractPollInterval + +```toml +ContractPollInterval = '1m' # Default +``` + +ContractPollInterval is the polling interval at which ContractConfigTracker is queried for +updated on-chain configurations. Recommended values are between +fifteen seconds and two minutes. + +### ContractSubscribeInterval + +```toml +ContractSubscribeInterval = '2m' # Default +``` + +ContractSubscribeInterval is the interval at which we try to establish a subscription on ContractConfigTracker +if one doesn't exist. Recommended values are between two and five minutes. + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in OCR. Set to 0 to use `SendEvery` strategy instead. + +### KeyBundleID + +```toml +KeyBundleID = 'acdd42797a8b921b2910497badc5000600000000000000000000000000000000' # Example +``` + +KeyBundleID is the default key bundle ID to use for OCR jobs. If you have an OCR job that does not explicitly specify a key bundle ID, it will fall back to this value. + +### SimulateTransactions + +```toml +SimulateTransactions = false # Default +``` + +SimulateTransactions enables transaction simulation for OCR. + +### TransmitterAddress + +```toml +TransmitterAddress = '0xa0788FC17B1dEe36f057c42B6F373A34B014687e' # Example +``` + +TransmitterAddress is the default sending address to use for OCR. If you have an OCR job that does not explicitly specify a transmitter address, it will fall back to this value. + +### CaptureEATelemetry + +```toml +CaptureEATelemetry = false # Default +``` + +CaptureEATelemetry toggles collecting extra information from External Adaptares + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P + +```toml +[P2P] +IncomingMessageBufferSize = 10 # Default +OutgoingMessageBufferSize = 10 # Default +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +TraceLogging = false # Default +``` + +P2P supports multiple networking stack versions. You may configure `[P2P.V1]`, `[P2P.V2]`, or both to run simultaneously. +If both are configured, then for each link with another peer, V2 networking will be preferred. If V2 does not work, the link will +automatically fall back to V1. If V2 starts working again later, it will automatically be preferred again. This is useful +for migrating networks without downtime. Note that the two networking stacks _must not_ be configured to bind to the same IP/port. + +All nodes in the OCR network should share the same networking stack. + +### IncomingMessageBufferSize + +```toml +IncomingMessageBufferSize = 10 # Default +``` + +IncomingMessageBufferSize is the per-remote number of incoming +messages to buffer. Any additional messages received on top of those +already in the queue will be dropped. + +### OutgoingMessageBufferSize + +```toml +OutgoingMessageBufferSize = 10 # Default +``` + +OutgoingMessageBufferSize is the per-remote number of outgoing +messages to buffer. Any additional messages send on top of those +already in the queue will displace the oldest. +NOTE: OutgoingMessageBufferSize should be comfortably smaller than remote's +IncomingMessageBufferSize to give the remote enough space to process +them all in case we regained connection and now send a bunch at once + +### PeerID + +```toml +PeerID = '12D3KooWMoejJznyDuEk5aX6GvbjaG12UzeornPCBNzMRqdwrFJw' # Example +``` + +PeerID is the default peer ID to use for OCR jobs. If unspecified, uses the first available peer ID. + +### TraceLogging + +```toml +TraceLogging = false # Default +``` + +TraceLogging enables trace level logging. + +## P2P.V1 + +```toml +[P2P.V1] +Enabled = true # Default +AnnounceIP = '1.2.3.4' # Example +AnnouncePort = 1337 # Example +BootstrapCheckInterval = '20s' # Default +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +DHTAnnouncementCounterUserPrefix = 0 # Default +DHTLookupInterval = 10 # Default +ListenIP = '0.0.0.0' # Default +ListenPort = 1337 # Example +NewStreamTimeout = '10s' # Default +PeerstoreWriteInterval = '5m' # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables P2P V1. + +### AnnounceIP + +```toml +AnnounceIP = '1.2.3.4' # Example +``` + +AnnounceIP should be set as the externally reachable IP address of the Chainlink node. + +### AnnouncePort + +```toml +AnnouncePort = 1337 # Example +``` + +AnnouncePort should be set as the externally reachable port of the Chainlink node. + +### BootstrapCheckInterval + +```toml +BootstrapCheckInterval = '20s' # Default +``` + +BootstrapCheckInterval is the interval at which nodes check connections to bootstrap nodes and reconnect if any of them is lost. +Setting this to a small value would allow newly joined bootstrap nodes to get more connectivity +more quickly, which helps to make bootstrap process faster. The cost of this operation is relatively +cheap. We set this to 1 minute during our test. + +### DefaultBootstrapPeers + +```toml +DefaultBootstrapPeers = ['/dns4/example.com/tcp/1337/p2p/12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U', '/ip4/1.2.3.4/tcp/9999/p2p/12D3KooWLZ9uTC3MrvKfDpGju6RAQubiMDL7CuJcAgDRTYP7fh7R'] # Example +``` + +DefaultBootstrapPeers is the default set of bootstrap peers. + +### DHTAnnouncementCounterUserPrefix + +```toml +DHTAnnouncementCounterUserPrefix = 0 # Default +``` + +DHTAnnouncementCounterUserPrefix can be used to restore the node's +ability to announce its IP/port on the P2P network after a database +rollback. Make sure to only increase this value, and _never_ decrease it. +Don't use this variable unless you really know what you're doing, since you +could semi-permanently exclude your node from the P2P network by +misconfiguring it. + +### DHTLookupInterval + + + +```toml +DHTLookupInterval = 10 # Default +``` + +DHTLookupInterval is the interval between which we do the expensive peer +lookup using DHT. + +Every DHTLookupInterval failures to open a stream to a peer, we will +attempt to lookup its IP from DHT + +### ListenIP + +```toml +ListenIP = '0.0.0.0' # Default +``` + +ListenIP is the default IP address to bind to. + +### ListenPort + +```toml +ListenPort = 1337 # Example +``` + +ListenPort is the port to listen on. If left blank, the node randomly selects a different port each time it boots. It is highly recommended to set this to a static value to avoid network instability. + +### NewStreamTimeout + + + +```toml +NewStreamTimeout = '10s' # Default +``` + +NewStreamTimeout is the maximum length of time to wait to open a +stream before we give up. +We shouldn't hit this in practice since libp2p will give up fast if +it can't get a connection, but it is here anyway as a failsafe. +Set to 0 to disable any timeout on top of what libp2p gives us by default. + +### PeerstoreWriteInterval + + + +```toml +PeerstoreWriteInterval = '5m' # Default +``` + +PeerstoreWriteInterval controls how often the peerstore for the OCR V1 networking stack is persisted to the database. + +## P2P.V2 + +```toml +[P2P.V2] +Enabled = false # Default +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +DeltaDial = '15s' # Default +DeltaReconcile = '1m' # Default +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables P2P V2. +Note: V1.Enabled is true by default, so it must be set false in order to run V2 only. + +### AnnounceAddresses + +```toml +AnnounceAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +AnnounceAddresses is the addresses the peer will advertise on the network in `host:port` form as accepted by the TCP version of Go’s `net.Dial`. +The addresses should be reachable by other nodes on the network. When attempting to connect to another node, +a node will attempt to dial all of the other node’s AnnounceAddresses in round-robin fashion. + +### DefaultBootstrappers + +```toml +DefaultBootstrappers = ['12D3KooWMHMRLQkgPbFSYHwD3NBuwtS1AmxhvKVUrcfyaGDASR4U@1.2.3.4:9999', '12D3KooWM55u5Swtpw9r8aFLQHEtw7HR4t44GdNs654ej5gRs2Dh@example.com:1234'] # Example +``` + +DefaultBootstrappers is the default bootstrapper peers for libocr's v2 networking stack. + +Oracle nodes typically only know each other’s PeerIDs, but not their hostnames, IP addresses, or ports. +DefaultBootstrappers are special nodes that help other nodes discover each other’s `AnnounceAddresses` so they can communicate. +Nodes continuously attempt to connect to bootstrappers configured in here. When a node wants to connect to another node +(which it knows only by PeerID, but not by address), it discovers the other node’s AnnounceAddresses from communications +received from its DefaultBootstrappers or other discovered nodes. To facilitate discovery, +nodes will regularly broadcast signed announcements containing their PeerID and AnnounceAddresses. + +### DeltaDial + +```toml +DeltaDial = '15s' # Default +``` + +DeltaDial controls how far apart Dial attempts are + +### DeltaReconcile + +```toml +DeltaReconcile = '1m' # Default +``` + +DeltaReconcile controls how often a Reconcile message is sent to every peer. + +### ListenAddresses + +```toml +ListenAddresses = ['1.2.3.4:9999', '[a52d:0:a88:1274::abcd]:1337'] # Example +``` + +ListenAddresses is the addresses the peer will listen to on the network in `host:port` form as accepted by `net.Listen()`, +but the host and port must be fully specified and cannot be empty. You can specify `0.0.0.0` (IPv4) or `::` (IPv6) to listen on all interfaces, but that is not recommended. + +## Keeper + +```toml +[Keeper] +DefaultTransactionQueueDepth = 1 # Default +GasPriceBufferPercent = 20 # Default +GasTipCapBufferPercent = 20 # Default +BaseFeeBufferPercent = 20 # Default +MaxGracePeriod = 100 # Default +TurnLookBack = 1_000 # Default +``` + +### DefaultTransactionQueueDepth + + + +```toml +DefaultTransactionQueueDepth = 1 # Default +``` + +DefaultTransactionQueueDepth controls the queue size for `DropOldestStrategy` in Keeper. Set to 0 to use `SendEvery` strategy instead. + +### GasPriceBufferPercent + + + +```toml +GasPriceBufferPercent = 20 # Default +``` + +GasPriceBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in legacy mode (EIP-1559 off). + +### GasTipCapBufferPercent + + + +```toml +GasTipCapBufferPercent = 20 # Default +``` + +GasTipCapBufferPercent specifies the percentage to add to the gas price used for checking whether to perform an upkeep. Only applies in EIP-1559 mode. + +### BaseFeeBufferPercent + + + +```toml +BaseFeeBufferPercent = 20 # Default +``` + +BaseFeeBufferPercent specifies the percentage to add to the base fee used for checking whether to perform an upkeep. Applies only in EIP-1559 mode. + +### MaxGracePeriod + + + +```toml +MaxGracePeriod = 100 # Default +``` + +MaxGracePeriod is the maximum number of blocks that a keeper will wait after performing an upkeep before it resumes checking that upkeep + +### TurnLookBack + +```toml +TurnLookBack = 1_000 # Default +``` + +TurnLookBack is the number of blocks in the past to look back when getting a block for a turn. + +## Keeper.Registry + +```toml +[Keeper.Registry] +CheckGasOverhead = 200_000 # Default +PerformGasOverhead = 300_000 # Default +SyncInterval = '30m' # Default +MaxPerformDataSize = 5_000 # Default +SyncUpkeepQueueSize = 10 # Default +``` + +### CheckGasOverhead + + + +```toml +CheckGasOverhead = 200_000 # Default +``` + +CheckGasOverhead is the amount of extra gas to provide checkUpkeep() calls to account for the gas consumed by the keeper registry. + +### PerformGasOverhead + + + +```toml +PerformGasOverhead = 300_000 # Default +``` + +PerformGasOverhead is the amount of extra gas to provide performUpkeep() calls to account for the gas consumed by the keeper registry + +### SyncInterval + + + +```toml +SyncInterval = '30m' # Default +``` + +SyncInterval is the interval in which the RegistrySynchronizer performs a full sync of the keeper registry contract it is tracking. + +### MaxPerformDataSize + + + +```toml +MaxPerformDataSize = 5_000 # Default +``` + +MaxPerformDataSize is the max size of perform data. + +### SyncUpkeepQueueSize + + + +```toml +SyncUpkeepQueueSize = 10 # Default +``` + +SyncUpkeepQueueSize represents the maximum number of upkeeps that can be synced in parallel. + +## AutoPprof + +```toml +[AutoPprof] +Enabled = false # Default +ProfileRoot = 'prof/root' # Example +PollInterval = '10s' # Default +GatherDuration = '10s' # Default +GatherTraceDuration = '5s' # Default +MaxProfileSize = '100mb' # Default +CPUProfileRate = 1 # Default +MemProfileRate = 1 # Default +BlockProfileRate = 1 # Default +MutexProfileFraction = 1 # Default +MemThreshold = '4gb' # Default +GoroutineThreshold = 5000 # Default +``` + +The Chainlink node is equipped with an internal "nurse" service that can perform automatic `pprof` profiling when the certain resource thresholds are exceeded, such as memory and goroutine count. These profiles are saved to disk to facilitate fine-grained debugging of performance-related issues. In general, if you notice that your node has begun to accumulate profiles, forward them to the Chainlink team. + +To learn more about these profiles, read the [Profiling Go programs with pprof](https://jvns.ca/blog/2017/09/24/profiling-go-with-pprof/) guide. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables the automatic profiling service. + +### ProfileRoot + +```toml +ProfileRoot = 'prof/root' # Example +``` + +ProfileRoot sets the location on disk where pprof profiles will be stored. Defaults to `RootDir`. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval is the interval at which the node's resources are checked. + +### GatherDuration + +```toml +GatherDuration = '10s' # Default +``` + +GatherDuration is the duration for which profiles are gathered when profiling starts. + +### GatherTraceDuration + +```toml +GatherTraceDuration = '5s' # Default +``` + +GatherTraceDuration is the duration for which traces are gathered when profiling is kicked off. This is separately configurable because traces are significantly larger than other types of profiles. + +### MaxProfileSize + +```toml +MaxProfileSize = '100mb' # Default +``` + +MaxProfileSize is the maximum amount of disk space that profiles may consume before profiling is disabled. + +### CPUProfileRate + +```toml +CPUProfileRate = 1 # Default +``` + +CPUProfileRate sets the rate for CPU profiling. See https://pkg.go.dev/runtime#SetCPUProfileRate. + +### MemProfileRate + +```toml +MemProfileRate = 1 # Default +``` + +MemProfileRate sets the rate for memory profiling. See https://pkg.go.dev/runtime#pkg-variables. + +### BlockProfileRate + +```toml +BlockProfileRate = 1 # Default +``` + +BlockProfileRate sets the fraction of blocking events for goroutine profiling. See https://pkg.go.dev/runtime#SetBlockProfileRate. + +### MutexProfileFraction + +```toml +MutexProfileFraction = 1 # Default +``` + +MutexProfileFraction sets the fraction of contention events for mutex profiling. See https://pkg.go.dev/runtime#SetMutexProfileFraction. + +### MemThreshold + +```toml +MemThreshold = '4gb' # Default +``` + +MemThreshold sets the maximum amount of memory the node can actively consume before profiling begins. + +### GoroutineThreshold + +```toml +GoroutineThreshold = 5000 # Default +``` + +GoroutineThreshold is the maximum number of actively-running goroutines the node can spawn before profiling begins. + +## Pyroscope + +```toml +[Pyroscope] +ServerAddress = 'http://localhost:4040' # Example +Environment = 'mainnet' # Default +``` + +### ServerAddress + +```toml +ServerAddress = 'http://localhost:4040' # Example +``` + +ServerAddress sets the address that will receive the profile logs. It enables the profiling service. + +### Environment + +```toml +Environment = 'mainnet' # Default +``` + +Environment sets the target environment tag in which profiles will be added to. + +## Sentry + +```toml +[Sentry] +Debug = false # Default +DSN = 'sentry-dsn' # Example +Environment = 'my-custom-env' # Example +Release = 'v1.2.3' # Example +``` + +### Debug + + + +```toml +Debug = false # Default +``` + +Debug enables printing of Sentry SDK debug messages. + +### DSN + +```toml +DSN = 'sentry-dsn' # Example +``` + +DSN is the data source name where events will be sent. Sentry is completely disabled if this is left blank. + +### Environment + +```toml +Environment = 'my-custom-env' # Example +``` + +Environment overrides the Sentry environment to the given value. Otherwise autodetects between dev/prod. + +### Release + +```toml +Release = 'v1.2.3' # Example +``` + +Release overrides the Sentry release to the given value. Otherwise uses the compiled-in version number. + +## Insecure + +```toml +[Insecure] +DevWebServer = false # Default +OCRDevelopmentMode = false # Default +InfiniteDepthQueries = false # Default +DisableRateLimiting = false # Default +``` + +Insecure config family is only allowed in development builds. + +### DevWebServer + + + +```toml +DevWebServer = false # Default +``` + +DevWebServer skips secure configuration for webserver AllowedHosts, SSL, etc. + +### OCRDevelopmentMode + +```toml +OCRDevelopmentMode = false # Default +``` + +OCRDevelopmentMode run OCR in development mode. + +### InfiniteDepthQueries + +```toml +InfiniteDepthQueries = false # Default +``` + +InfiniteDepthQueries skips graphql query depth limit checks. + +### DisableRateLimiting + +```toml +DisableRateLimiting = false # Default +``` + +DisableRateLimiting skips ratelimiting on asset requests. + +## EVM + +EVM defaults depend on ChainID: + +### Ethereum Mainnet (1) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x514910771AF9Ca656af840dff83E8264EcF986CA' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x3E64Cd889482443324F91bFA9c84fE72A511f48A' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Ropsten (3) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x20fE562d797A42Dcb3399062AE9546cd06f63280' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Rinkeby (4) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x01BE23585060835E02B77ef475b0Cc51aA1e0709' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Goerli (5) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Optimism Mainnet (10) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimismBedrock' +FinalityDepth = 200 +LinkContractAddress = '0x350a791Bfc2C21F9Ed5d10980Dad2e2638ffa7f6' +LogBackfillBatchSize = 1000 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '40s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '30s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 wei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '100 wei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 300 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### RSK Mainnet (30) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x14AdaE34beF7ca957Ce2dDe5ADD97ea050123827' +LogBackfillBatchSize = 1000 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### RSK Testnet (31) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8bBbd80981FE76d44854D8DF305e8985c19f0e78' +LogBackfillBatchSize = 1000 +LogPollInterval = '30s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '50 mwei' +PriceMax = '50 gwei' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 mwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Kovan (42) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xa36085F69e2889c224210F603D836748e7dC0088' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +OperatorFactoryAddress = '0x8007e24251b1D2Fc518Eb843A701d9cD21fe0aA3' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### BSC Mainnet (56) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 1000 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Testnet (65) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### OKX Mainnet (66) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### xDai Mainnet (100) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'xdai' +FinalityDepth = 50 +LinkContractAddress = '0xE2e73A1c69ecF83F464EFCE6A5be353a37cA09b2' +LogBackfillBatchSize = 1000 +LogPollInterval = '5s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '500 gwei' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Heco Mainnet (128) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x404460C6A5EdE2D891e8297795264fDe62ADBB75' +LogBackfillBatchSize = 1000 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 5 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '2s' +DatabaseTimeout = '2s' +ObservationGracePeriod = '500ms' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mainnet (137) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0xb0897686c545045aFc77CF20eC7A532E3120E0F1' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '30 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '30 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Mainnet (250) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x6F43FF82CCA38001B6699a8AC47A2d0E66939407' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 3800000 +``` + +### Optimism Goerli (420) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimismBedrock' +FinalityDepth = 200 +LinkContractAddress = '0xdc2CC710e42857672E7907CF474a69B63B93089f' +LogBackfillBatchSize = 1000 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '40s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '30s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 wei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '100 wei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 60 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 300 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### Metis Rinkeby (588) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Klaytn Testnet (1001) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Metis Mainnet (1088) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'metis' +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Simulated (1337) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '100' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '0s' +ResendAfterThreshold = '0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'FixedPrice' +PriceDefault = '20 gwei' +PriceMax = '100 micro' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '100 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 10 +MaxBufferSize = 100 +SamplingInterval = '0s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Fantom Testnet (4002) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xfaFedb041c0DD4fA2Dc0d87a6B0979Ee6FA7af5F' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '15 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 3800000 +``` + +### Klaytn Mainnet (8217) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'L2Suggested' +PriceDefault = '750 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Base Mainnet (8453) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimismBedrock' +FinalityDepth = 200 +LogBackfillBatchSize = 1000 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '40s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '30s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 wei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '100 wei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 300 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### Arbitrum Mainnet (42161) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xf97f4df75117a78c1A5a0DBb814Af92458539FB4' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Celo Mainnet (42220) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'celo' +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '5s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '1m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '500 gwei' +PriceMin = '5 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '2 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 12 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 50 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Fuji (43113) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x0b9d5D9136855f6FEc3c0993feE6E9CE8a297846' +LogBackfillBatchSize = 1000 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Avalanche Mainnet (43114) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 1 +LinkContractAddress = '0x5947BB275c521040051D82396192181b413227A3' +LogBackfillBatchSize = 1000 +LogPollInterval = '3s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 2 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '25 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '25 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Celo Testnet (44787) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'celo' +FinalityDepth = 1 +LogBackfillBatchSize = 1000 +LogPollInterval = '5s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '1m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '500 gwei' +PriceMin = '5 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '2 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 50 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Polygon Mumbai (80001) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 500 +LinkContractAddress = '0x326C977E6efc84E512bB9C30f76E30c160eD06FB' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 5 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 10 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 5000 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '1 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '20 gwei' +BumpPercent = 20 +BumpThreshold = 5 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 24 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 2000 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Base Goerli (84531) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'optimismBedrock' +FinalityDepth = 200 +LogBackfillBatchSize = 1000 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '40s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '30s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 wei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '100 wei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 60 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 300 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 6500000 +``` + +### Arbitrum Rinkeby (421611) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0x615fBe6372676474d9e6933d310469c9b68e9726' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Arbitrum Goerli (421613) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +ChainType = 'arbitrum' +FinalityDepth = 50 +LinkContractAddress = '0xd14838A68E8AFBAdE5efb411d5871ea0011AFd28' +LogBackfillBatchSize = 1000 +LogPollInterval = '1s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'Arbitrum' +PriceDefault = '100 mwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '0' +LimitDefault = 500000 +LimitMax = 1000000000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 0 +EIP1559DynamicFees = false +FeeCapDefault = '1 micro' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 0 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 10 + +[OCR] +ContractConfirmations = 1 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Ethereum Sepolia (11155111) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0xb227f007804c16546Bd054dfED2E7A1fD5437678' +LogBackfillBatchSize = 1000 +LogPollInterval = '15s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 3 +MinContractPayment = '0.1 link' +NonceAutoSync = true +NoNewHeadsThreshold = '3m0s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '20 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = true +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 4 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 50 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Mainnet (1666600000) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x218532a12a389a4a92fC0C5Fb22901D1c19198aA' +LogBackfillBatchSize = 1000 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### Harmony Testnet (1666700000) + +```toml +AutoCreateKey = true +BlockBackfillDepth = 10 +BlockBackfillSkip = false +FinalityDepth = 50 +LinkContractAddress = '0x8b12Ac23BFe11cAb03a634C1F117D64a7f2cFD3e' +LogBackfillBatchSize = 1000 +LogPollInterval = '2s' +LogKeepBlocksDepth = 100000 +MinIncomingConfirmations = 1 +MinContractPayment = '0.00001 link' +NonceAutoSync = true +NoNewHeadsThreshold = '30s' +RPCDefaultBatchSize = 250 +RPCBlockQueryDelay = 1 + +[Transactions] +ForwardersEnabled = false +MaxInFlight = 16 +MaxQueued = 250 +ReaperInterval = '1h0m0s' +ReaperThreshold = '168h0m0s' +ResendAfterThreshold = '1m0s' + +[BalanceMonitor] +Enabled = true + +[GasEstimator] +Mode = 'BlockHistory' +PriceDefault = '5 gwei' +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' +PriceMin = '1 gwei' +LimitDefault = 500000 +LimitMax = 500000 +LimitMultiplier = '1' +LimitTransfer = 21000 +BumpMin = '5 gwei' +BumpPercent = 20 +BumpThreshold = 3 +EIP1559DynamicFees = false +FeeCapDefault = '100 gwei' +TipCapDefault = '1 wei' +TipCapMin = '1 wei' + +[GasEstimator.BlockHistory] +BatchSize = 25 +BlockHistorySize = 8 +CheckInclusionBlocks = 12 +CheckInclusionPercentile = 90 +TransactionPercentile = 60 + +[HeadTracker] +HistoryDepth = 100 +MaxBufferSize = 3 +SamplingInterval = '1s' + +[NodePool] +PollFailureThreshold = 5 +PollInterval = '10s' +SelectionMode = 'HighestHead' +SyncThreshold = 5 + +[OCR] +ContractConfirmations = 4 +ContractTransmitterTransmitTimeout = '10s' +DatabaseTimeout = '10s' +ObservationGracePeriod = '1s' + +[OCR2] +[OCR2.Automation] +GasLimit = 5300000 +``` + +### ChainID + +```toml +ChainID = '1' # Example +``` + +ChainID is the EVM chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### AutoCreateKey + +```toml +AutoCreateKey = true # Default +``` + +AutoCreateKey, if set to true, will ensure that there is always at least one transmit key for the given chain. + +### BlockBackfillDepth + + + +```toml +BlockBackfillDepth = 10 # Default +``` + +BlockBackfillDepth specifies the number of blocks before the current HEAD that the log broadcaster will try to re-consume logs from. + +### BlockBackfillSkip + +```toml +BlockBackfillSkip = false # Default +``` + +BlockBackfillSkip enables skipping of very long backfills. + +### ChainType + +```toml +ChainType = 'arbitrum' # Example +``` + +ChainType is automatically detected from chain ID. Set this to force a certain chain type regardless of chain ID. +Available types: arbitrum, metis, optimismBedrock, xdai + +### FinalityDepth + +```toml +FinalityDepth = 50 # Default +``` + +FinalityDepth is the number of blocks after which an ethereum transaction is considered "final". Note that the default is automatically set based on chain ID so it should not be necessary to change this under normal operation. +BlocksConsideredFinal determines how deeply we look back to ensure that transactions are confirmed onto the longest chain +There is not a large performance penalty to setting this relatively high (on the order of hundreds) +It is practically limited by the number of heads we store in the database and should be less than this with a comfortable margin. +If a transaction is mined in a block more than this many blocks ago, and is reorged out, we will NOT retransmit this transaction and undefined behaviour can occur including gaps in the nonce sequence that require manual intervention to fix. +Therefore this number represents a number of blocks we consider large enough that no re-org this deep will ever feasibly happen. + +Special cases: +`FinalityDepth`=0 would imply that transactions can be final even before they were mined into a block. This is not supported. +`FinalityDepth`=1 implies that transactions are final after we see them in one block. + +Examples: + +Transaction sending: +A transaction is sent at block height 42 + +`FinalityDepth` is set to 5 +A re-org occurs at height 44 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 46 starting at block 41, transaction is marked for rebroadcast +A re-org occurs at height 47 starting at block 41, transaction is NOT marked for rebroadcast + +### FlagsContractAddress + + + +```toml +FlagsContractAddress = '0xae4E781a6218A8031764928E88d457937A954fC3' # Example +``` + +FlagsContractAddress can optionally point to a [Flags contract](../contracts/src/v0.8/Flags.sol). If set, the node will lookup that contract for each job that supports flags contracts (currently OCR and FM jobs are supported). If the job's contractAddress is set as hibernating in the FlagsContractAddress address, it overrides the standard update parameters (such as heartbeat/threshold). + +### LinkContractAddress + +```toml +LinkContractAddress = '0x538aAaB4ea120b2bC2fe5D296852D948F07D849e' # Example +``` + +LinkContractAddress is the canonical ERC-677 LINK token contract address on the given chain. Note that this is usually autodetected from chain ID. + +### LogBackfillBatchSize + + + +```toml +LogBackfillBatchSize = 1000 # Default +``` + +LogBackfillBatchSize sets the batch size for calling FilterLogs when we backfill missing logs. + +### LogPollInterval + + + +```toml +LogPollInterval = '15s' # Default +``` + +LogPollInterval works in conjunction with Feature.LogPoller. Controls how frequently the log poller polls for logs. Defaults to the block production rate. + +### LogKeepBlocksDepth + + + +```toml +LogKeepBlocksDepth = 100000 # Default +``` + +LogKeepBlocksDepth works in conjunction with Feature.LogPoller. Controls how many blocks the poller will keep, must be greater than FinalityDepth+1. + +### MinContractPayment + +```toml +MinContractPayment = '10000000000000 juels' # Default +``` + +MinContractPayment is the minimum payment in LINK required to execute a direct request job. This can be overridden on a per-job basis. + +### MinIncomingConfirmations + +```toml +MinIncomingConfirmations = 3 # Default +``` + +MinIncomingConfirmations is the minimum required confirmations before a log event will be consumed. + +### NonceAutoSync + +```toml +NonceAutoSync = true # Default +``` + +NonceAutoSync enables automatic nonce syncing on startup. Chainlink nodes will automatically try to sync its local nonce with the remote chain on startup and fast forward if necessary. This is almost always safe but can be disabled in exceptional cases by setting this value to false. + +### NoNewHeadsThreshold + +```toml +NoNewHeadsThreshold = '3m' # Default +``` + +NoNewHeadsThreshold controls how long to wait after receiving no new heads before `NodePool` marks rpc endpoints as +out-of-sync, and `HeadTracker` logs warnings. + +Set to zero to disable out-of-sync checking. + +### OperatorFactoryAddress + +```toml +OperatorFactoryAddress = '0xa5B85635Be42F21f94F28034B7DA440EeFF0F418' # Example +``` + +OperatorFactoryAddress is the address of the canonical operator forwarder contract on the given chain. Note that this is usually autodetected from chain ID. + +### RPCDefaultBatchSize + +```toml +RPCDefaultBatchSize = 250 # Default +``` + +RPCDefaultBatchSize is the default batch size for batched RPC calls. + +### RPCBlockQueryDelay + + + +```toml +RPCBlockQueryDelay = 1 # Default +``` + +RPCBlockQueryDelay controls the number of blocks to trail behind head in the block history estimator and balance monitor. +For example, if this is set to 3, and we receive block 10, block history estimator will fetch block 7. + +CAUTION: You might be tempted to set this to 0 to use the latest possible +block, but it is possible to receive a head BEFORE that block is actually +available from the connected node via RPC, due to race conditions in the code of the remote ETH node. In this case you will get false +"zero" blocks that are missing transactions. + +## EVM.Transactions + +```toml +[EVM.Transactions] +ForwardersEnabled = false # Default +MaxInFlight = 16 # Default +MaxQueued = 250 # Default +ReaperInterval = '1h' # Default +ReaperThreshold = '168h' # Default +ResendAfterThreshold = '1m' # Default +``` + +### ForwardersEnabled + +```toml +ForwardersEnabled = false # Default +``` + +ForwardersEnabled enables or disables sending transactions through forwarder contracts. + +### MaxInFlight + +```toml +MaxInFlight = 16 # Default +``` + +MaxInFlight controls how many transactions are allowed to be "in-flight" i.e. broadcast but unconfirmed at any one time. You can consider this a form of transaction throttling. + +The default is set conservatively at 16 because this is a pessimistic minimum that both geth and parity will hold without evicting local transactions. If your node is falling behind and you need higher throughput, you can increase this setting, but you MUST make sure that your ETH node is configured properly otherwise you can get nonce gapped and your node will get stuck. + +0 value disables the limit. Use with caution. + +### MaxQueued + +```toml +MaxQueued = 250 # Default +``` + +MaxQueued is the maximum number of unbroadcast transactions per key that are allowed to be enqueued before jobs will start failing and rejecting send of any further transactions. This represents a sanity limit and generally indicates a problem with your ETH node (transactions are not getting mined). + +Do NOT blindly increase this value thinking it will fix things if you start hitting this limit because transactions are not getting mined, you will instead only make things worse. + +In deployments with very high burst rates, or on chains with large re-orgs, you _may_ consider increasing this. + +0 value disables any limit on queue size. Use with caution. + +### ReaperInterval + +```toml +ReaperInterval = '1h' # Default +``` + +ReaperInterval controls how often the EthTx reaper will run. + +### ReaperThreshold + +```toml +ReaperThreshold = '168h' # Default +``` + +ReaperThreshold indicates how old an EthTx ought to be before it can be reaped. + +### ResendAfterThreshold + +```toml +ResendAfterThreshold = '1m' # Default +``` + +ResendAfterThreshold controls how long to wait before re-broadcasting a transaction that has not yet been confirmed. + +## EVM.BalanceMonitor + +```toml +[EVM.BalanceMonitor] +Enabled = true # Default +``` + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled balance monitoring for all keys. + +## EVM.GasEstimator + +```toml +[EVM.GasEstimator] +Mode = 'BlockHistory' # Default +PriceDefault = '20 gwei' # Default +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +PriceMin = '1 gwei' # Default +LimitDefault = 500_000 # Default +LimitMax = 500_000 # Default +LimitMultiplier = '1.0' # Default +LimitTransfer = 21_000 # Default +BumpMin = '5 gwei' # Default +BumpPercent = 20 # Default +BumpThreshold = 3 # Default +BumpTxDepth = 16 # Example +EIP1559DynamicFees = false # Default +FeeCapDefault = '100 gwei' # Default +TipCapDefault = '1 wei' # Default +TipCapMin = '1 wei' # Default +``` + +### Mode + +```toml +Mode = 'BlockHistory' # Default +``` + +Mode controls what type of gas estimator is used. + +- `FixedPrice` uses static configured values for gas price (can be set via API call). +- `BlockHistory` dynamically adjusts default gas price based on heuristics from mined blocks. +- `L2Suggested` is a special mode only for use with L2 blockchains. This mode will use the gas price suggested by the rpc endpoint via `eth_gasPrice`. +- `Arbitrum` is a special mode only for use with Arbitrum blockchains. It uses the suggested gas price (up to `ETH_MAX_GAS_PRICE_WEI`, with `1000 gwei` default) as well as an estimated gas limit (up to `ETH_GAS_LIMIT_MAX`, with `1,000,000,000` default). + +Chainlink nodes decide what gas price to use using an `Estimator`. It ships with several simple and battle-hardened built-in estimators that should work well for almost all use-cases. Note that estimators will change their behaviour slightly depending on if you are in EIP-1559 mode or not. + +You can also use your own estimator for gas price by selecting the `FixedPrice` estimator and using the exposed API to set the price. + +An important point to note is that the Chainlink node does _not_ ship with built-in support for go-ethereum's `estimateGas` call. This is for several reasons, including security and reliability. We have found empirically that it is not generally safe to rely on the remote ETH node's idea of what gas price should be. + +### PriceDefault + +```toml +PriceDefault = '20 gwei' # Default +``` + +PriceDefault is the default gas price to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to legacy transactions) + +Can be used with the `chainlink setgasprice` to be updated while the node is still running. + +### PriceMax + +```toml +PriceMax = '115792089237316195423570985008687907853269984665.640564039457584007913129639935 tether' # Default +``` + +PriceMax is the maximum gas price. Chainlink nodes will never pay more than this for a transaction. +This applies to both legacy and EIP1559 transactions. +Note that it is impossible to disable the maximum limit. Setting this value to zero will prevent paying anything for any transaction (which can be useful in some rare cases). +Most chains by default have the maximum set to 2\*\*256-1 Wei which is the maximum allowed gas price on EVM-compatible chains, and is so large it may as well be unlimited. + +### PriceMin + +```toml +PriceMin = '1 gwei' # Default +``` + +PriceMin is the minimum gas price. Chainlink nodes will never pay less than this for a transaction. + +(Only applies to legacy transactions) + +It is possible to force the Chainlink node to use a fixed gas price by setting a combination of these, e.g. + +```toml +EIP1559DynamicFees = false +PriceMax = 100 +PriceMin = 100 +PriceDefault = 100 +BumpThreshold = 0 +Mode = 'FixedPrice' +``` + +### LimitDefault + +```toml +LimitDefault = 500_000 # Default +``` + +LimitDefault sets default gas limit for outgoing transactions. This should not need to be changed in most cases. +Some job types, such as Keeper jobs, might set their own gas limit unrelated to this value. + +### LimitMax + +```toml +LimitMax = 500_000 # Default +``` + +LimitMax sets a maximum for _estimated_ gas limits. This currently only applies to `Arbitrum` `GasEstimatorMode`. + +### LimitMultiplier + +```toml +LimitMultiplier = '1.0' # Default +``` + +LimitMultiplier is the factor by which a transaction's GasLimit is multiplied before transmission. So if the value is 1.1, and the GasLimit for a transaction is 10, 10% will be added before transmission. + +This factor is always applied, so includes L2 transactions which uses a default gas limit of 1 and is also applied to `LimitDefault`. + +### LimitTransfer + +```toml +LimitTransfer = 21_000 # Default +``` + +LimitTransfer is the gas limit used for an ordinary ETH transfer. + +### BumpMin + +```toml +BumpMin = '5 gwei' # Default +``` + +BumpMin is the minimum fixed amount of wei by which gas is bumped on each transaction attempt. + +### BumpPercent + +```toml +BumpPercent = 20 # Default +``` + +BumpPercent is the percentage by which to bump gas on a transaction that has exceeded `BumpThreshold`. The larger of `GasBumpPercent` and `GasBumpWei` is taken for gas bumps. + +### BumpThreshold + +```toml +BumpThreshold = 3 # Default +``` + +BumpThreshold is the number of blocks to wait for a transaction stuck in the mempool before automatically bumping the gas price. Set to 0 to disable gas bumping completely. + +### BumpTxDepth + +```toml +BumpTxDepth = 16 # Example +``` + +BumpTxDepth is the number of transactions to gas bump starting from oldest. Set to 0 for no limit (i.e. bump all). Can not be greater than EVM.Transactions.MaxInFlight. If not set, defaults to EVM.Transactions.MaxInFlight. + +### EIP1559DynamicFees + +```toml +EIP1559DynamicFees = false # Default +``` + +EIP1559DynamicFees torces EIP-1559 transaction mode. Enabling EIP-1559 mode can help reduce gas costs on chains that support it. This is supported only on official Ethereum mainnet and testnets. It is not recommended to enable this setting on Polygon because the EIP-1559 fee market appears to be broken on all Polygon chains and EIP-1559 transactions are less likely to be included than legacy transactions. + +#### Technical details + +Chainlink nodes include experimental support for submitting transactions using type 0x2 (EIP-1559) envelope. + +EIP-1559 mode is enabled by default on the Ethereum Mainnet, but can be enabled on a per-chain basis or globally. + +This might help to save gas on spikes. Chainlink nodes should react faster on the upleg and avoid overpaying on the downleg. It might also be possible to set `EVM.GasEstimator.BlockHistory.BatchSize` to a smaller value such as 12 or even 6 because tip cap should be a more consistent indicator of inclusion time than total gas price. This would make Chainlink nodes more responsive and should reduce response time variance. Some experimentation is required to find optimum settings. + +Set with caution, if you set this on a chain that does not actually support EIP-1559 your node will be broken. + +In EIP-1559 mode, the total price for the transaction is the minimum of base fee + tip cap and fee cap. More information can be found on the [official EIP](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1559.md). + +Chainlink's implementation of EIP-1559 works as follows: + +If you are using FixedPriceEstimator: + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=GasTipCapDefault` +- With gas bumping enabled, it will submit all transactions initially with `feecap=GasFeeCapDefault` and `tipcap=GasTipCapDefault`. + +If you are using BlockHistoryEstimator (default for most chains): + +- With gas bumping disabled, it will submit all transactions with `feecap=PriceMax` and `tipcap=` +- With gas bumping enabled (default for most chains) it will submit all transactions initially with `feecap = ( current block base fee * (1.125 ^ N) + tipcap )` where N is configurable by setting `EVM.GasEstimator.BlockHistory.EIP1559FeeCapBufferBlocks` but defaults to `gas bump threshold+1` and `tipcap=` + +Bumping works as follows: + +- Increase tipcap by `max(tipcap * (1 + GasBumpPercent), tipcap + GasBumpWei)` +- Increase feecap by `max(feecap * (1 + GasBumpPercent), feecap + GasBumpWei)` + +A quick note on terminology - Chainlink nodes use the same terms used internally by go-ethereum source code to describe various prices. This is not the same as the externally used terms. For reference: + +- Base Fee Per Gas = BaseFeePerGas +- Max Fee Per Gas = FeeCap +- Max Priority Fee Per Gas = TipCap + +In EIP-1559 mode, the following changes occur to how configuration works: + +- All new transactions will be sent as type 0x2 transactions specifying a TipCap and FeeCap. Be aware that existing pending legacy transactions will continue to be gas bumped in legacy mode. +- `BlockHistoryEstimator` will apply its calculations (gas percentile etc) to the TipCap and this value will be used for new transactions (GasPrice will be ignored) +- `FixedPriceEstimator` will use `GasTipCapDefault` instead of `GasPriceDefault` for the tip cap +- `FixedPriceEstimator` will use `GasFeeCapDefault` instaed of `GasPriceDefault` for the fee cap +- `PriceMin` is ignored for new transactions and `GasTipCapMinimum` is used instead (default 0) +- `PriceMax` still represents that absolute upper limit that Chainlink will ever spend (total) on a single tx +- `Keeper.GasTipCapBufferPercent` is ignored in EIP-1559 mode and `Keeper.GasTipCapBufferPercent` is used instead + +### FeeCapDefault + +```toml +FeeCapDefault = '100 gwei' # Default +``` + +FeeCapDefault controls the fixed initial fee cap, if EIP1559 mode is enabled and `FixedPrice` gas estimator is used. + +### TipCapDefault + +```toml +TipCapDefault = '1 wei' # Default +``` + +TipCapDefault is the default gas tip to use when submitting transactions to the blockchain. Will be overridden by the built-in `BlockHistoryEstimator` if enabled, and might be increased if gas bumping is enabled. + +(Only applies to EIP-1559 transactions) + +### TipCapMin + +```toml +TipCapMin = '1 wei' # Default +``` + +TipCapMinimum is the minimum gas tip to use when submitting transactions to the blockchain. + +Only applies to EIP-1559 transactions) + +## EVM.GasEstimator.LimitJobType + +```toml +[EVM.GasEstimator.LimitJobType] +OCR = 100_000 # Example +OCR2 = 100_000 # Example +DR = 100_000 # Example +VRF = 100_000 # Example +FM = 100_000 # Example +Keeper = 100_000 # Example +``` + +### OCR + +```toml +OCR = 100_000 # Example +``` + +OCR overrides LimitDefault for OCR jobs. + +### OCR2 + +```toml +OCR2 = 100_000 # Example +``` + +OCR2 overrides LimitDefault for OCR2 jobs. + +### DR + +```toml +DR = 100_000 # Example +``` + +DR overrides LimitDefault for Direct Request jobs. + +### VRF + +```toml +VRF = 100_000 # Example +``` + +VRF overrides LimitDefault for VRF jobs. + +### FM + +```toml +FM = 100_000 # Example +``` + +FM overrides LimitDefault for Flux Monitor jobs. + +### Keeper + +```toml +Keeper = 100_000 # Example +``` + +Keeper overrides LimitDefault for Keeper jobs. + +## EVM.GasEstimator.BlockHistory + +```toml +[EVM.GasEstimator.BlockHistory] +BatchSize = 25 # Default +BlockHistorySize = 8 # Default +CheckInclusionBlocks = 12 # Default +CheckInclusionPercentile = 90 # Default +EIP1559FeeCapBufferBlocks = 13 # Example +TransactionPercentile = 60 # Default +``` + +These settings allow you to configure how your node calculates gas prices when using the block history estimator. +In most cases, leaving these values at their defaults should give good results. + +### BatchSize + +```toml +BatchSize = 25 # Default +``` + +BatchSize sets the maximum number of blocks to fetch in one batch in the block history estimator. +If the `BatchSize` variable is set to 0, it defaults to `EVM.RPCDefaultBatchSize`. + +### BlockHistorySize + +```toml +BlockHistorySize = 8 # Default +``` + +BlockHistorySize controls the number of past blocks to keep in memory to use as a basis for calculating a percentile gas price. + +### CheckInclusionBlocks + +```toml +CheckInclusionBlocks = 12 # Default +``` + +CheckInclusionBlocks is the number of recent blocks to use to detect if there is a transaction propagation/connectivity issue, and to prevent bumping in these cases. +This can help avoid the situation where RPC nodes are not propagating transactions for some non-price-related reason (e.g. go-ethereum bug, networking issue etc) and bumping gas would not help. + +Set to zero to disable connectivity checking completely. + +### CheckInclusionPercentile + +```toml +CheckInclusionPercentile = 90 # Default +``` + +CheckInclusionPercentile controls the percentile that a transaction must have been higher than for all the blocks in the inclusion check window in order to register as a connectivity issue. + +For example, if CheckInclusionBlocks=12 and CheckInclusionPercentile=90 then further bumping will be prevented for any transaction with any attempt that has a higher price than the 90th percentile for the most recent 12 blocks. + +### EIP1559FeeCapBufferBlocks + + + +```toml +EIP1559FeeCapBufferBlocks = 13 # Example +``` + +EIP1559FeeCapBufferBlocks controls the buffer blocks to add to the current base fee when sending a transaction. By default, the gas bumping threshold + 1 block is used. + +Only applies to EIP-1559 transactions) + +### TransactionPercentile + +```toml +TransactionPercentile = 60 # Default +``` + +TransactionPercentile specifies gas price to choose. E.g. if the block history contains four transactions with gas prices `[100, 200, 300, 400]` then picking 25 for this number will give a value of 200. If the calculated gas price is higher than `GasPriceDefault` then the higher price will be used as the base price for new transactions. + +Must be in range 0-100. + +Only has an effect if gas updater is enabled. + +Think of this number as an indicator of how aggressive you want your node to price its transactions. + +Setting this number higher will cause the Chainlink node to select higher gas prices. + +Setting it lower will tend to set lower gas prices. + +## EVM.HeadTracker + +```toml +[EVM.HeadTracker] +HistoryDepth = 100 # Default +MaxBufferSize = 3 # Default +SamplingInterval = '1s' # Default +``` + +The head tracker continually listens for new heads from the chain. + +In addition to these settings, it log warnings if `EVM.NoNewHeadsThreshold` is exceeded without any new blocks being emitted. + +### HistoryDepth + +```toml +HistoryDepth = 100 # Default +``` + +HistoryDepth tracks the top N block numbers to keep in the `heads` database table. +Note that this can easily result in MORE than N records since in the case of re-orgs we keep multiple heads for a particular block height. +This number should be at least as large as `FinalityDepth`. +There may be a small performance penalty to setting this to something very large (10,000+) + +### MaxBufferSize + +```toml +MaxBufferSize = 3 # Default +``` + +MaxBufferSize is the maximum number of heads that may be +buffered in front of the head tracker before older heads start to be +dropped. You may think of it as something like the maximum permittable "lag" +for the head tracker before we start dropping heads to keep up. + +### SamplingInterval + + + +```toml +SamplingInterval = '1s' # Default +``` + +SamplingInterval means that head tracker callbacks will at maximum be made once in every window of this duration. This is a performance optimisation for fast chains. Set to 0 to disable sampling entirely. + +## EVM.KeySpecific + +```toml +[[EVM.KeySpecific]] +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +GasEstimator.PriceMax = '79 gwei' # Example +``` + +### Key + +```toml +Key = '0x2a3e23c6f242F5345320814aC8a1b4E58707D292' # Example +``` + +Key is the account to apply these settings to + +### PriceMax + +```toml +GasEstimator.PriceMax = '79 gwei' # Example +``` + +GasEstimator.PriceMax overrides the maximum gas price for this key. See EVM.GasEstimator.PriceMax. + +## EVM.NodePool + +```toml +[EVM.NodePool] +PollFailureThreshold = 5 # Default +PollInterval = '10s' # Default +SelectionMode = 'HighestHead' # Default +SyncThreshold = 5 # Default +``` + +The node pool manages multiple RPC endpoints. + +In addition to these settings, `EVM.NoNewHeadsThreshold` controls how long to wait after receiving no new heads before marking the node as out-of-sync. + +### PollFailureThreshold + +```toml +PollFailureThreshold = 5 # Default +``` + +PollFailureThreshold indicates how many consecutive polls must fail in order to mark a node as unreachable. + +Set to zero to disable poll checking. + +### PollInterval + +```toml +PollInterval = '10s' # Default +``` + +PollInterval controls how often to poll the node to check for liveness. + +Set to zero to disable poll checking. + +### SelectionMode + +```toml +SelectionMode = 'HighestHead' # Default +``` + +SelectionMode controls node selection strategy: + +- HighestHead: use the node with the highest head number +- RoundRobin: rotate through nodes, per-request +- TotalDifficulty: use the node with the greatest total difficulty + +### SyncThreshold + +```toml +SyncThreshold = 5 # Default +``` + +SyncThreshold controls how far a node may lag behind the best node before being marked out-of-sync. +Depending on `SelectionMode`, this represents a difference in the number of blocks (`HighestHead`, `RoundRobin`, `PriorityLevel`), or total difficulty (`TotalDifficulty`). + +Set to 0 to disable this check. + +## EVM.OCR + +```toml +[EVM.OCR] +ContractConfirmations = 4 # Default +ContractTransmitterTransmitTimeout = '10s' # Default +DatabaseTimeout = '10s' # Default +ObservationGracePeriod = '1s' # Default +``` + +### ContractConfirmations + +```toml +ContractConfirmations = 4 # Default +``` + +ContractConfirmations sets `OCR.ContractConfirmations` for this EVM chain. + +### ContractTransmitterTransmitTimeout + +```toml +ContractTransmitterTransmitTimeout = '10s' # Default +``` + +ContractTransmitterTransmitTimeout sets `OCR.ContractTransmitterTransmitTimeout` for this EVM chain. + +### DatabaseTimeout + +```toml +DatabaseTimeout = '10s' # Default +``` + +DatabaseTimeout sets `OCR.DatabaseTimeout` for this EVM chain. + +### ObservationGracePeriod + +```toml +ObservationGracePeriod = '1s' # Default +``` + +ObservationGracePeriod sets `OCR.ObservationGracePeriod` for this EVM chain. + +## EVM.Nodes + +```toml +[[EVM.Nodes]] +Name = 'foo' # Example +WSURL = 'wss://web.socket/test' # Example +HTTPURL = 'https://foo.web' # Example +SendOnly = false # Default +Order = 100 # Default +``` + +### Name + +```toml +Name = 'foo' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### WSURL + +```toml +WSURL = 'wss://web.socket/test' # Example +``` + +WSURL is the WS(S) endpoint for this node. Required for primary nodes. + +### HTTPURL + +```toml +HTTPURL = 'https://foo.web' # Example +``` + +HTTPURL is the HTTP(S) endpoint for this node. Required for all nodes. + +### SendOnly + +```toml +SendOnly = false # Default +``` + +SendOnly limits usage to sending transaction broadcasts only. With this enabled, only HTTPURL is required, and WSURL is not used. + +### Order + +```toml +Order = 100 # Default +``` + +Order of the node in the pool, will takes effect if `SelectionMode` is `PriorityLevel` or will be used as a tie-breaker for `HighestHead` and `TotalDifficulty` + +## EVM.OCR2.Automation + +```toml +[EVM.OCR2.Automation] +GasLimit = 5300000 # Default +``` + +### GasLimit + +```toml +GasLimit = 5300000 # Default +``` + +GasLimit controls the gas limit for transmit transactions from ocr2automation job. + +## Cosmos + +```toml +[[Cosmos]] +ChainID = 'Malaga-420' # Example +Enabled = true # Default +BlockRate = '6s' # Default +BlocksUntilTxTimeout = 30 # Default +ConfirmPollPeriod = '1s' # Default +FallbackGasPriceUAtom = '0.015' # Default +FCDURL = 'http://cosmos.com' # Example +GasLimitMultiplier = '1.5' # Default +MaxMsgsPerBatch = 100 # Default +OCR2CachePollPeriod = '4s' # Default +OCR2CacheTTL = '1m' # Default +TxMsgTimeout = '10m' # Default +``` + +### ChainID + +```toml +ChainID = 'Malaga-420' # Example +``` + +ChainID is the Cosmos chain ID. Mandatory. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### BlockRate + +```toml +BlockRate = '6s' # Default +``` + +BlockRate is the average time between blocks. + +### BlocksUntilTxTimeout + +```toml +BlocksUntilTxTimeout = 30 # Default +``` + +BlocksUntilTxTimeout is the number of blocks to wait before giving up on the tx getting confirmed. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '1s' # Default +``` + +ConfirmPollPeriod sets how often check for tx confirmation. + +### FallbackGasPriceUAtom + +```toml +FallbackGasPriceUAtom = '0.015' # Default +``` + +FallbackGasPriceUAtom sets a fallback gas price to use when the estimator is not available. + +### FCDURL + +```toml +FCDURL = 'http://cosmos.com' # Example +``` + +FCDURL sets the FCD (Full Client Daemon) URL. + +### GasLimitMultiplier + +```toml +GasLimitMultiplier = '1.5' # Default +``` + +GasLimitMultiplier scales the estimated gas limit. + +### MaxMsgsPerBatch + +```toml +MaxMsgsPerBatch = 100 # Default +``` + +MaxMsgsPerBatch limits the numbers of mesages per transaction batch. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '4s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxMsgTimeout + +```toml +TxMsgTimeout = '10m' # Default +``` + +TxMsgTimeout is the maximum age for resending transaction before they expire. + +## Cosmos.Nodes + +```toml +[[Cosmos.Nodes]] +Name = 'primary' # Example +TendermintURL = 'http://tender.mint' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### TendermintURL + +```toml +TendermintURL = 'http://tender.mint' # Example +``` + +TendermintURL is the HTTP(S) tendermint endpoint for this node. + +## Solana + +```toml +[[Solana]] +ChainID = 'mainnet' # Example +Enabled = false # Default +BalancePollPeriod = '5s' # Default +ConfirmPollPeriod = '500ms' # Default +OCR2CachePollPeriod = '1s' # Default +OCR2CacheTTL = '1m' # Default +TxTimeout = '1m' # Default +TxRetryTimeout = '10s' # Default +TxConfirmTimeout = '30s' # Default +SkipPreflight = true # Default +Commitment = 'confirmed' # Default +MaxRetries = 0 # Default +FeeEstimatorMode = 'fixed' # Default +ComputeUnitPriceMax = 1000 # Default +ComputeUnitPriceMin = 0 # Default +ComputeUnitPriceDefault = 0 # Default +FeeBumpPeriod = '3s' # Default +``` + +### ChainID + +```toml +ChainID = 'mainnet' # Example +``` + +ChainID is the Solana chain ID. Must be one of: mainnet, testnet, devnet, localnet. Mandatory. + +### Enabled + +```toml +Enabled = false # Default +``` + +Enabled enables this chain. + +### BalancePollPeriod + +```toml +BalancePollPeriod = '5s' # Default +``` + +BalancePollPeriod is the rate to poll for SOL balance and update Prometheus metrics. + +### ConfirmPollPeriod + +```toml +ConfirmPollPeriod = '500ms' # Default +``` + +ConfirmPollPeriod is the rate to poll for signature confirmation. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '1s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### TxTimeout + +```toml +TxTimeout = '1m' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### TxRetryTimeout + +```toml +TxRetryTimeout = '10s' # Default +``` + +TxRetryTimeout is the duration for tx manager to attempt rebroadcasting to RPC, before giving up. + +### TxConfirmTimeout + +```toml +TxConfirmTimeout = '30s' # Default +``` + +TxConfirmTimeout is the duration to wait when confirming a tx signature, before discarding as unconfirmed. + +### SkipPreflight + +```toml +SkipPreflight = true # Default +``` + +SkipPreflight enables or disables preflight checks when sending txs. + +### Commitment + +```toml +Commitment = 'confirmed' # Default +``` + +Commitment is the confirmation level for solana state and transactions. ([documentation](https://docs.solana.com/developing/clients/jsonrpc-api#configuring-state-commitment)) + +### MaxRetries + +```toml +MaxRetries = 0 # Default +``` + +MaxRetries is the maximum number of times the RPC node will automatically rebroadcast a tx. +The default is 0 for custom txm rebroadcasting method, set to -1 to use the RPC node's default retry strategy. + +### FeeEstimatorMode + +```toml +FeeEstimatorMode = 'fixed' # Default +``` + +FeeEstimatorMode is the method used to determine the base fee + +### ComputeUnitPriceMax + +```toml +ComputeUnitPriceMax = 1000 # Default +``` + +ComputeUnitPriceMax is the maximum price per compute unit that a transaction can be bumped to + +### ComputeUnitPriceMin + +```toml +ComputeUnitPriceMin = 0 # Default +``` + +ComputeUnitPriceMin is the minimum price per compute unit that transaction can have + +### ComputeUnitPriceDefault + +```toml +ComputeUnitPriceDefault = 0 # Default +``` + +ComputeUnitPriceDefault is the default price per compute unit price, and the starting base fee when FeeEstimatorMode = 'fixed' + +### FeeBumpPeriod + +```toml +FeeBumpPeriod = '3s' # Default +``` + +FeeBumpPeriod is the amount of time before a tx is retried with a fee bump + +## Solana.Nodes + +```toml +[[Solana.Nodes]] +Name = 'primary' # Example +URL = 'http://solana.web' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://solana.web' # Example +``` + +URL is the HTTP(S) endpoint for this node. + +## Starknet + +```toml +[[Starknet]] +ChainID = 'foobar' # Example +Enabled = true # Default +OCR2CachePollPeriod = '5s' # Default +OCR2CacheTTL = '1m' # Default +RequestTimeout = '10s' # Default +TxTimeout = '10s' # Default +ConfirmationPoll = '5s' # Default +``` + +### ChainID + +```toml +ChainID = 'foobar' # Example +``` + +ChainID is the Starknet chain ID. + +### Enabled + +```toml +Enabled = true # Default +``` + +Enabled enables this chain. + +### OCR2CachePollPeriod + +```toml +OCR2CachePollPeriod = '5s' # Default +``` + +OCR2CachePollPeriod is the rate to poll for the OCR2 state cache. + +### OCR2CacheTTL + +```toml +OCR2CacheTTL = '1m' # Default +``` + +OCR2CacheTTL is the stale OCR2 cache deadline. + +### RequestTimeout + +```toml +RequestTimeout = '10s' # Default +``` + +RequestTimeout is the RPC client timeout. + +### TxTimeout + +```toml +TxTimeout = '10s' # Default +``` + +TxTimeout is the timeout for sending txes to an RPC endpoint. + +### ConfirmationPoll + +```toml +ConfirmationPoll = '5s' # Default +``` + +ConfirmationPoll is how often to confirmer checks for tx inclusion on chain. + +## Starknet.Nodes + +```toml +[[Starknet.Nodes]] +Name = 'primary' # Example +URL = 'http://stark.node' # Example +``` + +### Name + +```toml +Name = 'primary' # Example +``` + +Name is a unique (per-chain) identifier for this node. + +### URL + +```toml +URL = 'http://stark.node' # Example +``` + +URL is the base HTTP(S) endpoint for this node. diff --git a/src/scripts/nodes-config/config.json b/src/scripts/nodes-config/config.json new file mode 100644 index 00000000000..72dce1f718f --- /dev/null +++ b/src/scripts/nodes-config/config.json @@ -0,0 +1,21 @@ +{ + "owner": "smartcontractkit", + "repo": "chainlink", + "path": "docs/CONFIG.md", + "current-tags": [ + "v1.6.0", + "v1.7.0", + "v1.7.1", + "v1.8.0", + "v1.8.1", + "v1.9.0", + "v1.10.0", + "v1.11.0", + "v1.12.0", + "v1.13.0", + "v2.0.0", + "v2.1.0", + "v2.2.0", + "v2.3.0" + ] +} diff --git a/src/scripts/nodes-config/nodes-config.ts b/src/scripts/nodes-config/nodes-config.ts index a085f1a110e..682f26831d6 100644 --- a/src/scripts/nodes-config/nodes-config.ts +++ b/src/scripts/nodes-config/nodes-config.ts @@ -1,23 +1,20 @@ +import nodesConfig from "./config.json" import { Octokit } from "octokit" import { createTokenAuth } from "@octokit/auth-token" import fetch from "node-fetch" -import { writeFile, readFile } from "fs/promises" -import { normalize } from "path" +import { writeFile, readFile, mkdir, access } from "fs/promises" +import path, { normalize } from "path" import { format } from "prettier" - +import { rules } from "./transformation" import * as dotenv from "dotenv" -dotenv.config() -const nodesConfig = { - owner: "smartcontractkit", - repo: "chainlink", - path: "docs/CONFIG.md", - "current-tags": ["v1.6.0", "v1.7.0", "v1.7.1", "v1.8.0"], -} +dotenv.config() +const chainlinkNodesAbsolute = "/chainlink-nodes" +const nodesPageDir = `./src/pages${chainlinkNodesAbsolute}` const getTags = async () => { - const PAT = process.env.PAT - if (!PAT) throw new Error("PAT not found in .env") + const PAT = process.env.PAT_PUBLIC_READ + if (!PAT) throw new Error("PAT_PUBLIC_READ not found in .env") const auth = createTokenAuth(PAT) const authentication = await auth() const octokit = new Octokit({ @@ -54,22 +51,44 @@ const getTags = async () => { return response.repository.releases.edges.map((edge) => edge.node.tagName) } -const filterTags = (tags: string[]) => { +interface TagInfo { + tag: string + majorVersion: number +} + +const filterTags = (tags: string[]): TagInfo[] => { const currentTags = nodesConfig["current-tags"] as string[] // Test to follow this pattern: v0.8.1 , v0.8.11 , v0.11.12...Etc - const pattern = /^v\d{1,2}\.\d{1,2}\.\d{1,2}$/ + const pattern = /^v(\d{1,2})\.\d{1,2}\.\d{1,2}$/ + const result: TagInfo[] = [] + + tags.forEach((tag) => { + const match = pattern.exec(tag) + if (match && currentTags.indexOf(tag) === -1) { + if (Number(match[1]) === 0) { + // console.log("Skip tag:", tag) // no docs available for tags v0 + } else { + result.push({ + tag, + majorVersion: Number(match[1]), + }) + } + } + }) - return tags.filter((tag) => pattern.test(tag) && currentTags.indexOf(tag) === -1) + return result } -const sortTags = (tags: string[]) => { - return tags.sort((t1, t2) => { - // remove v - const tag1 = t1.slice(1) - const tag2 = t2.slice(1) +const sortTags = (tags: TagInfo[]): TagInfo[] => { + return tags.sort((a, b) => { + // Extract tag value from the TagInfo object + const tag1 = a.tag.slice(1) + const tag2 = b.tag.slice(1) const version1 = tag1.split(".").map((x) => parseInt(x)) const version2 = tag2.split(".").map((x) => parseInt(x)) - if (version1.length !== version2.length) throw new Error(`cannot sort tags ${t1},${t2}`) + + if (version1.length !== version2.length) throw new Error(`cannot sort tags ${a.tag},${b.tag}`) + for (let i = 0; i < version1.length; i++) { if (version1[i] < version2[i]) { return -1 @@ -77,42 +96,82 @@ const sortTags = (tags: string[]) => { return 1 } } + return 0 }) } -const updateIndex = async (tags: { tagName: string; path: string }[]) => { - if (tags.length === 0) return - const path = normalize(`./docs/chainlink-nodes/config/index.md`) - let data = (await readFile(path)).toString() +const updateIndex = async (results: { tagInfo: TagInfo; path: string }[]) => { + if (results.length === 0) return - for (const tag of tags) { - const entry = `- [${tag.tagName}](${tag.path})` - data = data.replace("**Topics**", `**Topics**\n${entry}`) + const defaultContent = `--- +layout: ../../../../layouts/MainLayout.astro +section: nodeOperator +date: Last Modified +title: "Configuring Chainlink Nodes" +--- + +**Topics**` + + // Group results by majorVersion + const groupedByVersion: { [key: number]: { tagInfo: TagInfo; path: string }[] } = {} + + for (const result of results) { + if (!groupedByVersion[result.tagInfo.majorVersion]) { + groupedByVersion[result.tagInfo.majorVersion] = [] + } + groupedByVersion[result.tagInfo.majorVersion].push(result) } - await writeFile( - path, - format(data, { - parser: "markdown", - semi: true, - trailingComma: "es5", - singleQuote: true, - printWidth: 120, - }), - { - flag: "w", + for (const majorVersion in groupedByVersion) { + const versionResults = groupedByVersion[majorVersion] + + // Build path for the current majorVersion's index.mdx + const indexDirPath = normalize(`${nodesPageDir}/v${majorVersion}/config`) + const indexPath = normalize(`${indexDirPath}/index.mdx`) + + // Ensure the directory and file exist + await mkdir(indexDirPath, { recursive: true }) + try { + await access(indexPath) // This will throw if file does not exist + } catch (error) { + await writeFile(indexPath, defaultContent) } - ) + + let data = (await readFile(indexPath)).toString() + + for (const result of versionResults) { + const entry = `- [${result.tagInfo.tag}](${result.path})` + data = data.replace("**Topics**", `**Topics**\n${entry}`) + } + + // Write updated data to the index.mdx + await writeFile( + indexPath, + data, + /* + format(data, { + parser: "markdown", + semi: true, + trailingComma: "es5", + singleQuote: true, + printWidth: 120, + }), + */ + { + flag: "w", + } + ) + } } -const updateTags = async (tags: { tagName: string; path: string }[]) => { - if (tags.length === 0) return - for (const tag of tags) { - ;(nodesConfig["current-tags"] as string[]).push(tag.tagName) +const updateTags = async (results: { tagInfo: TagInfo; path: string }[]) => { + if (results.length === 0) return + for (const result of results) { + ;(nodesConfig["current-tags"] as string[]).push(result.tagInfo.tag) } - const nodesConfigPath = normalize("./_src/reference/nodesConf.json") + const nodesConfigPath = normalize(path.join(__dirname, "config.json")) await writeFile( nodesConfigPath, format(JSON.stringify(nodesConfig), { @@ -128,35 +187,45 @@ const updateTags = async (tags: { tagName: string; path: string }[]) => { ) } -const writeConfigFile = async (tagName: string) => { +const writeConfigFile = async (tagInfo: TagInfo) => { const patternTagInFile = "__TAG__" const fileHeader = ` --- -layout: nodes.liquid +layout: ../../../../layouts/MainLayout.astro section: nodeOperator date: Last Modified title: "Configuring Chainlink Nodes" -permalink: "docs/chainlink-nodes/config/${patternTagInFile}/" --- +import { Aside } from "@components" ` - const tagInPath = tagName.replace(/\./g, "_") + const tagInPath = tagInfo.tag.replace(/\./g, "_") const clean = [ { from: ":warning:", to: "⚠️", }, ] - const path = normalize(`./docs/chainlink-nodes/config/${tagInPath}.md`) + const configDirPath = normalize(`${nodesPageDir}/v${tagInfo.majorVersion}/config`) + await mkdir(configDirPath, { recursive: true }) // ensure the directory is created if not exist + + const path = normalize(`${configDirPath}/${tagInPath}.mdx`) + const pathInPage = `${chainlinkNodesAbsolute}/v${tagInfo.majorVersion}/config/${tagInPath}` const url = normalize( - `https://raw.githubusercontent.com/${nodesConfig.owner}/${nodesConfig.repo}/${tagName}/${nodesConfig.path}` + `https://raw.githubusercontent.com/${nodesConfig.owner}/${nodesConfig.repo}/${tagInfo.tag}/${nodesConfig.path}` ) const response = await fetch(url) if (response.status === 200) { let data = await (await fetch(url)).text() + for (const rule of rules) { + data = rule(data) + } + /* for (const key in clean) { data = data.replace(new RegExp(clean[key].from, "g"), clean[key].to) } + */ + const content = fileHeader.replace(patternTagInFile, tagInPath) + data await writeFile( @@ -173,30 +242,32 @@ permalink: "docs/chainlink-nodes/config/${patternTagInFile}/" } ) - return { tagName, path: `/docs/chainlink-nodes/config/${tagInPath}/` } + return { tagInfo, path: pathInPage } } else if (response.status !== 404) { throw new Error(`couldn't fetch ${url}. status ${response.status}`) } - return { tagName: "", path: "" } + return { tagInfo: null, path: "" } } -const writeConfigFiles = async (tags: string[]) => { +const writeConfigFiles = async (tags: TagInfo[]) => { interface Result { - success: { tagName: string; path: string }[] + success: { tagInfo: TagInfo; path: string }[] error: { tag: string errorMessage: unknown }[] } const result: Result = { success: [], error: [] } - for (const tag of tags) { + + for (const tagInfo of tags) { try { - const successTag = await writeConfigFile(tag) - if (successTag.tagName) result.success.push(successTag) + const successTag = await writeConfigFile(tagInfo) + if (successTag.tagInfo) result.success.push(successTag) } catch (error) { - result.error.push({ tag, errorMessage: error }) + result.error.push({ tag: tagInfo.tag, errorMessage: error }) } } + return result } getTags().then(async (w) => { diff --git a/src/scripts/nodes-config/transformation.ts b/src/scripts/nodes-config/transformation.ts new file mode 100644 index 00000000000..1aa3705bf48 --- /dev/null +++ b/src/scripts/nodes-config/transformation.ts @@ -0,0 +1,42 @@ +const rule1 = (content: string): string => { + // This regex captures: + // 1. Everything between
and (including any HTML tags inside) + // 2. Everything after

and before

+ const regex = /
([\s\S]*?)<\/summary>

([\s\S]*?)<\/p><\/details>/g + + let transformedContent = content + + let match + while ((match = regex.exec(content)) !== null) { + // Removing potential HTML tags inside the summary + const headerContent = match[1].replace(/<[^>]*>/g, "").trim() + const header = `### ${headerContent}\n` + const innerContent = match[2].trim() + + transformedContent = transformedContent.replace(match[0], header + "\n\n" + innerContent + "\n") + } + + return transformedContent +} + +const rule2 = (content: string): string => { + // This regex captures the pattern :warning: followed by any text until a newline + const regex = /:warning: (.*?)(\n|$)/gm + + // Replacement pattern:

+ const transformedContent = content.replace(regex, '\n\n') + + return transformedContent +} + +const rule3 = (content: string): string => { + // This regex matches the specific pattern to be removed + const regex = /\[\/\/\]: # \(Documentation generated from docs(\/\*.toml)? - DO NOT EDIT.\)\n/g + + // Remove the matched pattern + const cleanedContent = content.replace(regex, "") + + return cleanedContent +} + +export const rules = [rule1, rule2, rule3] From 22f3de9784520dce5e653378d807a06cb2424b20 Mon Sep 17 00:00:00 2001 From: aelmanaa Date: Mon, 31 Jul 2023 17:15:59 +0200 Subject: [PATCH 4/5] nodes config --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 7dcfe64cceb..e8c5c4547ca 100644 --- a/package.json +++ b/package.json @@ -93,7 +93,7 @@ }, "lint-staged": { "*.{css,md,mdx,yml,yaml,astro}": "prettier --write", - "*.{js,ts}": [ + "*.{js,ts,json}": [ "prettier --write", "eslint" ], From 97e09f82c1155404935ab80dc905b91d91c14318 Mon Sep 17 00:00:00 2001 From: aelmanaa Date: Mon, 31 Jul 2023 17:26:07 +0200 Subject: [PATCH 5/5] nodes config --- src/pages/chainlink-nodes/v1/config/index.mdx | 21 +++++++++++++++++++ .../chainlink-nodes/v1/config/v1_6_0.mdx | 1 - .../chainlink-nodes/v1/config/v1_7_0.mdx | 1 - .../chainlink-nodes/v1/config/v1_7_1.mdx | 1 - .../chainlink-nodes/v1/config/v1_8_0.mdx | 1 - .../chainlink-nodes/v1/config/v1_8_1.mdx | 1 - .../chainlink-nodes/v1/config/v1_9_0.mdx | 1 - src/pages/chainlink-nodes/v2/config/index.mdx | 9 ++++++++ src/scripts/nodes-config/transformation.ts | 5 +++-- 9 files changed, 33 insertions(+), 8 deletions(-) diff --git a/src/pages/chainlink-nodes/v1/config/index.mdx b/src/pages/chainlink-nodes/v1/config/index.mdx index 844c3aef3f6..3afea4612fc 100644 --- a/src/pages/chainlink-nodes/v1/config/index.mdx +++ b/src/pages/chainlink-nodes/v1/config/index.mdx @@ -7,6 +7,27 @@ title: "Configuring Chainlink Nodes" **Topics** +- [v1.13.0](/chainlink-nodes/v1/config/v1_13_0) +- [v1.12.0](/chainlink-nodes/v1/config/v1_12_0) +- [v1.11.0](/chainlink-nodes/v1/config/v1_11_0) +- [v1.10.0](/chainlink-nodes/v1/config/v1_10_0) +- [v1.9.0](/chainlink-nodes/v1/config/v1_9_0) +- [v1.8.1](/chainlink-nodes/v1/config/v1_8_1) +- [v1.8.0](/chainlink-nodes/v1/config/v1_8_0) +- [v1.7.1](/chainlink-nodes/v1/config/v1_7_1) +- [v1.7.0](/chainlink-nodes/v1/config/v1_7_0) +- [v1.6.0](/chainlink-nodes/v1/config/v1_6_0) +- [v1.13.0](/chainlink-nodes/v1/config/v1_13_0) +- [v1.12.0](/chainlink-nodes/v1/config/v1_12_0) +- [v1.11.0](/chainlink-nodes/v1/config/v1_11_0) +- [v1.10.0](/chainlink-nodes/v1/config/v1_10_0) +- [v1.9.0](/chainlink-nodes/v1/config/v1_9_0) +- [v1.8.1](/chainlink-nodes/v1/config/v1_8_1) +- [v1.8.0](/chainlink-nodes/v1/config/v1_8_0) +- [v1.7.1](/chainlink-nodes/v1/config/v1_7_1) +- [v1.7.0](/chainlink-nodes/v1/config/v1_7_0) +- [v1.6.0](/chainlink-nodes/v1/config/v1_6_0) + - [v1.13.0](/chainlink-nodes/v1/config/v1_13_0) - [v1.12.0](/chainlink-nodes/v1/config/v1_12_0) - [v1.11.0](/chainlink-nodes/v1/config/v1_11_0) diff --git a/src/pages/chainlink-nodes/v1/config/v1_6_0.mdx b/src/pages/chainlink-nodes/v1/config/v1_6_0.mdx index d8658867337..b91ec565adf 100644 --- a/src/pages/chainlink-nodes/v1/config/v1_6_0.mdx +++ b/src/pages/chainlink-nodes/v1/config/v1_6_0.mdx @@ -6,7 +6,6 @@ title: "Configuring Chainlink Nodes" --- import { Aside } from "@components" -[//]: # (Documentation generated from docs.toml - DO NOT EDIT.) ## Table of contents diff --git a/src/pages/chainlink-nodes/v1/config/v1_7_0.mdx b/src/pages/chainlink-nodes/v1/config/v1_7_0.mdx index e941dfd8057..c353c44935a 100644 --- a/src/pages/chainlink-nodes/v1/config/v1_7_0.mdx +++ b/src/pages/chainlink-nodes/v1/config/v1_7_0.mdx @@ -6,7 +6,6 @@ title: "Configuring Chainlink Nodes" --- import { Aside } from "@components" -[//]: # (Documentation generated from docs.toml - DO NOT EDIT.) ## Table of contents diff --git a/src/pages/chainlink-nodes/v1/config/v1_7_1.mdx b/src/pages/chainlink-nodes/v1/config/v1_7_1.mdx index e941dfd8057..c353c44935a 100644 --- a/src/pages/chainlink-nodes/v1/config/v1_7_1.mdx +++ b/src/pages/chainlink-nodes/v1/config/v1_7_1.mdx @@ -6,7 +6,6 @@ title: "Configuring Chainlink Nodes" --- import { Aside } from "@components" -[//]: # (Documentation generated from docs.toml - DO NOT EDIT.) ## Table of contents diff --git a/src/pages/chainlink-nodes/v1/config/v1_8_0.mdx b/src/pages/chainlink-nodes/v1/config/v1_8_0.mdx index 8726bb464c5..cc04ad00b1f 100644 --- a/src/pages/chainlink-nodes/v1/config/v1_8_0.mdx +++ b/src/pages/chainlink-nodes/v1/config/v1_8_0.mdx @@ -6,7 +6,6 @@ title: "Configuring Chainlink Nodes" --- import { Aside } from "@components" -[//]: # (Documentation generated from docs.toml - DO NOT EDIT.) ## Table of contents diff --git a/src/pages/chainlink-nodes/v1/config/v1_8_1.mdx b/src/pages/chainlink-nodes/v1/config/v1_8_1.mdx index c05c556561a..8a6a3ddb940 100644 --- a/src/pages/chainlink-nodes/v1/config/v1_8_1.mdx +++ b/src/pages/chainlink-nodes/v1/config/v1_8_1.mdx @@ -6,7 +6,6 @@ title: "Configuring Chainlink Nodes" --- import { Aside } from "@components" -[//]: # (Documentation generated from docs.toml - DO NOT EDIT.) ## Table of contents diff --git a/src/pages/chainlink-nodes/v1/config/v1_9_0.mdx b/src/pages/chainlink-nodes/v1/config/v1_9_0.mdx index aee7f1f4117..c4babd22dc2 100644 --- a/src/pages/chainlink-nodes/v1/config/v1_9_0.mdx +++ b/src/pages/chainlink-nodes/v1/config/v1_9_0.mdx @@ -6,7 +6,6 @@ title: "Configuring Chainlink Nodes" --- import { Aside } from "@components" -[//]: # (Documentation generated from docs.toml - DO NOT EDIT.) ## Table of contents diff --git a/src/pages/chainlink-nodes/v2/config/index.mdx b/src/pages/chainlink-nodes/v2/config/index.mdx index 12dafb8649a..199f7f76df7 100644 --- a/src/pages/chainlink-nodes/v2/config/index.mdx +++ b/src/pages/chainlink-nodes/v2/config/index.mdx @@ -7,6 +7,15 @@ title: "Configuring Chainlink Nodes" **Topics** +- [v2.3.0](/chainlink-nodes/v2/config/v2_3_0) +- [v2.2.0](/chainlink-nodes/v2/config/v2_2_0) +- [v2.1.0](/chainlink-nodes/v2/config/v2_1_0) +- [v2.0.0](/chainlink-nodes/v2/config/v2_0_0) +- [v2.3.0](/chainlink-nodes/v2/config/v2_3_0) +- [v2.2.0](/chainlink-nodes/v2/config/v2_2_0) +- [v2.1.0](/chainlink-nodes/v2/config/v2_1_0) +- [v2.0.0](/chainlink-nodes/v2/config/v2_0_0) + - [v2.3.0](/chainlink-nodes/v2/config/v2_3_0) - [v2.2.0](/chainlink-nodes/v2/config/v2_2_0) - [v2.1.0](/chainlink-nodes/v2/config/v2_1_0) diff --git a/src/scripts/nodes-config/transformation.ts b/src/scripts/nodes-config/transformation.ts index 1aa3705bf48..9747e4f4ddf 100644 --- a/src/scripts/nodes-config/transformation.ts +++ b/src/scripts/nodes-config/transformation.ts @@ -31,10 +31,11 @@ const rule2 = (content: string): string => { const rule3 = (content: string): string => { // This regex matches the specific pattern to be removed - const regex = /\[\/\/\]: # \(Documentation generated from docs(\/\*.toml)? - DO NOT EDIT.\)\n/g + const regex1 = /\[\/\/\]: # \(Documentation generated from docs(\/\*.toml)? - DO NOT EDIT.\)(\r\n|\n)/g + const regex2 = /\[\/\/\]: # \(Documentation generated from docs\.toml - DO NOT EDIT\.\)(\r\n|\n)?/g // Remove the matched pattern - const cleanedContent = content.replace(regex, "") + const cleanedContent = content.replace(regex1, "").replace(regex2, "") return cleanedContent }