Skip to content

Latest commit

 

History

History
732 lines (662 loc) · 155 KB

configuration.md

File metadata and controls

732 lines (662 loc) · 155 KB

Configuration

The components of the Hedera Mirror Node all support loading configuration from an application.yml file or via the environment.

Default Values

The default configuration allows users to quickly get up and running without having to configure anything. This provides ease of use at the trade-off of some insecure default configuration. Most configuration settings have appropriate defaults and can be left unchanged. It is recommended to browse the properties below and adjust to your needs.

One of the important settings that should be changed for all components is the network property as it controls which of the Hedera networks to mirror. Additionally, the password properties have a default, but it is strongly recommended passwords be changed from the default.

Depending upon your deployment tool, the process to modify this configuration may vary. For our Helm charts, we do support automatic generation of random passwords.

Importer

The Importer component uses Spring Boot properties to configure the application. As a result, property files, YAML files, environment variables and command-line arguments can all be used to configure the application. See the Spring Boot documentation for the location and order it loads configuration.

The following table lists the available properties along with their default values. Unless you need to set a non-default value, it is recommended to only populate overridden properties in the custom application.yml.

Name Default Description
hedera.mirror.importer.cache.addressBook maximumSize=100,expireAfterWrite=5m,recordStats The Caffeine cache specification for the address book.
hedera.mirror.importer.cache.alias maximumSize=100000,expireAfterAccess=30m,recordStats The Caffeine cache specification for alias or EVM address to entity ID mapping.
hedera.mirror.importer.cache.enabled true Whether caching should be enabled at all.
hedera.mirror.importer.cache.timePartition maximumSize=50,expireAfterWrite=1d,recordStats The Caffeine cache specification for time partition lookups.
hedera.mirror.importer.cache.timePartitionOverlap maximumSize=50,expireAfterWrite=1d,recordStats The Caffeine cache specification for time partition overlap lookups.
hedera.mirror.importer.consensusMode STAKE_IN_ADDRESS_BOOK The consensus mode to determine minimum consensus stake. See the ConsensusMode enum for a list of possible values
hedera.mirror.importer.dataPath ./data The data directory used to store downloaded files and other application state
hedera.mirror.importer.db.connectionInitSql set temp_buffers='256MB'; set timezone TO 'UTC'; Sql ran on each connection initialized from the datasource
hedera.mirror.importer.db.host 127.0.0.1 The IP or hostname used to connect to the database
hedera.mirror.importer.db.loadBalance true Whether to enable pgpool load balancing. If false, it sends all reads to the primary db backend instead of load balancing them across the primary and replicas.
hedera.mirror.importer.db.metricRefreshInterval 5m The interval which we wait to refresh database statistics. Specified as a spring duration expression
hedera.mirror.importer.db.name mirror_node The name of the database
hedera.mirror.importer.db.owner mirror_node The username of the db user with owner permissions to create and modify the schema
hedera.mirror.importer.db.ownerPassword mirror_node_pass The password for the owner user the processor uses to connect.
hedera.mirror.importer.db.partition.cron 0 0 0 * * ? The cron schedule for creating new partitions This is applicable to the v2 database schema
hedera.mirror.importer.db.partition.enabled true Whether new partitions should be created automatically. This is applicable to the v2 database schema
hedera.mirror.importer.db.password mirror_importer_pass The database password for the Importer user the processor uses to connect.
hedera.mirror.importer.db.port 5432 The port used to connect to the database
hedera.mirror.importer.db.restPassword mirror_api_pass The database password the API uses to connect.
hedera.mirror.importer.db.restUsername mirror_api The username the API uses to connect to the database
hedera.mirror.importer.db.schema public The name of the custom schema database objects will be created in. This is applicable from v2 of the data schema
hedera.mirror.importer.db.username mirror_importer The Importer username the processor uses to connect to the database
hedera.mirror.importer.downloader.accessKey "" The cloud storage access key
hedera.mirror.importer.downloader.allowAnonymousAccess Whether the cloud storage bucket allows for anonymous access.
hedera.mirror.importer.downloader.balance.enabled false Whether to enable balance file downloads
hedera.mirror.importer.downloader.balance.frequency 30s The fixed period between invocations. Can accept duration units like 10s, 2m, etc. If not specified, millisecond is implied as the unit.
hedera.mirror.importer.downloader.balance.persistBytes false Whether to persist the balance file bytes to the database.
hedera.mirror.importer.downloader.balance.writeFiles false Whether to write verified stream files to the filesystem.
hedera.mirror.importer.downloader.balance.writeSignatures false Whether to write verified signature files to the filesystem.
hedera.mirror.importer.downloader.batchSize 25 The number of signature files to download per node before downloading the signed files
hedera.mirror.importer.downloader.bucketName The cloud storage bucket name to download streamed files. This value takes priority over network hardcoded bucket names regardless of hedera.mirror.importer.network value.
hedera.mirror.importer.downloader.cloudProvider S3 The cloud provider to download files from. Either GCP, LOCAL, or S3.
hedera.mirror.importer.downloader.consensusRatio 0.33333333333 The ratio of verified nodes (nodes used to come to consensus on the signature file hash) to total number of nodes available.
hedera.mirror.importer.downloader.downloadRatio 1 The ratio of nodes (or stake) to be concurrently downloaded to verify signatures to total number of nodes (or stake) available.
hedera.mirror.importer.downloader.endpointOverride Can be specified to download streams from a source other than S3 and GCP. Should be S3 compatible
hedera.mirror.importer.downloader.gcpProjectId GCP project id to bill for requests to GCS bucket which has Requester Pays enabled.
hedera.mirror.importer.downloader.local.deleteAfterProcessing true Whether to delete files downloaded locally after successfully processing them.
hedera.mirror.importer.downloader.maxSize 52428800 The maximum size in bytes of stream files to consider for downloading.
hedera.mirror.importer.downloader.pathType ACCOUNT_ID The bucket structure path type to assume for all consensus nodes when downloading streams via the stream file provider. Either ACCOUNT_ID (legacy), NODE_ID (HIP-679), or AUTO (detect at runtime, per consensus node)
hedera.mirror.importer.downloader.record.enabled true Whether to enable record file downloads
hedera.mirror.importer.downloader.record.frequency 500ms The fixed period between invocations. Can accept duration units like 10s, 2m, etc. If not specified, millisecond is implied as the unit.
hedera.mirror.importer.downloader.record.persistBytes false Whether to persist the record file bytes to the database.
hedera.mirror.importer.downloader.record.writeFiles false Whether to write verified stream files to the filesystem.
hedera.mirror.importer.downloader.record.writeSignatures false Whether to write verified signature files to the filesystem.
hedera.mirror.importer.downloader.region us-east-1 The region associated with the bucket
hedera.mirror.importer.downloader.secretKey "" The cloud storage secret key
hedera.mirror.importer.downloader.sources [] A list of download sources to use for stream files. The grandfathered hedera.mirror.importer.downloader will also be utilized as the first source in the list.
hedera.mirror.importer.downloader.sources.backoff 60s The amount of time to wait before retrying a source after an exception
hedera.mirror.importer.downloader.sources.connectionTimeout 5s The amount of time to wait for a connection before throwing an exception
hedera.mirror.importer.downloader.sources.credentials.accessKey The cloud storage access key for the given source
hedera.mirror.importer.downloader.sources.credentials.secretKey The cloud storage secret key for the given source
hedera.mirror.importer.downloader.sources.maxConcurrency 1000 The maximum number of allowed open HTTP connections. Used by AWS SDK directly.
hedera.mirror.importer.downloader.sources.projectId The cloud project ID to bill for requests to the bucket which has requester pays enabled.
hedera.mirror.importer.downloader.sources.region us-east-1 The region associated with the bucket
hedera.mirror.importer.downloader.sources.type The source type to download files from. Either GCP, LOCAL, or S3.
hedera.mirror.importer.downloader.sources.uri The endpoint override URI to use as an alternate for the default URI provided by the source type.
hedera.mirror.importer.downloader.timeout 30s The amount of time to wait for a download before throwing an exception
hedera.mirror.importer.endDate 2262-04-11T23:47:16.854775807Z The end date (inclusive) of the data to import. Items after this date will be ignored. Format: YYYY-MM-ddTHH:mm:ss.nnnnnnnnnZ
hedera.mirror.importer.importHistoricalAccountInfo true Import historical account information that occurred before the last stream reset. Skipped if startDate is unset or after 2019-09-14T00:00:10Z.
hedera.mirror.importer.initialAddressBook "" The path to the bootstrap address book used to override the built-in address book
hedera.mirror.importer.migration.<migrationName>.checksum 1 The checksum of the repeatable migration. Change it to a different value to re-run the migration
hedera.mirror.importer.migration.<migrationName>.enabled true Whether to enable the repeatable migration
hedera.mirror.importer.network demo Which Hedera network to use. Recognized names are demo, mainnet, other, testnet, and previewnet. Other names are allowed but are treated as development or test networks.
hedera.mirror.importer.nodePublicKey A X509 public key in DER format encoded to hexadecimal. Used to override each node's public key in the address book solely for testing manually generated stream files.
hedera.mirror.importer.parser.balance.batchSize 200000 The number of balances to store in memory before saving to the database
hedera.mirror.importer.parser.balance.batch.flushInterval 2s The amount of time to wait before a batch is flushed to be persisted by the parser
hedera.mirror.importer.parser.balance.batch.maxFiles 1 The maximum number of files to consider for batching before being persistedy by the parser
hedera.mirror.importer.parser.balance.batch.maxItems 1000000 The maximum number of items across multiple files to consider for batching before being persistedy by the parser
hedera.mirror.importer.parser.balance.batch.queueCapacity 1 How many balance files to queue in memory while waiting to be persisted by the parser
hedera.mirror.importer.parser.balance.batch.window 5m The amount of time the importer has to be behind before starting to batch stream files
hedera.mirror.importer.parser.balance.enabled true Whether to enable balance file parsing
hedera.mirror.importer.parser.balance.fileBufferSize 200000 The size of the buffer to use when reading in the balance file
hedera.mirror.importer.parser.balance.frequency 1s How often to poll for new messages. Can accept duration units like 10s, 2m etc. If not specified, millisecond is implied as the unit.
hedera.mirror.importer.parser.balance.processingTimeout 10s The additional timeout to allow after the last balance stream file health check to verify that files are still being processed.
hedera.mirror.importer.parser.balance.retry.maxAttempts 3 How many attempts should be made to retry file parsing errors
hedera.mirror.importer.parser.balance.retry.maxBackoff 10s The maximum amount of time to wait between retries
hedera.mirror.importer.parser.balance.retry.minBackoff 250ms The minimum amount of time to wait between retries
hedera.mirror.importer.parser.balance.retry.multiplier 2 Used to generate the next delay for backoff
hedera.mirror.importer.parser.balance.transactionTimeout 5m The timeout for a database transaction
hedera.mirror.importer.parser.bufferSize 32768 The size of the byte buffer to allocate for each batch
hedera.mirror.importer.parser.exclude [] A list of filters that determine which transactions are ignored. Takes precedence over include
hedera.mirror.importer.parser.exclude.entity [] A list of entity IDs to ignore in shard.realm.num (e.g. 0.0.3) format
hedera.mirror.importer.parser.exclude.expression A restricted Spring Expression Language (SpEL) expression which when evaluated to true ignores the transaction
hedera.mirror.importer.parser.exclude.transaction [] A list of transaction types to ignore. See TransactionType.java for possible values
hedera.mirror.importer.parser.include [] A list of filters that determine which transactions are stored
hedera.mirror.importer.parser.include.entity [] A list of entity IDs to store in shard.realm.num (e.g. 0.0.3) format
hedera.mirror.importer.parser.include.expression A restricted Spring Expression Language (SpEL) expression which when evaluated to true includes the transaction
hedera.mirror.importer.parser.include.transaction [] A list of transaction types to store. See TransactionType.java for possible values
hedera.mirror.importer.parser.record.batch.flushInterval 2s The amount of time to wait before a batch is flushed to be persisted by the parser
hedera.mirror.importer.parser.record.batch.maxFiles 1 The maximum number of files to consider for batching before being persistedy by the parser
hedera.mirror.importer.parser.record.batch.maxItems 60000 The maximum number of items across multiple files to consider for batching before being persistedy by the parser
hedera.mirror.importer.parser.record.batch.queueCapacity 10 How many balance files to queue in memory while waiting to be persisted by the parser
hedera.mirror.importer.parser.record.batch.window 5m The amount of time the importer has to be behind before starting to batch stream files
hedera.mirror.importer.parser.record.enabled true Whether to enable record file parsing
hedera.mirror.importer.parser.record.entity.notify.enabled false Whether to use PostgreSQL Notify to send topic messages to the gRPC process
hedera.mirror.importer.parser.record.entity.notify.maxJsonPayloadSize 8000 Max number of bytes for json payload used in pg_notify of db inserts
hedera.mirror.importer.parser.record.entity.persist.claims false Persist claim data to the database
hedera.mirror.importer.parser.record.entity.persist.contracts true Persist contract data to the database
hedera.mirror.importer.parser.record.entity.persist.contractResults true Persist contract results data to the database
hedera.mirror.importer.parser.record.entity.persist.contractTransaction true Persist contract transaction parties (records results, logs, and state changes
hedera.mirror.importer.parser.record.entity.persist.contractTransactionHash true Persist contract result transaction hash data to the database
hedera.mirror.importer.parser.record.entity.persist.cryptoTransferAmounts true Persist crypto transfer amounts to the database
hedera.mirror.importer.parser.record.entity.persist.entityHistory true Persist entity history to the database. When set to false, historical entity changes except entity creation are ignored. Use with caution since disabling it will break logic depending on accurate entity historical state.
hedera.mirror.importer.parser.record.entity.persist.entityTransactionExclusion ["0.0.98", "0.0.800"] Entity IDs excluded from transaction tracking
hedera.mirror.importer.parser.record.entity.persist.entityTransactions false Persist entity transactions to the database
hedera.mirror.importer.parser.record.entity.persist.ethereumTransactions true Persist all ethereum transactions data to the database
hedera.mirror.importer.parser.record.entity.persist.files true Persist all file data to the database
hedera.mirror.importer.parser.record.entity.persist.itemizedTransfers false Persist itemized transfers for transactions that explicitly request hbar transfers
hedera.mirror.importer.parser.record.entity.persist.nodes true Persist node transaction data to the database
hedera.mirror.importer.parser.record.entity.persist.pendingReward true Calculate pending reward and update entity stake state
hedera.mirror.importer.parser.record.entity.persist.schedules true Persist schedule transactions to the database
hedera.mirror.importer.parser.record.entity.persist.syntheticContractLogs true Persist synthetic contract logs from HAPI transaction to the database
hedera.mirror.importer.parser.record.entity.persist.syntheticContractResults false Persist synthetic contract results from HAPI transaction to the database
hedera.mirror.importer.parser.record.entity.persist.systemFiles true Persist only system files (number lower than 1000) to the database
hedera.mirror.importer.parser.record.entity.persist.tokenAirdrops true Persist token airdrop data to the database
hedera.mirror.importer.parser.record.entity.persist.tokens true Persist token data to the database
hedera.mirror.importer.parser.record.entity.persist.topics true Persist topic messages to the database
hedera.mirror.importer.parser.record.entity.persist.topicMessageLookups false Persist topic message lookups to the database
hedera.mirror.importer.parser.record.entity.persist.trackAllowance true Track remaining crypto and fungible token allowance amounts by debiting approved transfers from original grant amount and persist to the database
hedera.mirror.importer.parser.record.entity.persist.trackBalance true Track entity balance changes and persist to the database
hedera.mirror.importer.parser.record.entity.persist.trackNonce true Track nonce changes and persist to the entity database
hedera.mirror.importer.parser.record.entity.persist.transactionBytes false Persist raw transaction bytes to the database
hedera.mirror.importer.parser.record.entity.persist.transactionHash true Persist transaction hash to the database
hedera.mirror.importer.parser.record.entity.persist.transactionHashTypes All except CONSENSUSSUBMITMESSAGE A set of transaction types to persist transaction hash for
hedera.mirror.importer.parser.record.entity.persist.transactionRecordBytes false Persist raw transaction record bytes to the database
hedera.mirror.importer.parser.record.entity.persist.transactionSignatures SCHEDULECREATE, SCHEDULESIGN A list of transaction types whose transaction signatures will be stored
hedera.mirror.importer.parser.record.entity.redis.enabled true Whether to use Redis to send messages to the gRPC process. Requires spring.redis.* properties
hedera.mirror.importer.parser.record.entity.redis.queueCapacity 8 The size of the queue used to buffer topic messages between parser and redis publisher threads
hedera.mirror.importer.parser.record.entity.sql.enabled true Whether to use PostgreSQL Copy mechanism to insert into the database
hedera.mirror.importer.parser.record.frequency 20ms How often to poll for new messages. Can accept duration units like 10s, 2m etc. If not specified, millisecond is implied as the unit.
hedera.mirror.importer.parser.record.historicalBalance.enabled true Whether to enable historical balances service to generate balances information
hedera.mirror.importer.parser.record.historicalBalance.initialDelay 2m Initial delay for environments in which the consensus nodes don't produce account balance files. Can accept duration units like 10s, 2m etc.
hedera.mirror.importer.parser.record.historicalBalance.minFrequency 15m How often at least to generate balances information. Can accept duration units like 10s, 2m etc. The minimum allowed value is 15m, and the maximum is 7d.
hedera.mirror.importer.parser.record.historicalBalance.tokenBalances true Whether to generate token balances information.
hedera.mirror.importer.parser.record.historicalBalance.transactionTimeout 10m The timeout in seconds for the database transaction to generate balances information.
hedera.mirror.importer.parser.record.processingTimeout 10s The additional timeout to allow after the last record stream file health check to verify that files are still being processed.
hedera.mirror.importer.parser.record.pubsub.topicName Pubsub topic to publish transactions to
hedera.mirror.importer.parser.record.pubsub.maxSendAttempts 5 Number of attempts when sending messages to PubSub (only for retryable errors)
hedera.mirror.importer.parser.record.retry.maxAttempts Integer.MAX_VALUE How many attempts should be made to retry file parsing errors
hedera.mirror.importer.parser.record.retry.maxBackoff 30s The maximum amount of time to wait between retries
hedera.mirror.importer.parser.record.retry.minBackoff 500ms The minimum amount of time to wait between retries
hedera.mirror.importer.parser.record.retry.multiplier 2 Used to generate the next delay for backoff
hedera.mirror.importer.parser.record.sidecar.enabled false Whether to download and read sidecar record files
hedera.mirror.importer.parser.record.sidecar.persistBytes false Whether to persist the sidecar file bytes to the database
hedera.mirror.importer.parser.record.sidecar.types [] Which types of transaction sidecar records to process. By default it is empty to indicate all types. Accepts CONTRACT_ACTION, CONTRACT_BYTECODE, or CONTRACT_STATE_CHANGE.
hedera.mirror.importer.parser.record.transactionTimeout 120s The timeout in seconds for a database transaction
hedera.mirror.importer.reconciliation.cron 0 0 0 * * * When to run the balance reconciliation job. Defaults to once a day at midnight. See Spring docs.
hedera.mirror.importer.reconciliation.delay 1s How much time to wait in between balance files
hedera.mirror.importer.reconciliation.enabled false Whether the balance reconciliation job should periodically run to reconcile data.
hedera.mirror.importer.reconciliation.endDate 2262-04-11T23:47:16.854775807Z The consensus timestamp of the last balance file to reconcile.
hedera.mirror.importer.reconciliation.remediationStrategy FAIL The strategy to use to handle errors. Can be ACCUMULATE, RESET, or FAIL. ACCUMULATE and RESET will both proceed after an error, but RESET will correct the balances while ACCUMULATE does not
hedera.mirror.importer.reconciliation.startDate 1970-01-01T00:00:00Z The consensus timestamp of the first balance file to reconcile.
hedera.mirror.importer.reconciliation.token false Whether to reconcile token information.
hedera.mirror.importer.retention.batchPeriod 1d How often to commit deletions when pruning.
hedera.mirror.importer.retention.enabled false Whether to data retention should be enabled to purge older data.
hedera.mirror.importer.retention.exclude [] Which tables to exclude when pruning data. By default it is empty to indicate no tables will be excluded from retention.
hedera.mirror.importer.retention.frequency 1d How often to run the retention job to purge older data. If it is already running from a previous period, skip execution. If not specified, millisecond is implied as the unit.
hedera.mirror.importer.retention.include [] Which tables to include when pruning data. By default it is empty to indicate all tables that can be pruned will be.
hedera.mirror.importer.retention.period 90d How far in the past to remove data. This value is relative to the timestamp of the last transaction in the database and not to the current time.
hedera.mirror.importer.topicRunningHashV2AddedTimestamp Network-based Unix timestamp (in nanos) of first topic message with v2 as running hash version. Use this config to override the default network based value
hedera.mirror.importer.shard 0 The default shard number that the component participates in
hedera.mirror.importer.startDate The start date (inclusive) of the data to import. It takes effect 1) if it's set and the date is after the last downloaded file or the database is empty; 2) if it's not set and the database is empty, it defaults to now. Format: YYYY-MM-ddTHH:mm:ss.nnnnnnnnnZ
hedera.mirror.importer.startBlockNumber null The block number that will be set as the downloaded stream files starting index.

