The components of the Hedera Mirror Node all support loading configuration from an application.yml
file or via the
environment.
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.
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. |
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 (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
andtransactionRecord
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)
orT(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.
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.
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
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
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"
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.
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
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 |
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 |
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:
./config/application.yml
./application.yml
${CONFIG_PATH}/application.yml
- 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 |
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>
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 |
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:
- Hard coded configuration embedded in the code
./application.yml
${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
)- 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 |
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 |