Transaction and Entity Filtering

The mirror node may be configured to only store a subset of data for entities and/or transaction types of interest -- essentially, which rows of data to retain. Note that the exclude properties take priority over the include properties - if you list the same value in both lists, it will be excluded. In addition, the various boolean hedera.mirror.importer.record.entity.persist properties may be specified to control which additional fields get stored (which additional tables get recorded). See the hedera.mirror.importer.parser.include.* and hedera.mirror.importer.parser.exclude.* properties listed in the table above for full details.

Spring Expression Language Support

Spring Expression Language (SpEL) expressions may also be utilized for including or excluding transactions. The mirror node sets up a restricted evaluation context and parses and evaluates the supplied expressions.

Expression restrictions include:

  • Each transaction is represented by a record item. Only the top-level transactionBody and transactionRecord properties may be referenced. These are respectively the TransactionBody and TransactionRecord protocol buffers defined in the Java SDK. These are immutable and you can refer to them to see what may be accessed as sub properties etc.
  • Mirror node Spring beans (using @) cannot be accessed within an expression.
  • Arbitrary types (mirror node, dependencies, Java) such as T(java.lang.Runtime) or T(com.hedera.mirror.importer.SomeClass) cannot be accessed within an expression.
  • No property can be written to.
  • The expression must evaluate to a boolean value.
  • Since expressions may contain Java code, enclosing them within single or double quotes will help prevent errors when read from YAML or properties configuration files.

For any property resolved, the methods it supports is not restricted. For example, TransactionBody.memo is a String, and any public methods on that type can be invoked. Thus the following are all acceptable expressions returning a boolean value:

transactionBody.memo.startsWith("MyApp")
transactionBody.memo.contains("Some value")
transactionBody.memo.length() > 10 && transactionBody.memo.startsWith("MyApp")

One objective is to provide sufficient access to support powerful expressions while limiting the SpEL injection attack surface. Keep in mind though, transaction filter configuration properties are set by mirror node operators, so intentionally injecting oneself should be a rare occurrence.

Another important goal is to not expose too many mirror node implementation details, which may change in future releases, possibly breaking filter expressions that functioned properly in the past.

Filtering Example

The scenario we wish to model is the same for each of the three configuration formats. Only choose one of the three ways to configure your instance of the mirror node.

  • We wish to omit all records (regardless of transaction type) that are associated with account 0.0.98, which is the account representing the network (to which fees generally get paid to).
  • We are interested in all CRYPTOTRANSFER transactions, for all accounts other than 0.0.98.
  • We are interested in accounts 0.0.1000 and 0.0.1001, and wish to store all their transactions, regardless of transaction type.
  • We are also interested in system files 0.0.101 and 0.0.102, and wish to store all their FILEAPPEND, FILECREATE, FILEDELETE, and FILEUPDATE transactions.
  • For all CONTRACTCREATEINSTANCE transactions, we are only interested in those where the renewal account number is 2000.
  • We do not wish to persist message topics for any transactions we do store.

application.yml

To configure the above scenario via application.yml file, include the following lines:

hedera:
  mirror:
    importer:
      parser:
        exclude:
          - entity: [0.0.98]
        include:
          - transaction: [CRYPTOTRANSFER]
          - entity: [0.0.1000, 0.0.1001]
          - entity: [0.0.101, 0.0.102]
            transaction: [FILEAPPEND, FILECREATE, FILEDELETE, FILEUPDATE]
          - transaction: [CONTRACTCREATEINSTANCE]
            expression: "transactionBody.contractCreateInstance.autoRenewAccountId.accountNum == 2000"
        record:
          entity:
            persist:
              topics: false

application.properties

To configure the above scenario via application.properties file, include the following lines:

hedera.mirror.importer.parser.exclude[0].entity[0]=0.0.98
hedera.mirror.importer.parser.include[0].transaction[0]=CRYPTOTRANSFER
hedera.mirror.importer.parser.include[1].entity[0]=0.0.1000
hedera.mirror.importer.parser.include[1].entity[1]=0.0.1001
hedera.mirror.importer.parser.include[2].entity[0]=0.0.101
hedera.mirror.importer.parser.include[2].entity[1]=0.0.102
hedera.mirror.importer.parser.include[2].transaction[0]=FILEAPPEND
hedera.mirror.importer.parser.include[2].transaction[1]=FILECREATE
hedera.mirror.importer.parser.include[2].transaction[2]=FILEDELETE
hedera.mirror.importer.parser.include[2].transaction[3]=FILEUPDATE
hedera.mirror.importer.parser.include[3].transaction[0]=CONTRACTCREATEINSTANCE
hedera.mirror.importer.parser.include[3].expression="transactionBody.contractCreateInstance.autoRenewAccountId.accountNum == 2000"
hedera.mirror.importer.parser.record.entity.persist.topics=false

Environment variables

To configure the above scenario via environmental variables, set the following:

HEDERA_MIRROR_IMPORTER_PARSER_EXCLUDE_0_ENTITY_0_: 0.0.98
HEDERA_MIRROR_IMPORTER_PARSER_INCLUDE_0_TRANSACTION_0_: CRYPTOTRANSFER
HEDERA_MIRROR_IMPORTER_PARSER_INCLUDE_1_ENTITY_0_: 0.0.1000
HEDERA_MIRROR_IMPORTER_PARSER_INCLUDE_1_ENTITY_1_: 0.0.1001
HEDERA_MIRROR_IMPORTER_PARSER_INCLUDE_2_ENTITY_0_: 0.0.101
HEDERA_MIRROR_IMPORTER_PARSER_INCLUDE_2_ENTITY_1_: 0.0.102
HEDERA_MIRROR_IMPORTER_PARSER_INCLUDE_2_TRANSACTION_0_: FILEAPPEND
HEDERA_MIRROR_IMPORTER_PARSER_INCLUDE_2_TRANSACTION_1_: FILECREATE
HEDERA_MIRROR_IMPORTER_PARSER_INCLUDE_2_TRANSACTION_2_: FILEDELETE
HEDERA_MIRROR_IMPORTER_PARSER_INCLUDE_2_TRANSACTION_3_: FILEUPDATE
HEDERA_MIRROR_IMPORTER_PARSER_INCLUDE_3_TRANSACTION_0_: CONTRACTCREATEINSTANCE
HEDERA_MIRROR_IMPORTER_PARSER_INCLUDE_3_EXPRESSION_: "transactionBody.contractCreateInstance.autoRenewAccountId.accountNum == 2000"
HEDERA_MIRROR_IMPORTER_PARSER_RECORD_ENTITY_PERSIST_TOPICS: "false"

Export transactions to PubSub

Importer can be configured to publish transactions (in json format) to a Pubsub topic using following properties:

  • spring.cloud.gcp.pubsub.enabled
  • spring.cloud.gcp.pubsub.project-id
  • hedera.mirror.importer.parser.record.pubsub.topicName
  • spring.cloud.gcp.pubsub.credentials.*
  • hedera.mirror.importer.parser.record.entity.enabled (Importer can not export to both database and pubsub simultaneously)

See Spring Cloud documentation for more info about spring.cloud.gcp.* properties.

Connect to S3 with the Default Credentials Provider

When connecting to an AWS S3 bucket that requires authentication (such as a requester pays bucket), you can opt to allow the AWS Default Credentials Provider Chain to handle the authentication for you, instead of providing your static access and secret keys in the config. This will also allow you to take advantage of alternative authorization modes such as AssumeRole. If the mirror node is configured to connect to an S3 bucket that requires authentication, and the static credentials are not provided in the config, the mirror node will default to using this provider. For more information and to see how you can set up your environment to take advantage of this, see the AWS Credentials Documentation When running in Docker or Kubernetes, credentials can be attached in a variety of ways, including by using volumes and secrets to directly add static credentials or an existing AWS credentials file, by using other tools such as Vault or AWS Secrets Manager, and many more.

Docker-compose.yml

volumes:
  - ~/.aws/:/root/.aws:ro

GRPC API

Similar to the Importer, the gRPC API uses Spring Boot properties to configure the application.

The following table lists the available properties along with their default values. Unless you need to set a non-default value, it is recommended to only populate overridden properties in the custom application.yml.

Name Default Description
hedera.mirror.grpc.addressbook.cacheExpiry 5s The amount of time to cache address book entries
hedera.mirror.grpc.addressbook.cacheSize 50 The maximum number of address book pages to cache
hedera.mirror.grpc.addressbook.maxPageDelay 250ms The maximum amount of time to sleep between paging for address book entries
hedera.mirror.grpc.addressbook.minPageDelay 100ms The minimum amount of time to sleep between paging for address book entries
hedera.mirror.grpc.addressbook.pageSize 10 The maximum number of address book entries to return in a single page
hedera.mirror.grpc.addressbook.nodeStakeCacheExpiry 24h The amount of time to cache node stake assignments
hedera.mirror.grpc.addressbook.nodeStakeCacheSize 5 The maximum number of versions of node stake assignments to cache
hedera.mirror.grpc.checkTopicExists true Whether to throw an error when the topic doesn't exist
hedera.mirror.grpc.db.host 127.0.0.1 The IP or hostname used to connect to the database
hedera.mirror.grpc.db.name mirror_node The name of the database
hedera.mirror.grpc.db.password mirror_grpc_pass The database password used to connect to the database.
hedera.mirror.grpc.db.port 5432 The port used to connect to the database
hedera.mirror.grpc.db.statementTimeout 10000 The number of milliseconds to wait before timing out a query statement
hedera.mirror.grpc.db.username mirror_grpc The username used to connect to the database
hedera.mirror.grpc.endTimeInterval 30s How often we should check if a subscription has gone past the end time
hedera.mirror.grpc.entityCacheSize 50000 The maximum size of the cache to store entities used for existence check
hedera.mirror.grpc.listener.enabled true Whether to listen for incoming massages or not
hedera.mirror.grpc.listener.interval 500ms How often to poll or retry errors (varies by type). Can accept duration units like 50ms, 10s, etc.
hedera.mirror.grpc.listener.maxBufferSize 16384 The maximum number of messages the notifying listener or the shared polling listener buffers before sending an error to a client
hedera.mirror.grpc.listener.maxPageSize 5000 The maximum number of messages the listener can return in a single call to the database
hedera.mirror.grpc.listener.prefetch 48 The prefetch queue size for shared listeners
hedera.mirror.grpc.listener.type REDIS The type of listener to use for incoming messages. Accepts either NOTIFY, POLL, REDIS or SHARED_POLL
hedera.mirror.grpc.netty.executorCoreThreadCount 10 The number of core threads
hedera.mirror.grpc.netty.executorMaxThreadCount 1000 The maximum allowed number of threads
hedera.mirror.grpc.netty.maxConnectionIdle 10m The max amount of time a connection can be idle before it will be gracefully terminated
hedera.mirror.grpc.netty.maxConcurrentCallsPerConnection 5 The maximum number of concurrent calls permitted for each incoming connection
hedera.mirror.grpc.netty.maxInboundMessageSize 1024 The maximum message size allowed to be received on the server
hedera.mirror.grpc.netty.maxInboundMetadataSize 1024 The maximum size of metadata allowed to be received
hedera.mirror.grpc.netty.threadKeepAliveTime 1m The amount of time for which threads may remain idle before being terminated
hedera.mirror.grpc.port 5600 The GRPC API port
hedera.mirror.grpc.retriever.enabled true Whether to retrieve historical massages or not
hedera.mirror.grpc.retriever.maxPageSize 1000 The maximum number of messages the retriever can return in a single call to the database
hedera.mirror.grpc.retriever.pollingFrequency 2s How often to poll for historical messages. Can accept duration units like 50ms, 10s etc
hedera.mirror.grpc.retriever.threadMultiplier 4 Multiplied by the CPU count to calculate the number of retriever threads
hedera.mirror.grpc.retriever.timeout 60s How long to wait between emission of messages before returning an error
hedera.mirror.grpc.retriever.unthrottled.maxPageSize 5000 The maximum number of messages the retriever can return in a single call to the database when unthrottled
hedera.mirror.grpc.retriever.unthrottled.maxPolls 12 The max number of polls when unthrottled
hedera.mirror.grpc.retriever.unthrottled.pollingFrequency 20ms How often to poll for messages when unthrottled. Can accept duration units like 50ms, 10s etc

Monitor

Similar to the Importer, the monitor uses Spring Boot properties to configure the application.

The following table lists the available properties along with their default values. Unless you need to set a non-default value, it is recommended to only populate overridden properties in the custom application.yml.

See the monitor documentation for more general information about configuring and using the monitor.

Name Default Description
hedera.mirror.monitor.health.release.cacheExpiry 30s The amount of time to cache cluster release health status
hedera.mirror.monitor.health.release.enabled false Whether to enable cluster release health check
hedera.mirror.monitor.mirrorNode.grpc.host "" The hostname of the mirror node's gRPC API
hedera.mirror.monitor.mirrorNode.grpc.port 5600 The port of the mirror node's gRPC API
hedera.mirror.monitor.mirrorNode.rest.host "" The hostname of the mirror node's REST API
hedera.mirror.monitor.mirrorNode.rest.port 443 The port of the mirror node's REST API
hedera.mirror.monitor.network TESTNET Which network to connect to. Automatically populates the main node & mirror node endpoints. Can be MAINNET, PREVIEWNET, TESTNET or OTHER
hedera.mirror.monitor.nodes[].accountId "" The consensus node's account ID
hedera.mirror.monitor.nodes[].certHash "" The consensus node's certificate hash used for TLS certificate verification
hedera.mirror.monitor.nodes[].host "" The consensus node's hostname
hedera.mirror.monitor.nodes[].nodeId "" The consensus node's node ID
hedera.mirror.monitor.nodes[].port 50211 The consensus node's port
hedera.mirror.monitor.nodeValidation.enabled true Whether to validate and remove invalid or down nodes permanently before publishing
hedera.mirror.monitor.nodeValidation.frequency 1d The amount of time between validations of the network. If not specified, millisecond is implied as the unit.
hedera.mirror.monitor.nodeValidation.maxAttempts 8 The number of times the monitor should attempt to receive a healthy response from a node before marking it as unhealthy.
hedera.mirror.monitor.nodeValidation.maxBackoff 2s The maximum amount of time to wait in between attempts when trying to validate a node
hedera.mirror.monitor.nodeValidation.maxThreads 25 The maximum number of threads to use for node validation
hedera.mirror.monitor.nodeValidation.minBackoff 500ms The minimum amount of time to wait in between attempts when trying to validate a node
hedera.mirror.monitor.nodeValidation.requestTimeout 15s The amount of time to wait for a validation request before timing out
hedera.mirror.monitor.nodeValidation.retryBackoff 2m The fixed amount of time to wait in between unsuccessful node validations that result in no valid nodes
hedera.mirror.monitor.nodeValidation.tls BOTH Whether to communicate to consensus nodes over TLS, PLAINTEXT, or BOTH. TLS currently defaults to not verifying certificate hash.
hedera.mirror.monitor.operator.accountId "" Operator account ID used to pay for transactions
hedera.mirror.monitor.operator.privateKey "" Operator ED25519 private key used to sign transactions in hex encoded DER format
hedera.mirror.monitor.publish.async true Whether to use the SDK's asynchronous execution or synchronous. Synchronous requires more monitor responseThreads.
hedera.mirror.monitor.publish.batchDivisor 100 The divisor used to calculate batch size when generating transactions
hedera.mirror.monitor.publish.clients 4 How many total SDK clients to publish transactions. Clients will be used in a round-robin fashion
hedera.mirror.monitor.publish.enabled true Whether to enable transaction publishing
hedera.mirror.monitor.publish.nodeMaxBackoff 1m The maximum backoff time for any node in the network
hedera.mirror.monitor.publish.responseThreads 40 How many threads to use to resolve the asynchronous responses
hedera.mirror.monitor.publish.scenarios A map of scenario name to publish scenarios. The name is used as a unique identifier in logs, metrics, and the REST API
hedera.mirror.monitor.publish.scenarios.<name>.duration How long this scenario should publish transactions. Leave empty for infinite
hedera.mirror.monitor.publish.scenarios.<name>.enabled true Whether this publish scenario is enabled
hedera.mirror.monitor.publish.scenarios.<name>.limit 0 How many transactions to publish before halting. 0 for unlimited
hedera.mirror.monitor.publish.scenarios.<name>.logResponse false Whether to log the response from HAPI
hedera.mirror.monitor.publish.scenarios.<name>.properties {} Key/value pairs used to configure the TransactionSupplier associated with this scenario type
hedera.mirror.monitor.publish.scenarios.<name>.receiptPercent 0.0 The percentage of receipts to retrieve from HAPI. Accepts values between 0-1
hedera.mirror.monitor.publish.scenarios.<name>.recordPercent 0.0 The percentage of records to retrieve from HAPI. Accepts values between 0-1
hedera.mirror.monitor.publish.scenarios.<name>.retry.maxAttempts 1 The maximum number of times a scenario transaction will be attempted
hedera.mirror.monitor.publish.scenarios.<name>.timeout 12s How long to wait for the transaction result
hedera.mirror.monitor.publish.scenarios.<name>.tps 1.0 The rate at which transactions will publish
hedera.mirror.monitor.publish.scenarios.<name>.type The type of transaction to publish. See the TransactionType enum for a list of possible values
hedera.mirror.monitor.publish.statusFrequency 10s How often to log publishing statistics
hedera.mirror.monitor.publish.warmupPeriod 30s The amount of time the publisher should ramp up its rate before reaching its stable (maximum) rate
hedera.mirror.monitor.nodeValidation.retrieveAddressBook true Whether to download the address book from the mirror node and use those nodes to publish transactions
hedera.mirror.monitor.subscribe.clients 1 How many SDK clients should be created to subscribe to mirror node APIs. Clients will be used in a round-robin fashion
hedera.mirror.monitor.subscribe.enabled true Whether to enable subscribing to mirror node APIs to verify published transactions
hedera.mirror.monitor.subscribe.grpc A map of scenario name to gRPC subscriber scenarios. The name is used as a unique identifier in logs, metrics, and the REST API
hedera.mirror.monitor.subscribe.grpc.<name>.duration How long to stay subscribed to the API
hedera.mirror.monitor.subscribe.grpc.<name>.enabled true Whether this subscribe scenario is enabled
hedera.mirror.monitor.subscribe.grpc.<name>.limit 0 How many transactions to receive before halting. 0 for unlimited
hedera.mirror.monitor.subscribe.grpc.<name>.retry.maxAttempts 2^63 - 1 How many consecutive retry attempts before giving up connecting to the API
hedera.mirror.monitor.subscribe.grpc.<name>.retry.maxBackoff 8s The maximum amount of time to wait between retry attempts
hedera.mirror.monitor.subscribe.grpc.<name>.retry.minBackoff 500ms The initial amount of time to wait between retry attempts
hedera.mirror.monitor.subscribe.grpc.<name>.startTime The start time passed to the gRPC API. Defaults to current time if not set
hedera.mirror.monitor.subscribe.grpc.<name>.subscribers 1 How many concurrent subscribers should be instantiated for this scenario
hedera.mirror.monitor.subscribe.grpc.<name>.topicId Which topic to subscribe to
hedera.mirror.monitor.subscribe.rest A map of scenario name to REST subscriber scenarios. The name is used as a unique identifier in logs, metrics, and the REST API
hedera.mirror.monitor.subscribe.rest.<name>.duration How long to stay subscribed to the API
hedera.mirror.monitor.subscribe.rest.<name>.enabled true Whether this subscribe scenario is enabled
hedera.mirror.monitor.subscribe.rest.<name>.limit 0 How many transactions to receive before halting. 0 for unlimited
hedera.mirror.monitor.subscribe.rest.<name>.publishers [] A list of publisher scenario names to consider for sampling
hedera.mirror.monitor.subscribe.rest.<name>.retry.maxAttempts 16 How many consecutive retry attempts before giving up connecting to the API
hedera.mirror.monitor.subscribe.rest.<name>.retry.maxBackoff 1s The maximum amount of time to wait between retry attempts
hedera.mirror.monitor.subscribe.rest.<name>.retry.minBackoff 500ms The initial amount of time to wait between retry attempts
hedera.mirror.monitor.subscribe.rest.<name>.samplePercent 1.0 The percentage of transactions to verify against the API. Accepts values between 0-1
hedera.mirror.monitor.subscribe.rest.<name>.timeout 5s Maximum amount of time to wait for a API call to retrieve data
hedera.mirror.monitor.subscribe.statusFrequency 10s How often to log subscription statistics

REST API

The REST API supports loading configuration from YAML or environment variables. By default, it loads a file named application.yml or application.yaml in each of the search paths (see below). The file name can be changed by setting the CONFIG_NAME environment variable. A custom location can be loaded by setting the CONFIG_PATH environment variable. The configuration is loaded in the following order with the latter configuration overwriting (technically recursively merged into) the current configuration:

  1. ./config/application.yml
  2. ./application.yml
  3. ${CONFIG_PATH}/application.yml
  4. Environment variables that start with HEDERA_MIRROR_REST_ (e.g. HEDERA_MIRROR_REST_MAXLIMIT=100)

The following table lists the available properties along with their default values. Unless you need to set a non-default value, it is recommended to only populate overridden properties in the custom application.yml.

Name Default Description
hedera.mirror.rest.cache.entityId.maxAge 1800 The number of seconds until the entityId cache entry expires
hedera.mirror.rest.cache.entityId.maxSize 100000 The maximum number of entries in the entityId cache
hedera.mirror.rest.cache.token.maxSize 100000 The maximum number of entries in the token cache
hedera.mirror.rest.cache.response.enabled false Whether or not the Redis based REST API response cache is enabled. If so, Redis itself must be enabled and properly configured.
hedera.mirror.rest.cache.response.compress true Store cached response in gzip format and serve gzipped if supported by client
hedera.mirror.rest.db.host 127.0.0.1 The IP or hostname used to connect to the database
hedera.mirror.rest.db.name mirror_node The name of the database
hedera.mirror.rest.db.password mirror_api_pass The database password the processor uses to connect.
hedera.mirror.rest.db.pool.connectionTimeout 20000 The number of milliseconds to wait before timing out when connecting a new database client
hedera.mirror.rest.db.pool.maxConnections 10 The maximum number of clients the database pool can contain
hedera.mirror.rest.db.pool.statementTimeout 20000 The number of milliseconds to wait before timing out a query statement
hedera.mirror.rest.db.port 5432 The port used to connect to the database
hedera.mirror.rest.db.sslMode DISABLE The ssl level of protection against Eavesdropping, Man-in-the-middle (MITM) and Impersonation on the db connection. Accepts either DISABLE, ALLOW, PREFER, REQUIRE, VERIFY_CA or VERIFY_FULL.
hedera.mirror.rest.db.tls.ca "" The path to the certificate authority used by the database for secure connections
hedera.mirror.rest.db.tls.cert "" The path to the public key the client should use to securely connect to the database
hedera.mirror.rest.db.tls.enabled false Whether TLS should be used for the database connection
hedera.mirror.rest.db.tls.key "" The path to the private key the client should use to securely connect to the database
hedera.mirror.rest.db.username mirror_api The username the processor uses to connect to the database
hedera.mirror.rest.log.level info The logging level. Can be trace, debug, info, warn, error or fatal.
hedera.mirror.rest.metrics.config See application.yml The configuration to pass to Swagger stats (https://swaggerstats.io/guide/conf.html#options)
hedera.mirror.rest.metrics.config.authentication true Whether access to metrics for the REST API is authenticated
hedera.mirror.rest.metrics.config.username mirror_api_metrics The REST API metrics username to access the dashboard
hedera.mirror.rest.metrics.config.password mirror_api_metrics_pass The REST API metrics password to access the dashboard
hedera.mirror.rest.metrics.config.uriPath '/swagger' The REST API metrics uri path
hedera.mirror.rest.metrics.enabled true Whether metrics should be collected and exposed for scraping
hedera.mirror.rest.metrics.ipMetrics false Whether metrics should be associated with a masked client IP label
hedera.mirror.rest.network.unreleasedSupplyAccounts [0.0.2, 0.0.42, ...] An array of account IDs whose aggregated balance subtracted from the total supply is the released supply
hedera.mirror.rest.openapi.specFileName 'openapi' The file name of the OpenAPI spec file
hedera.mirror.rest.openapi.swaggerUIPath '/docs' Swagger UI path for your REST API
hedera.mirror.rest.openapi.validation.enabled false Whether or not the OpenAPI request validation is enabled.
hedera.mirror.rest.port 5551 The REST API port
hedera.mirror.rest.query.bindTimestampRange false Whether to bind the timestamp range to maxTimestampRange
hedera.mirror.rest.query.maxRecordFileCloseInterval 10s The maximum close interval of record files to limit the time partitions to scan. Note the default value is larger than the actual network close interval
hedera.mirror.rest.query.maxRepeatedQueryParameters 100 The maximum number of times any query parameter can be repeated in the uri
hedera.mirror.rest.query.maxScheduledTransactionConsensusTimestampRange 89285m The maximum amount of time of a scheduled transaction's consensus timestamp from its valid start timestamp.
hedera.mirror.rest.query.maxTimestampRange 7d The maximum amount of time a timestamp range query param can span for some APIs.
hedera.mirror.rest.query.maxTransactionConsensusTimestampRange 35m The maximum amount of time of a transaction's consensus timestamp from its valid start timestamp.
hedera.mirror.rest.query.maxTransactionsTimestampRange 60d The maximum timestamp range to list transactions.
hedera.mirror.rest.query.strictTimestampParam true Enables strict checking of timestamp query param (currently only effects /api/v1/accounts/{id}?timestamp={timestamp}
hedera.mirror.rest.query.topicMessageLookup false Enables topic message lookup querying
'hedera.mirror.rest.query.transactions.precedingTransactionTypes' [11, 15] Array of transaction types to be included in transactions by account id response when there is no parent and nonce is non-zero.
hedera.mirror.rest.redis.commandTimeout 10000 The amount of time in milliseconds to wait before a Redis command will timeout
hedera.mirror.rest.redis.connectTimeout 10000 The amount of time in milliseconds to wait for a connection to Redis
hedera.mirror.rest.redis.enabled true Whether Redis should be used as a caching layer for the database
hedera.mirror.rest.redis.maxBackoff 128000 The maximum amount of time in milliseconds to wait in between retrying Redis connection errors
hedera.mirror.rest.redis.maxMemory 250Mb The maximum amount of memory that Redis should be configured to use for caching
hedera.mirror.rest.redis.maxMemoryPolicy allkeys-lfu The key eviction policy Redis should use when the max memory threshold has been reached
hedera.mirror.rest.redis.maxRetriesPerRequest 1 The maximum number of times that the Redis command should be retried
hedera.mirror.rest.redis.sentinel.enabled false Whether Redis sentinel should be enabled
hedera.mirror.rest.redis.sentinel.host 127.0.0.1 The Redis sentinel host
hedera.mirror.rest.redis.sentinel.name "mirror" The Redis sentinel master group name
hedera.mirror.rest.redis.sentinel.password "" The Redis sentinel password
hedera.mirror.rest.redis.sentinel.port 26379 The Redis sentinel port
hedera.mirror.rest.redis.uri redis://127.0.0.1:6379 The URI to use when connecting to Redis
hedera.mirror.rest.response.compression true Whether content negotiation should occur to compress response bodies if requested
hedera.mirror.rest.response.headers.default See application.yml The default headers to add to every response.
hedera.mirror.rest.response.headers.path See application.yml The per path headers to add to every response. The key is the route name and the value is a header map.
hedera.mirror.rest.response.includeHostInLink false Whether to include the hostname and port in the next link in the response
hedera.mirror.rest.response.limit.default 25 The default value for the limit parameter that controls the REST API response size
hedera.mirror.rest.response.limit.max 100 The maximum size the limit parameter can be that controls the REST API response size
hedera.mirror.rest.response.limit.tokenBalance.multipleAccounts 50 The maximum number of token balances per account for endpoints which return such info for multiple accounts
hedera.mirror.rest.response.limit.tokenBalance.singleAccount 1000 The maximum number of token balances per account for endpoints which return such info for a single account
hedera.mirror.rest.shard 0 The default shard number that this mirror node participates in
hedera.mirror.rest.stateproof.enabled false Whether to enable stateproof REST API or not
hedera.mirror.rest.stateproof.streams.accessKey "" The cloud storage access key
hedera.mirror.rest.stateproof.streams.bucketName The cloud storage bucket name to download streamed files. This value takes priority over network hardcoded bucket names regardless of hedera.mirror.rest.stateproof.streams.network
hedera.mirror.rest.stateproof.streams.cloudProvider S3 The cloud provider to download files from. Either S3 or GCP
hedera.mirror.rest.stateproof.streams.endpointOverride Can be specified to download streams from a source other than S3 and GCP. Should be S3 compatible
hedera.mirror.rest.stateproof.streams.gcpProjectId GCP project id to bill for requests to GCS bucket which has Requester Pays enabled.
hedera.mirror.rest.stateproof.streams.httpOptions.connectTimeout 2000 The number of milliseconds to wait to establish a connection
hedera.mirror.rest.stateproof.streams.httpOptions.timeout 5000 The number of milliseconds a request can take before automatically being terminated
hedera.mirror.rest.stateproof.streams.maxRetries 3 The maximum amount of retries to perform for a cloud storage download request.
hedera.mirror.rest.stateproof.streams.network DEMO Which Hedera network to use. Can be either DEMO, MAINNET, TESTNET, PREVIEWNET or OTHER
hedera.mirror.rest.stateproof.streams.region us-east-1 The region associated with the bucket
hedera.mirror.rest.stateproof.streams.secretKey "" The cloud storage secret key

Enable State Proof Alpha

To enable State Proof logic the REST API configurations must updated to allow for communication with cloud buckets to pull down the necessary files (address book, signatures files and record file). The process involves setting the properties under hedera.mirror.rest.stateproof as documented above REST API Config.

An example configuration is provided below

hedera:
  mirror:
    rest:
      stateproof:
        enabled: true
        streams:
          accessKey: <accessKey>
          bucketName: "hedera-mainnet-streams"
          cloudProvider: "GCP"
          network: "MAINNET"
          region: "us-east-1"
          secretKey: <secretKey>

REST Java API

Similar to the Importer, the REST Java API uses Spring Boot properties to configure the application.

The following table lists the available properties along with their default values. Unless you need to set a non-default value, it is recommended to only populate overridden properties in the custom application.yml.

Name Default Description
hedera.mirror.restJava.db.host 127.0.0.1 The IP or hostname used to connect to the database
hedera.mirror.restJava.db.name mirror_node The name of the database
hedera.mirror.restJava.db.password mirror_rest_java_pass The database password used to connect to the database
hedera.mirror.restJava.db.port 5432 The port used to connect to the database
hedera.mirror.restJava.db.sslMode DISABLE The SSL level. Accepts either DISABLE, ALLOW, PREFER, REQUIRE, VERIFY_CA or VERIFY_FULL.
hedera.mirror.restJava.db.statementTimeout 10000 The number of milliseconds to wait before timing out a query statement
hedera.mirror.restJava.db.username mirror_rest_java The username used to connect to the database
hedera.mirror.restJava.response.headers.defaults See application.yml The default headers to add to every response. For each header, specify its name: value
hedera.mirror.restJava.response.headers.path See application.yml Override default or add headers per path to add to every response. The key is the controller request mapping, then for each header, specify its name: value
hedera.mirror.restJava.shard 0 The default shard number that this mirror node participates in

Rosetta API

The Rosetta API supports loading configuration from YAML. By default, it loads a file named application.yml in each of the search paths (see below). The configuration is loaded in the following order with the latter configuration overwriting (technically recursively merged into) the current configuration:

  1. Hard coded configuration embedded in the code
  2. ./application.yml
  3. ${HEDERA_MIRROR_ROSETTA_API_CONFIG} environment variable to custom values file ( e.g. HEDERA_MIRROR_ROSETTA_API_CONFIG=/Users/Downloads/hedera-mirror-rosetta/application.yml)
  4. Environment variables that start with HEDERA_MIRROR_ROSETTA_ (e.g. HEDERA_MIRROR_ROSETTA_API_VERSION=1.4.2)

The following table lists the available properties along with their default values.

Name Default Description
hedera.mirror.rosetta.cache.entity.maxSize 524288 The max number of entities to cache
hedera.mirror.rosetta.db.host 127.0.0.1 The IP or hostname used to connect to the database
hedera.mirror.rosetta.db.name mirror_node The name of the database
hedera.mirror.rosetta.db.password mirror_rosetta_pass The database password the processor uses to connect
hedera.mirror.rosetta.db.pool.maxIdleConnections 20 The maximum number of idle database connections
hedera.mirror.rosetta.db.pool.maxLifetime 30 The maximum lifetime of a database connection in minutes
hedera.mirror.rosetta.db.pool.maxOpenConnections 100 The maximum number of open database connections
hedera.mirror.rosetta.db.port 5432 The port used to connect to the database
hedera.mirror.rosetta.db.statementTimeout 20 The number of seconds to wait before timing out a query statement
hedera.mirror.rosetta.db.username mirror_rosetta The username the processor uses to connect to the database
hedera.mirror.rosetta.http.idleTimeout 10000000000 The maximum amount of time in nanoseconds to wait for the next request when keep-alives are enabled
hedera.mirror.rosetta.http.readHeaderTimeout 3000000000 The maximum amount of time in nanoseconds to read request headers
hedera.mirror.rosetta.http.readTimeout 5000000000 The maximum duration in nanoseconds for reading the entire request, including the body
hedera.mirror.rosetta.http.writeTimeout 10000000000 The maximum duration in nanoseconds before timing out writes of the response
hedera.mirror.rosetta.log.level info The log level
hedera.mirror.rosetta.network DEMO Which Hedera network to use. Can be either DEMO, MAINNET, PREVIEWNET, TESTNET or OTHER
hedera.mirror.rosetta.nodeRefreshInterval 24h The fixed period between scheduled network address book updates. Can accept values like 10m, 2h
hedera.mirror.rosetta.nodeVersion 0 The default canonical version of the node runtime
hedera.mirror.rosetta.nodes {} A map of main nodes with its service endpoint as the key and the node account id as its value
hedera.mirror.rosetta.online true The default online mode of the Rosetta interface
hedera.mirror.rosetta.port 5700 The REST API port
hedera.mirror.rosetta.realm 0 The default realm number within the shard
hedera.mirror.rosetta.shard 0 The default shard number that this mirror node participates in
hedera.mirror.rosetta.shutdownTimeout 10s The time to wait for the server to shutdown gracefully

Web3 API

Similar to the Importer, the web3 API uses Spring Boot properties to configure the application.

The following table lists the available properties along with their default values. Unless you need to set a non-default value, it is recommended to only populate overridden properties in the custom application.yml.

Name Default Description
hedera.mirror.web3.cache.contract expireAfterAccess=60m,maximumSize=1000,recordStats Cache configuration for contract
hedera.mirror.web3.cache.contractState expireAfterWrite=1s,maximumSize=10000,recordStats Cache configuration for contract state
hedera.mirror.web3.cache.entity expireAfterWrite=1s,maximumSize=10000,recordStats Cache configuration for entity
hedera.mirror.web3.cache.fee expireAfterWrite=10m,maximumSize=20,recordStats Cache configuration for fee related info
hedera.mirror.web3.cache.token expireAfterWrite=1s,maximumSize=10000,recordStats Cache configuration for token related info
hedera.mirror.web3.db.host 127.0.0.1 The IP or hostname used to connect to the database
hedera.mirror.web3.db.name mirror_node The name of the database
hedera.mirror.web3.db.password mirror_web3_pass The database password used to connect to the database
hedera.mirror.web3.db.port 5432 The port used to connect to the database
hedera.mirror.web3.db.sslMode DISABLE The ssl level of protection against eavesdropping, man-in-the-middle (MITM) and impersonation on the db connection. Accepts either DISABLE, ALLOW, PREFER, REQUIRE, VERIFY_CA or VERIFY_FULL.
hedera.mirror.web3.db.statementTimeout 10000 The number of milliseconds to wait before timing out a query statement
hedera.mirror.web3.db.username mirror_web3 The username used to connect to the database
hedera.mirror.web3.evm.allowTreasuryToOwnNfts true Whether the treasury is allowed to own NFTs
hedera.mirror.web3.evm.autoRenewTargetTypes [] The entities that are auto-renewed
hedera.mirror.web3.evm.estimateGasIterationThresholdPercent 0.10 Percent used during gas estimation algorithm
hedera.mirror.web3.evm.directTokenCall true Flag enabling contract like calls to tokens
hedera.mirror.web3.evm.dynamicEvmVersion false Flag indicating whether a dynamic evm version to be used
hedera.mirror.web3.evm.evmVersion v0.34 The besu EVM version to be used as dynamic one
hedera.mirror.web3.evm.evmSpecVersion SHANGHAI The besu EVM spec version to be used as dynamic one
hedera.mirror.web3.evm.exchangeRateGasReq 100 Gas requirement for ExchangeRatePrecompile.
hedera.mirror.web3.evm.expirationCacheTime 10m Maximum time for contract bytecode's caching
hedera.mirror.web3.evm.fundingAccount 0x0000000000000000000000000000000000000062 Default Hedera funding account
hedera.mirror.web3.evm.htsDefaultGasCost 10000 Default gas cost for Hedera Token Service Precompiles
hedera.mirror.web3.evm.limitTokenAssociations false Whether the TokenAssociations are limited
hedera.mirror.web3.evm.maxAutoRenewDuration 8000001 Maximum duration for auto-renew account
hedera.mirror.web3.evm.maxBatchSizeBurn 10 Maximum number of burn operations in a single transaction
hedera.mirror.web3.evm.maxBatchSizeMint 10 Maximum number of mint operations in a single transaction
hedera.mirror.web3.evm.maxBatchSizeWipe 10 Maximum number of wipe operations in a single transaction
hedera.mirror.web3.evm.maxCustomFeesAllowed 10 Maximum number of custom fees in a single transaction
hedera.mirror.web3.evm.maxDataSize 128 KiB Maximum contract data size in bytes, for both contract create and call. Spring Boot DataSize defines suffixes in powers of 2: KB (1024) and MB (1,048,576), aka KiB and MiB.
hedera.mirror.web3.evm.maxGasEstimateRetriesCount 20 Estimate gas contract call retry threshold
hedera.mirror.web3.evm.maxGasRefundPercentage 100% Maximal percent of gas refunding
hedera.mirror.web3.evm.maxGas 15000000 Maximum gas allowed in contract call request
hedera.mirror.web3.evm.maxMemoUtf8Bytes 100 Maximum size in bytes for token memo
hedera.mirror.web3.evm.maxNftMetadataBytes 100 Maximum size in bytes for NFT metadata
hedera.mirror.web3.evm.maxTokenNameUtf8Bytes 100 Maximum size in bytes for token name
hedera.mirror.web3.evm.maxTokensPerAccount 1000 Maximum number token associations per account
hedera.mirror.web3.evm.maxTokenSymbolUtf8Bytes 100 Maximum size in bytes for token symbol
hedera.mirror.web3.evm.minAutoRenewDuration 2592000 Minimum duration for auto-renew account
hedera.mirror.web3.evm.modularizedServices false Flag that indicates if the hedera.app dependency is used. This is under development. It is recommended to be set to false.
hedera.mirror.web3.evm.network TESTNET Which Hedera network to use. Can be either MAINNET, PREVIEWNET, TESTNET or OTHER
hedera.mirror.web3.evm.feesTokenTransferUsageMultiplier 380 Used to calculate token transfer fees
hedera.mirror.web3.evm.trace.enabled false Flag enabling tracer
hedera.mirror.web3.evm.trace.contract [] A set with contract addresses to filter. By default it is empty to indicate it will trace all contract addresses.
hedera.mirror.web3.evm.trace.status [] A set with frame statuses to filter. By default it is empty to indicate it will trace all frames regardless of status.
hedera.mirror.web3.maxPayloadLogSize 300 The maximum number of bytes to use to log the request payload.
hedera.mirror.web3.opcode.tracer.enabled false Whether the /contracts/results/{transactionIdOrHash}/opcodes endpoint is exposed
hedera.mirror.web3.throttle.gasLimitRefundPercent 100 Maximum gas percent from the passed gas limit in a request to return in the throttle bucket after the request is processed
hedera.mirror.web3.throttle.gasPerSecond 1000000000 Maximum gas limit that can be processed per second. The max value for this property is 1000000000. In case greater gas limit needs to be allowed per second, please refer to the property below.
hedera.mirror.web3.throttle.gasUnit 1 A multiplier that allows the max gas limit per second to be increased proportionally. For example, if the gasPerSecond is set to 1000000000 and the gasUnit is set to 5, the effective gas limit that can be processed per second would be 5000000000.
hedera.mirror.web3.throttle.requestsPerSecond 500 Maximum RPS limit