You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1157 lines
62 KiB
1157 lines
62 KiB
import Config
|
|
|
|
[__DIR__ | ~w(config_helper.exs)]
|
|
|> Path.join()
|
|
|> Code.eval_file()
|
|
|
|
######################
|
|
### BlockScout Web ###
|
|
######################
|
|
|
|
disable_api? = ConfigHelper.parse_bool_env_var("DISABLE_API")
|
|
|
|
config :block_scout_web,
|
|
version: System.get_env("BLOCKSCOUT_VERSION"),
|
|
release_link: System.get_env("RELEASE_LINK"),
|
|
decompiled_smart_contract_token: System.get_env("DECOMPILED_SMART_CONTRACT_TOKEN"),
|
|
show_percentage: ConfigHelper.parse_bool_env_var("SHOW_ADDRESS_MARKETCAP_PERCENTAGE", "true"),
|
|
checksum_address_hashes: ConfigHelper.parse_bool_env_var("CHECKSUM_ADDRESS_HASHES", "true"),
|
|
other_networks: System.get_env("SUPPORTED_CHAINS"),
|
|
webapp_url: System.get_env("WEBAPP_URL"),
|
|
api_url: System.get_env("API_URL"),
|
|
apps_menu: ConfigHelper.parse_bool_env_var("APPS_MENU"),
|
|
apps: System.get_env("APPS") || System.get_env("EXTERNAL_APPS"),
|
|
gas_price: System.get_env("GAS_PRICE"),
|
|
dark_forest_addresses: System.get_env("CUSTOM_CONTRACT_ADDRESSES_DARK_FOREST"),
|
|
dark_forest_addresses_v_0_5: System.get_env("CUSTOM_CONTRACT_ADDRESSES_DARK_FOREST_V_0_5"),
|
|
circles_addresses: System.get_env("CUSTOM_CONTRACT_ADDRESSES_CIRCLES"),
|
|
new_tags: System.get_env("NEW_TAGS"),
|
|
chain_id: System.get_env("CHAIN_ID"),
|
|
json_rpc: System.get_env("JSON_RPC"),
|
|
disable_add_to_mm_button: ConfigHelper.parse_bool_env_var("DISABLE_ADD_TO_MM_BUTTON"),
|
|
permanent_dark_mode_enabled: ConfigHelper.parse_bool_env_var("PERMANENT_DARK_MODE_ENABLED"),
|
|
permanent_light_mode_enabled: ConfigHelper.parse_bool_env_var("PERMANENT_LIGHT_MODE_ENABLED"),
|
|
display_token_icons: ConfigHelper.parse_bool_env_var("DISPLAY_TOKEN_ICONS"),
|
|
hide_block_miner: ConfigHelper.parse_bool_env_var("HIDE_BLOCK_MINER"),
|
|
hide_scam_addresses: ConfigHelper.parse_bool_env_var("HIDE_SCAM_ADDRESSES"),
|
|
show_tenderly_link: ConfigHelper.parse_bool_env_var("SHOW_TENDERLY_LINK"),
|
|
sensitive_endpoints_api_key: System.get_env("API_SENSITIVE_ENDPOINTS_KEY"),
|
|
disable_api?: disable_api?
|
|
|
|
config :block_scout_web, :recaptcha,
|
|
v2_client_key: System.get_env("RE_CAPTCHA_CLIENT_KEY"),
|
|
v2_secret_key: System.get_env("RE_CAPTCHA_SECRET_KEY"),
|
|
v3_client_key: System.get_env("RE_CAPTCHA_V3_CLIENT_KEY"),
|
|
v3_secret_key: System.get_env("RE_CAPTCHA_V3_SECRET_KEY"),
|
|
is_disabled: ConfigHelper.parse_bool_env_var("RE_CAPTCHA_DISABLED"),
|
|
check_hostname?: ConfigHelper.parse_bool_env_var("RE_CAPTCHA_CHECK_HOSTNAME", "true"),
|
|
score_threshold: ConfigHelper.parse_float_env_var("RE_CAPTCHA_SCORE_THRESHOLD", "0.5")
|
|
|
|
network_path =
|
|
"NETWORK_PATH"
|
|
|> System.get_env("/")
|
|
|> (&(if String.ends_with?(&1, "/") do
|
|
String.trim_trailing(&1, "/")
|
|
else
|
|
&1
|
|
end)).()
|
|
|
|
# Configures the endpoint
|
|
config :block_scout_web, BlockScoutWeb.Endpoint,
|
|
server: true,
|
|
url: [
|
|
path: network_path,
|
|
scheme: System.get_env("BLOCKSCOUT_PROTOCOL") || "http",
|
|
host: System.get_env("BLOCKSCOUT_HOST") || "localhost"
|
|
],
|
|
render_errors: [view: BlockScoutWeb.ErrorView, accepts: ~w(html json)],
|
|
pubsub_server: BlockScoutWeb.PubSub
|
|
|
|
config :block_scout_web, BlockScoutWeb.Chain,
|
|
network: System.get_env("NETWORK"),
|
|
subnetwork: System.get_env("SUBNETWORK"),
|
|
network_icon: System.get_env("NETWORK_ICON"),
|
|
logo: System.get_env("LOGO"),
|
|
logo_text: System.get_env("LOGO_TEXT"),
|
|
has_emission_funds: false,
|
|
show_maintenance_alert: ConfigHelper.parse_bool_env_var("SHOW_MAINTENANCE_ALERT"),
|
|
enable_testnet_label: ConfigHelper.parse_bool_env_var("SHOW_TESTNET_LABEL"),
|
|
testnet_label_text: System.get_env("TESTNET_LABEL_TEXT", "Testnet")
|
|
|
|
config :block_scout_web, :footer,
|
|
logo: System.get_env("FOOTER_LOGO"),
|
|
chat_link: System.get_env("FOOTER_CHAT_LINK", "https://discord.gg/blockscout"),
|
|
github_link: System.get_env("FOOTER_GITHUB_LINK", "https://github.com/blockscout/blockscout"),
|
|
forum_link_enabled: ConfigHelper.parse_bool_env_var("FOOTER_FORUM_LINK_ENABLED"),
|
|
forum_link: System.get_env("FOOTER_FORUM_LINK", "https://forum.poa.network/c/blockscout"),
|
|
telegram_link_enabled: ConfigHelper.parse_bool_env_var("FOOTER_TELEGRAM_LINK_ENABLED"),
|
|
telegram_link: System.get_env("FOOTER_TELEGRAM_LINK"),
|
|
link_to_other_explorers: ConfigHelper.parse_bool_env_var("FOOTER_LINK_TO_OTHER_EXPLORERS"),
|
|
other_explorers: System.get_env("FOOTER_OTHER_EXPLORERS", "")
|
|
|
|
config :block_scout_web, :contract,
|
|
verification_max_libraries: ConfigHelper.parse_integer_env_var("CONTRACT_VERIFICATION_MAX_LIBRARIES", 10),
|
|
max_length_to_show_string_without_trimming: System.get_env("CONTRACT_MAX_STRING_LENGTH_WITHOUT_TRIMMING", "2040"),
|
|
disable_interaction: ConfigHelper.parse_bool_env_var("CONTRACT_DISABLE_INTERACTION"),
|
|
certified_list: ConfigHelper.parse_list_env_var("CONTRACT_CERTIFIED_LIST", "")
|
|
|
|
default_global_api_rate_limit = 50
|
|
default_api_rate_limit_by_key = 10
|
|
|
|
config :block_scout_web, :api_rate_limit,
|
|
disabled: ConfigHelper.parse_bool_env_var("API_RATE_LIMIT_DISABLED"),
|
|
global_limit: ConfigHelper.parse_integer_env_var("API_RATE_LIMIT", default_global_api_rate_limit),
|
|
limit_by_key: ConfigHelper.parse_integer_env_var("API_RATE_LIMIT_BY_KEY", default_api_rate_limit_by_key),
|
|
limit_by_whitelisted_ip:
|
|
ConfigHelper.parse_integer_env_var("API_RATE_LIMIT_BY_WHITELISTED_IP", default_global_api_rate_limit),
|
|
time_interval_limit: ConfigHelper.parse_time_env_var("API_RATE_LIMIT_TIME_INTERVAL", "1s"),
|
|
limit_by_ip: ConfigHelper.parse_integer_env_var("API_RATE_LIMIT_BY_IP", 3000),
|
|
time_interval_limit_by_ip: ConfigHelper.parse_time_env_var("API_RATE_LIMIT_BY_IP_TIME_INTERVAL", "5m"),
|
|
static_api_key: System.get_env("API_RATE_LIMIT_STATIC_API_KEY"),
|
|
no_rate_limit_api_key: System.get_env("API_NO_RATE_LIMIT_API_KEY"),
|
|
whitelisted_ips: System.get_env("API_RATE_LIMIT_WHITELISTED_IPS"),
|
|
is_blockscout_behind_proxy: ConfigHelper.parse_bool_env_var("API_RATE_LIMIT_IS_BLOCKSCOUT_BEHIND_PROXY"),
|
|
api_v2_ui_limit: ConfigHelper.parse_integer_env_var("API_RATE_LIMIT_UI_V2_WITH_TOKEN", 5),
|
|
api_v2_token_ttl_seconds: ConfigHelper.parse_integer_env_var("API_RATE_LIMIT_UI_V2_TOKEN_TTL_IN_SECONDS", 18000),
|
|
eth_json_rpc_max_batch_size: ConfigHelper.parse_integer_env_var("ETH_JSON_RPC_MAX_BATCH_SIZE", 5)
|
|
|
|
default_graphql_rate_limit = 10
|
|
|
|
config :block_scout_web, Api.GraphQL,
|
|
default_transaction_hash:
|
|
System.get_env(
|
|
"API_GRAPHQL_DEFAULT_TRANSACTION_HASH",
|
|
"0x69e3923eef50eada197c3336d546936d0c994211492c9f947a24c02827568f9f"
|
|
),
|
|
enabled: ConfigHelper.parse_bool_env_var("API_GRAPHQL_ENABLED", "true"),
|
|
rate_limit_disabled?: ConfigHelper.parse_bool_env_var("API_GRAPHQL_RATE_LIMIT_DISABLED"),
|
|
global_limit: ConfigHelper.parse_integer_env_var("API_GRAPHQL_RATE_LIMIT", default_graphql_rate_limit),
|
|
limit_by_key: ConfigHelper.parse_integer_env_var("API_GRAPHQL_RATE_LIMIT_BY_KEY", default_graphql_rate_limit),
|
|
time_interval_limit: ConfigHelper.parse_time_env_var("API_GRAPHQL_RATE_LIMIT_TIME_INTERVAL", "1s"),
|
|
limit_by_ip: ConfigHelper.parse_integer_env_var("API_GRAPHQL_RATE_LIMIT_BY_IP", 500),
|
|
time_interval_limit_by_ip: ConfigHelper.parse_time_env_var("API_GRAPHQL_RATE_LIMIT_BY_IP_TIME_INTERVAL", "5m"),
|
|
static_api_key: System.get_env("API_GRAPHQL_RATE_LIMIT_STATIC_API_KEY")
|
|
|
|
# Configures History
|
|
price_chart_config =
|
|
if ConfigHelper.parse_bool_env_var("SHOW_PRICE_CHART") do
|
|
%{market: [:price, :market_cap]}
|
|
else
|
|
%{}
|
|
end
|
|
|
|
price_chart_legend_enabled? =
|
|
ConfigHelper.parse_bool_env_var("SHOW_PRICE_CHART") || ConfigHelper.parse_bool_env_var("SHOW_PRICE_CHART_LEGEND")
|
|
|
|
transaction_chart_config =
|
|
if ConfigHelper.parse_bool_env_var("SHOW_TXS_CHART", "true") do
|
|
%{transactions: [:transactions_per_day]}
|
|
else
|
|
%{}
|
|
end
|
|
|
|
config :block_scout_web, :chart,
|
|
chart_config: Map.merge(price_chart_config, transaction_chart_config),
|
|
price_chart_legend_enabled?: price_chart_legend_enabled?
|
|
|
|
config :block_scout_web, BlockScoutWeb.Chain.Address.CoinBalance,
|
|
coin_balance_history_days: ConfigHelper.parse_integer_env_var("COIN_BALANCE_HISTORY_DAYS", 10)
|
|
|
|
config :block_scout_web, BlockScoutWeb.API.V2, enabled: ConfigHelper.parse_bool_env_var("API_V2_ENABLED", "true")
|
|
|
|
config :block_scout_web, BlockScoutWeb.MicroserviceInterfaces.TransactionInterpretation,
|
|
service_url: System.get_env("MICROSERVICE_TRANSACTION_INTERPRETATION_URL"),
|
|
enabled: ConfigHelper.parse_bool_env_var("MICROSERVICE_TRANSACTION_INTERPRETATION_ENABLED")
|
|
|
|
# Configures Ueberauth's Auth0 auth provider
|
|
config :ueberauth, Ueberauth.Strategy.Auth0.OAuth,
|
|
domain: System.get_env("ACCOUNT_AUTH0_DOMAIN"),
|
|
client_id: System.get_env("ACCOUNT_AUTH0_CLIENT_ID"),
|
|
client_secret: System.get_env("ACCOUNT_AUTH0_CLIENT_SECRET")
|
|
|
|
# Configures Ueberauth local settings
|
|
config :ueberauth, Ueberauth, logout_url: "https://#{System.get_env("ACCOUNT_AUTH0_DOMAIN")}/v2/logout"
|
|
|
|
########################
|
|
### Ethereum JSONRPC ###
|
|
########################
|
|
|
|
trace_url_missing? = System.get_env("ETHEREUM_JSONRPC_TRACE_URL") in ["", nil]
|
|
|
|
config :ethereum_jsonrpc,
|
|
rpc_transport: if(System.get_env("ETHEREUM_JSONRPC_TRANSPORT", "http") == "http", do: :http, else: :ipc),
|
|
ipc_path: System.get_env("IPC_PATH"),
|
|
disable_archive_balances?:
|
|
trace_url_missing? or ConfigHelper.parse_bool_env_var("ETHEREUM_JSONRPC_DISABLE_ARCHIVE_BALANCES"),
|
|
archive_balances_window: ConfigHelper.parse_integer_env_var("ETHEREUM_JSONRPC_ARCHIVE_BALANCES_WINDOW", 200)
|
|
|
|
config :ethereum_jsonrpc, EthereumJSONRPC.HTTP,
|
|
headers:
|
|
%{"Content-Type" => "application/json"}
|
|
|> Map.merge(ConfigHelper.parse_json_env_var("ETHEREUM_JSONRPC_HTTP_HEADERS", "{}"))
|
|
|> Map.to_list()
|
|
|
|
config :ethereum_jsonrpc, EthereumJSONRPC.Geth,
|
|
block_traceable?: ConfigHelper.parse_bool_env_var("ETHEREUM_JSONRPC_GETH_TRACE_BY_BLOCK"),
|
|
allow_empty_traces?: ConfigHelper.parse_bool_env_var("ETHEREUM_JSONRPC_GETH_ALLOW_EMPTY_TRACES"),
|
|
debug_trace_timeout: System.get_env("ETHEREUM_JSONRPC_DEBUG_TRACE_TRANSACTION_TIMEOUT", "5s"),
|
|
tracer:
|
|
if(ConfigHelper.chain_type() == :polygon_edge,
|
|
do: "polygon_edge",
|
|
else: System.get_env("INDEXER_INTERNAL_TRANSACTIONS_TRACER_TYPE", "call_tracer")
|
|
)
|
|
|
|
config :ethereum_jsonrpc, EthereumJSONRPC.PendingTransaction,
|
|
type: System.get_env("ETHEREUM_JSONRPC_PENDING_TRANSACTIONS_TYPE", "default")
|
|
|
|
config :ethereum_jsonrpc, EthereumJSONRPC.RequestCoordinator,
|
|
wait_per_timeout: ConfigHelper.parse_time_env_var("ETHEREUM_JSONRPC_WAIT_PER_TIMEOUT", "20s")
|
|
|
|
config :ethereum_jsonrpc, EthereumJSONRPC.WebSocket.RetryWorker,
|
|
retry_interval: ConfigHelper.parse_time_env_var("ETHEREUM_JSONRPC_WS_RETRY_INTERVAL", "1m")
|
|
|
|
config :ethereum_jsonrpc, EthereumJSONRPC.Utility.EndpointAvailabilityChecker, enabled: true
|
|
|
|
################
|
|
### Explorer ###
|
|
################
|
|
|
|
disable_indexer? = ConfigHelper.parse_bool_env_var("DISABLE_INDEXER")
|
|
disable_webapp? = ConfigHelper.parse_bool_env_var("DISABLE_WEBAPP")
|
|
disable_exchange_rates? = ConfigHelper.parse_bool_env_var("DISABLE_EXCHANGE_RATES")
|
|
|
|
checksum_function = System.get_env("CHECKSUM_FUNCTION")
|
|
exchange_rates_coin = System.get_env("EXCHANGE_RATES_COIN")
|
|
|
|
config :explorer,
|
|
mode: ConfigHelper.mode(),
|
|
coin: System.get_env("COIN") || exchange_rates_coin || "ETH",
|
|
coin_name: System.get_env("COIN_NAME") || exchange_rates_coin || "ETH",
|
|
allowed_solidity_evm_versions:
|
|
System.get_env("CONTRACT_VERIFICATION_ALLOWED_SOLIDITY_EVM_VERSIONS") ||
|
|
"homestead,tangerineWhistle,spuriousDragon,byzantium,constantinople,petersburg,istanbul,berlin,london,paris,shanghai,cancun,default",
|
|
allowed_vyper_evm_versions:
|
|
System.get_env("CONTRACT_VERIFICATION_ALLOWED_VYPER_EVM_VERSIONS") ||
|
|
"byzantium,constantinople,petersburg,istanbul,berlin,paris,shanghai,cancun,default",
|
|
include_uncles_in_average_block_time: ConfigHelper.parse_bool_env_var("UNCLES_IN_AVERAGE_BLOCK_TIME"),
|
|
healthy_blocks_period: ConfigHelper.parse_time_env_var("HEALTHY_BLOCKS_PERIOD", "5m"),
|
|
realtime_events_sender:
|
|
if(disable_api? or disable_webapp?,
|
|
do: Explorer.Chain.Events.DBSender,
|
|
else: Explorer.Chain.Events.SimpleSender
|
|
),
|
|
restricted_list: System.get_env("RESTRICTED_LIST"),
|
|
restricted_list_key: System.get_env("RESTRICTED_LIST_KEY"),
|
|
checksum_function: checksum_function && String.to_atom(checksum_function),
|
|
elasticity_multiplier: ConfigHelper.parse_integer_env_var("EIP_1559_ELASTICITY_MULTIPLIER", 2),
|
|
base_fee_max_change_denominator: ConfigHelper.parse_integer_env_var("EIP_1559_BASE_FEE_MAX_CHANGE_DENOMINATOR", 8),
|
|
csv_export_limit: ConfigHelper.parse_integer_env_var("CSV_EXPORT_LIMIT", 10_000),
|
|
shrink_internal_transactions_enabled: ConfigHelper.parse_bool_env_var("SHRINK_INTERNAL_TRANSACTIONS_ENABLED")
|
|
|
|
config :explorer, :proxy,
|
|
caching_implementation_data_enabled: true,
|
|
implementation_data_ttl_via_avg_block_time:
|
|
ConfigHelper.parse_bool_env_var("CONTRACT_PROXY_IMPLEMENTATION_TTL_VIA_AVG_BLOCK_TIME", "true"),
|
|
fallback_cached_implementation_data_ttl: :timer.seconds(4),
|
|
implementation_data_fetching_timeout: :timer.seconds(2)
|
|
|
|
config :explorer, Explorer.Chain.Events.Listener, enabled: disable_indexer?
|
|
|
|
precompiled_config_base_dir =
|
|
case config_env() do
|
|
:prod -> "/app/"
|
|
_ -> "./"
|
|
end
|
|
|
|
precompiled_config_default_path =
|
|
case ConfigHelper.chain_type() do
|
|
:arbitrum -> "#{precompiled_config_base_dir}config/assets/precompiles-arbitrum.json"
|
|
_ -> nil
|
|
end
|
|
|
|
config :explorer, Explorer.ChainSpec.GenesisData,
|
|
chain_spec_path: System.get_env("CHAIN_SPEC_PATH"),
|
|
emission_format: System.get_env("EMISSION_FORMAT", "DEFAULT"),
|
|
rewards_contract_address: System.get_env("REWARDS_CONTRACT", "0xeca443e8e1ab29971a45a9c57a6a9875701698a5"),
|
|
precompiled_config_path: System.get_env("PRECOMPILED_CONTRACTS_CONFIG_PATH", precompiled_config_default_path)
|
|
|
|
address_sum_global_ttl = ConfigHelper.parse_time_env_var("CACHE_ADDRESS_SUM_PERIOD", "1h")
|
|
|
|
config :explorer, Explorer.Chain.Cache.AddressSum, global_ttl: address_sum_global_ttl
|
|
|
|
config :explorer, Explorer.Chain.Cache.AddressSumMinusBurnt, global_ttl: address_sum_global_ttl
|
|
|
|
config :explorer, Explorer.Chain.Cache.GasUsage,
|
|
global_ttl: ConfigHelper.parse_time_env_var("CACHE_TOTAL_GAS_USAGE_PERIOD", "2h")
|
|
|
|
config :explorer, Explorer.Chain.Cache.Block,
|
|
global_ttl: ConfigHelper.parse_time_env_var("CACHE_BLOCK_COUNT_PERIOD", "2h")
|
|
|
|
config :explorer, Explorer.Chain.Cache.Transaction,
|
|
global_ttl: ConfigHelper.parse_time_env_var("CACHE_TXS_COUNT_PERIOD", "2h")
|
|
|
|
config :explorer, Explorer.Chain.Cache.PendingBlockOperation,
|
|
global_ttl: ConfigHelper.parse_time_env_var("CACHE_PBO_COUNT_PERIOD", "20m")
|
|
|
|
config :explorer, Explorer.Chain.Cache.GasPriceOracle,
|
|
global_ttl: ConfigHelper.parse_time_env_var("GAS_PRICE_ORACLE_CACHE_PERIOD", "30s"),
|
|
simple_transaction_gas: ConfigHelper.parse_integer_env_var("GAS_PRICE_ORACLE_SIMPLE_TRANSACTION_GAS", 21000),
|
|
num_of_blocks: ConfigHelper.parse_integer_env_var("GAS_PRICE_ORACLE_NUM_OF_BLOCKS", 200),
|
|
safelow_percentile: ConfigHelper.parse_integer_env_var("GAS_PRICE_ORACLE_SAFELOW_PERCENTILE", 35),
|
|
average_percentile: ConfigHelper.parse_integer_env_var("GAS_PRICE_ORACLE_AVERAGE_PERCENTILE", 60),
|
|
fast_percentile: ConfigHelper.parse_integer_env_var("GAS_PRICE_ORACLE_FAST_PERCENTILE", 90),
|
|
safelow_time_coefficient: ConfigHelper.parse_float_env_var("GAS_PRICE_ORACLE_SAFELOW_TIME_COEFFICIENT", 5),
|
|
average_time_coefficient: ConfigHelper.parse_float_env_var("GAS_PRICE_ORACLE_AVERAGE_TIME_COEFFICIENT", 3),
|
|
fast_time_coefficient: ConfigHelper.parse_float_env_var("GAS_PRICE_ORACLE_FAST_TIME_COEFFICIENT", 1)
|
|
|
|
config :explorer, Explorer.Chain.Cache.RootstockLockedBTC,
|
|
enabled: System.get_env("ETHEREUM_JSONRPC_VARIANT") == "rsk",
|
|
global_ttl: ConfigHelper.parse_time_env_var("ROOTSTOCK_LOCKED_BTC_CACHE_PERIOD", "10m"),
|
|
locking_cap: ConfigHelper.parse_integer_env_var("ROOTSTOCK_LOCKING_CAP", 21_000_000)
|
|
|
|
config :explorer, Explorer.Chain.Cache.OptimismFinalizationPeriod, enabled: ConfigHelper.chain_type() == :optimism
|
|
|
|
config :explorer, Explorer.Counters.AddressTransactionsGasUsageCounter,
|
|
cache_period: ConfigHelper.parse_time_env_var("CACHE_ADDRESS_TRANSACTIONS_GAS_USAGE_COUNTER_PERIOD", "30m")
|
|
|
|
config :explorer, Explorer.Counters.TokenHoldersCounter,
|
|
cache_period: ConfigHelper.parse_time_env_var("CACHE_TOKEN_HOLDERS_COUNTER_PERIOD", "1h")
|
|
|
|
config :explorer, Explorer.Counters.TokenTransfersCounter,
|
|
cache_period: ConfigHelper.parse_time_env_var("CACHE_TOKEN_TRANSFERS_COUNTER_PERIOD", "1h")
|
|
|
|
config :explorer, Explorer.Counters.AverageBlockTime,
|
|
enabled: true,
|
|
period: :timer.minutes(10),
|
|
cache_period: ConfigHelper.parse_time_env_var("CACHE_AVERAGE_BLOCK_PERIOD", "30m")
|
|
|
|
config :explorer, Explorer.Market.MarketHistoryCache,
|
|
cache_period: ConfigHelper.parse_time_env_var("CACHE_MARKET_HISTORY_PERIOD", "6h")
|
|
|
|
config :explorer, Explorer.Counters.AddressTransactionsCounter,
|
|
cache_period: ConfigHelper.parse_time_env_var("CACHE_ADDRESS_TRANSACTIONS_COUNTER_PERIOD", "1h")
|
|
|
|
config :explorer, Explorer.Counters.AddressTokenUsdSum,
|
|
cache_period: ConfigHelper.parse_time_env_var("CACHE_ADDRESS_TOKENS_USD_SUM_PERIOD", "1h")
|
|
|
|
config :explorer, Explorer.Counters.AddressTokenTransfersCounter,
|
|
cache_period: ConfigHelper.parse_time_env_var("CACHE_ADDRESS_TOKEN_TRANSFERS_COUNTER_PERIOD", "1h")
|
|
|
|
config :explorer, Explorer.Counters.LastOutputRootSizeCounter,
|
|
enabled: ConfigHelper.chain_type() == :optimism,
|
|
enable_consolidation: ConfigHelper.chain_type() == :optimism,
|
|
cache_period: ConfigHelper.parse_time_env_var("CACHE_OPTIMISM_LAST_OUTPUT_ROOT_SIZE_COUNTER_PERIOD", "5m")
|
|
|
|
config :explorer, Explorer.Counters.Transactions24hStats,
|
|
enabled: true,
|
|
cache_period: ConfigHelper.parse_time_env_var("CACHE_TRANSACTIONS_24H_STATS_PERIOD", "1h"),
|
|
enable_consolidation: true
|
|
|
|
config :explorer, Explorer.Counters.FreshPendingTransactionsCounter,
|
|
enabled: true,
|
|
cache_period: ConfigHelper.parse_time_env_var("CACHE_FRESH_PENDING_TRANSACTIONS_COUNTER_PERIOD", "5m"),
|
|
enable_consolidation: true
|
|
|
|
cmc_secondary_coin_id = System.get_env("EXCHANGE_RATES_COINMARKETCAP_SECONDARY_COIN_ID")
|
|
cg_secondary_coin_id = System.get_env("EXCHANGE_RATES_COINGECKO_SECONDARY_COIN_ID")
|
|
cc_secondary_coin_symbol = System.get_env("EXCHANGE_RATES_CRYPTOCOMPARE_SECONDARY_COIN_SYMBOL")
|
|
mobula_secondary_coin_id = System.get_env("EXCHANGE_RATES_MOBULA_SECONDARY_COIN_ID")
|
|
|
|
config :explorer, Explorer.ExchangeRates,
|
|
store: :ets,
|
|
enabled: !disable_exchange_rates?,
|
|
enable_consolidation: true,
|
|
secondary_coin_enabled:
|
|
!disable_exchange_rates? && (cmc_secondary_coin_id || cg_secondary_coin_id || mobula_secondary_coin_id),
|
|
fetch_btc_value: ConfigHelper.parse_bool_env_var("EXCHANGE_RATES_FETCH_BTC_VALUE"),
|
|
cache_period: ConfigHelper.parse_time_env_var("CACHE_EXCHANGE_RATES_PERIOD", "10m")
|
|
|
|
config :explorer, Explorer.ExchangeRates.Source,
|
|
source: ConfigHelper.exchange_rates_source(),
|
|
secondary_coin_source: ConfigHelper.exchange_rates_secondary_coin_source(),
|
|
price_source: ConfigHelper.exchange_rates_price_source(),
|
|
secondary_coin_price_source: ConfigHelper.exchange_rates_secondary_coin_price_source(),
|
|
market_cap_source: ConfigHelper.exchange_rates_market_cap_source(),
|
|
tvl_source: ConfigHelper.exchange_rates_tvl_source()
|
|
|
|
config :explorer, Explorer.ExchangeRates.Source.CoinMarketCap,
|
|
base_url: System.get_env("EXCHANGE_RATES_COINMARKETCAP_BASE_URL"),
|
|
api_key: System.get_env("EXCHANGE_RATES_COINMARKETCAP_API_KEY"),
|
|
coin_id: System.get_env("EXCHANGE_RATES_COINMARKETCAP_COIN_ID"),
|
|
secondary_coin_id: cmc_secondary_coin_id
|
|
|
|
config :explorer, Explorer.ExchangeRates.Source.CoinGecko,
|
|
platform: System.get_env("EXCHANGE_RATES_COINGECKO_PLATFORM_ID"),
|
|
base_url: System.get_env("EXCHANGE_RATES_COINGECKO_BASE_URL"),
|
|
base_pro_url: System.get_env("EXCHANGE_RATES_COINGECKO_BASE_PRO_URL"),
|
|
api_key: System.get_env("EXCHANGE_RATES_COINGECKO_API_KEY"),
|
|
coin_id: System.get_env("EXCHANGE_RATES_COINGECKO_COIN_ID"),
|
|
secondary_coin_id: cg_secondary_coin_id
|
|
|
|
config :explorer, Explorer.ExchangeRates.Source.Mobula,
|
|
platform: System.get_env("EXCHANGE_RATES_MOBULA_CHAIN_ID"),
|
|
base_url: System.get_env("EXCHANGE_RATES_MOBULA_BASE_URL", "https://api.mobula.io/api/1"),
|
|
api_key: System.get_env("EXCHANGE_RATES_MOBULA_API_KEY"),
|
|
coin_id: System.get_env("EXCHANGE_RATES_MOBULA_COIN_ID"),
|
|
secondary_coin_id: mobula_secondary_coin_id
|
|
|
|
config :explorer, Explorer.ExchangeRates.Source.DefiLlama, coin_id: System.get_env("EXCHANGE_RATES_DEFILLAMA_COIN_ID")
|
|
|
|
config :explorer, Explorer.Market.History.Source.Price.CryptoCompare, secondary_coin_symbol: cc_secondary_coin_symbol
|
|
|
|
config :explorer, Explorer.ExchangeRates.TokenExchangeRates,
|
|
enabled: !ConfigHelper.parse_bool_env_var("DISABLE_TOKEN_EXCHANGE_RATE", "true"),
|
|
interval: ConfigHelper.parse_time_env_var("TOKEN_EXCHANGE_RATE_INTERVAL", "5s"),
|
|
refetch_interval: ConfigHelper.parse_time_env_var("TOKEN_EXCHANGE_RATE_REFETCH_INTERVAL", "1h"),
|
|
max_batch_size: ConfigHelper.parse_integer_env_var("TOKEN_EXCHANGE_RATE_MAX_BATCH_SIZE", 150),
|
|
source: ConfigHelper.token_exchange_rates_source()
|
|
|
|
cryptorank_secondary_coin_id = ConfigHelper.parse_integer_or_nil_env_var("EXCHANGE_RATES_CRYPTORANK_SECONDARY_COIN_ID")
|
|
|
|
config :explorer, Explorer.ExchangeRates.Source.Cryptorank,
|
|
platform: ConfigHelper.parse_integer_or_nil_env_var("EXCHANGE_RATES_CRYPTORANK_PLATFORM_ID"),
|
|
base_url: System.get_env("EXCHANGE_RATES_CRYPTORANK_BASE_URL", "https://api.cryptorank.io/v1/"),
|
|
api_key: System.get_env("EXCHANGE_RATES_CRYPTORANK_API_KEY"),
|
|
coin_id: ConfigHelper.parse_integer_or_nil_env_var("EXCHANGE_RATES_CRYPTORANK_COIN_ID"),
|
|
secondary_coin_id: cryptorank_secondary_coin_id,
|
|
limit: ConfigHelper.parse_integer_env_var("EXCHANGE_RATES_CRYPTORANK_LIMIT", 1000)
|
|
|
|
config :explorer, Explorer.Market.History.Cataloger,
|
|
enabled: !disable_indexer? && !disable_exchange_rates?,
|
|
history_fetch_interval: ConfigHelper.parse_time_env_var("MARKET_HISTORY_FETCH_INTERVAL", "1h"),
|
|
secondary_coin_enabled:
|
|
cmc_secondary_coin_id || cg_secondary_coin_id || cc_secondary_coin_symbol || mobula_secondary_coin_id ||
|
|
cryptorank_secondary_coin_id
|
|
|
|
config :explorer, Explorer.Chain.Transaction, suave_bid_contracts: System.get_env("SUAVE_BID_CONTRACTS", "")
|
|
|
|
config :explorer, Explorer.Chain.Transaction.History.Historian,
|
|
enabled: ConfigHelper.parse_bool_env_var("TXS_STATS_ENABLED", "true"),
|
|
init_lag_milliseconds: ConfigHelper.parse_time_env_var("TXS_HISTORIAN_INIT_LAG", "0"),
|
|
days_to_compile_at_init: ConfigHelper.parse_integer_env_var("TXS_STATS_DAYS_TO_COMPILE_AT_INIT", 40)
|
|
|
|
if System.get_env("METADATA_CONTRACT") && System.get_env("VALIDATORS_CONTRACT") do
|
|
config :explorer, Explorer.Validator.MetadataRetriever,
|
|
metadata_contract_address: System.get_env("METADATA_CONTRACT"),
|
|
validators_contract_address: System.get_env("VALIDATORS_CONTRACT")
|
|
|
|
config :explorer, Explorer.Validator.MetadataProcessor, enabled: !disable_indexer?
|
|
else
|
|
config :explorer, Explorer.Validator.MetadataProcessor, enabled: false
|
|
end
|
|
|
|
config :explorer, Explorer.Chain.Block.Reward,
|
|
validators_contract_address: System.get_env("VALIDATORS_CONTRACT"),
|
|
keys_manager_contract_address: System.get_env("KEYS_MANAGER_CONTRACT")
|
|
|
|
case System.get_env("SUPPLY_MODULE") do
|
|
"rsk" ->
|
|
config :explorer, supply: Explorer.Chain.Supply.RSK
|
|
|
|
_ ->
|
|
:ok
|
|
end
|
|
|
|
config :explorer, Explorer.Chain.Cache.BlockNumber,
|
|
ttl_check_interval: ConfigHelper.cache_ttl_check_interval(disable_indexer?),
|
|
global_ttl: ConfigHelper.cache_global_ttl(disable_indexer?)
|
|
|
|
config :explorer, Explorer.Chain.Cache.Blocks,
|
|
ttl_check_interval: ConfigHelper.cache_ttl_check_interval(disable_indexer?),
|
|
global_ttl: ConfigHelper.cache_global_ttl(disable_indexer?)
|
|
|
|
config :explorer, Explorer.Chain.Cache.Transactions,
|
|
ttl_check_interval: ConfigHelper.cache_ttl_check_interval(disable_indexer?),
|
|
global_ttl: ConfigHelper.cache_global_ttl(disable_indexer?)
|
|
|
|
config :explorer, Explorer.Chain.Cache.TransactionsApiV2,
|
|
ttl_check_interval: ConfigHelper.cache_ttl_check_interval(disable_indexer?),
|
|
global_ttl: ConfigHelper.cache_global_ttl(disable_indexer?)
|
|
|
|
config :explorer, Explorer.Chain.Cache.Accounts,
|
|
ttl_check_interval: ConfigHelper.cache_ttl_check_interval(disable_indexer?),
|
|
global_ttl: ConfigHelper.cache_global_ttl(disable_indexer?)
|
|
|
|
config :explorer, Explorer.Chain.Cache.Uncles,
|
|
ttl_check_interval: ConfigHelper.cache_ttl_check_interval(disable_indexer?),
|
|
global_ttl: ConfigHelper.cache_global_ttl(disable_indexer?)
|
|
|
|
config :explorer, Explorer.Chain.Cache.Uncles,
|
|
ttl_check_interval: ConfigHelper.cache_ttl_check_interval(disable_indexer?),
|
|
global_ttl: ConfigHelper.cache_global_ttl(disable_indexer?)
|
|
|
|
config :explorer, Explorer.Chain.Cache.CeloCoreContracts,
|
|
contracts: ConfigHelper.parse_json_env_var("CELO_CORE_CONTRACTS")
|
|
|
|
config :explorer, Explorer.ThirdPartyIntegrations.Sourcify,
|
|
server_url: System.get_env("SOURCIFY_SERVER_URL") || "https://sourcify.dev/server",
|
|
enabled: ConfigHelper.parse_bool_env_var("SOURCIFY_INTEGRATION_ENABLED"),
|
|
chain_id: System.get_env("CHAIN_ID"),
|
|
repo_url: System.get_env("SOURCIFY_REPO_URL") || "https://repo.sourcify.dev/contracts"
|
|
|
|
config :explorer, Explorer.ThirdPartyIntegrations.SolidityScan,
|
|
platform_id: System.get_env("SOLIDITYSCAN_PLATFORM_ID", "16"),
|
|
chain_id: System.get_env("SOLIDITYSCAN_CHAIN_ID"),
|
|
api_key: System.get_env("SOLIDITYSCAN_API_TOKEN")
|
|
|
|
config :explorer, Explorer.ThirdPartyIntegrations.NovesFi,
|
|
service_url: System.get_env("NOVES_FI_BASE_API_URL") || "https://blockscout.noves.fi",
|
|
chain_name: System.get_env("NOVES_FI_CHAIN_NAME"),
|
|
api_key: System.get_env("NOVES_FI_API_TOKEN")
|
|
|
|
config :explorer, Explorer.ThirdPartyIntegrations.Zerion,
|
|
service_url: System.get_env("ZERION_BASE_API_URL", "https://api.zerion.io/v1"),
|
|
api_key: System.get_env("ZERION_API_TOKEN")
|
|
|
|
config :explorer, Explorer.ThirdPartyIntegrations.Xname,
|
|
service_url: System.get_env("XNAME_BASE_API_URL", "https://gateway.xname.app"),
|
|
api_key: System.get_env("XNAME_API_TOKEN")
|
|
|
|
enabled? = ConfigHelper.parse_bool_env_var("MICROSERVICE_SC_VERIFIER_ENABLED", "true")
|
|
# or "eth_bytecode_db"
|
|
type = System.get_env("MICROSERVICE_SC_VERIFIER_TYPE", "sc_verifier")
|
|
|
|
config :explorer, Explorer.SmartContract.RustVerifierInterfaceBehaviour,
|
|
service_url: System.get_env("MICROSERVICE_SC_VERIFIER_URL") || "https://eth-bytecode-db.services.blockscout.com/",
|
|
enabled: enabled?,
|
|
type: type,
|
|
eth_bytecode_db?: enabled? && type == "eth_bytecode_db",
|
|
api_key: System.get_env("MICROSERVICE_SC_VERIFIER_API_KEY")
|
|
|
|
config :explorer, Explorer.Visualize.Sol2uml,
|
|
service_url: System.get_env("MICROSERVICE_VISUALIZE_SOL2UML_URL"),
|
|
enabled: ConfigHelper.parse_bool_env_var("MICROSERVICE_VISUALIZE_SOL2UML_ENABLED")
|
|
|
|
config :explorer, Explorer.SmartContract.SigProviderInterface,
|
|
service_url: System.get_env("MICROSERVICE_SIG_PROVIDER_URL"),
|
|
enabled: ConfigHelper.parse_bool_env_var("MICROSERVICE_SIG_PROVIDER_ENABLED")
|
|
|
|
config :explorer, Explorer.MicroserviceInterfaces.BENS,
|
|
service_url: System.get_env("MICROSERVICE_BENS_URL"),
|
|
enabled: ConfigHelper.parse_bool_env_var("MICROSERVICE_BENS_ENABLED")
|
|
|
|
config :explorer, Explorer.MicroserviceInterfaces.AccountAbstraction,
|
|
service_url: System.get_env("MICROSERVICE_ACCOUNT_ABSTRACTION_URL"),
|
|
enabled: ConfigHelper.parse_bool_env_var("MICROSERVICE_ACCOUNT_ABSTRACTION_ENABLED")
|
|
|
|
config :explorer, Explorer.MicroserviceInterfaces.Metadata,
|
|
service_url: System.get_env("MICROSERVICE_METADATA_URL"),
|
|
enabled: ConfigHelper.parse_bool_env_var("MICROSERVICE_METADATA_ENABLED")
|
|
|
|
config :explorer, :air_table_public_tags,
|
|
table_url: System.get_env("ACCOUNT_PUBLIC_TAGS_AIRTABLE_URL"),
|
|
api_key: System.get_env("ACCOUNT_PUBLIC_TAGS_AIRTABLE_API_KEY")
|
|
|
|
audit_reports_table_url = System.get_env("CONTRACT_AUDIT_REPORTS_AIRTABLE_URL")
|
|
|
|
audit_reports_api_key =
|
|
System.get_env("CONTRACT_AUDIT_REPORTS_AIRTABLE_API_KEY") || System.get_env("ACCOUNT_PUBLIC_TAGS_AIRTABLE_API_KEY")
|
|
|
|
config :explorer, :air_table_audit_reports,
|
|
table_url: audit_reports_table_url,
|
|
api_key: audit_reports_api_key,
|
|
enabled: (audit_reports_table_url && audit_reports_api_key && true) || false
|
|
|
|
config :explorer, Explorer.Mailer,
|
|
adapter: Bamboo.SendGridAdapter,
|
|
api_key: System.get_env("ACCOUNT_SENDGRID_API_KEY")
|
|
|
|
config :explorer, Explorer.Account,
|
|
enabled: ConfigHelper.parse_bool_env_var("ACCOUNT_ENABLED"),
|
|
sendgrid: [
|
|
sender: System.get_env("ACCOUNT_SENDGRID_SENDER"),
|
|
template: System.get_env("ACCOUNT_SENDGRID_TEMPLATE")
|
|
],
|
|
verification_email_resend_interval:
|
|
ConfigHelper.parse_time_env_var("ACCOUNT_VERIFICATION_EMAIL_RESEND_INTERVAL", "5m"),
|
|
otp_resend_interval: ConfigHelper.parse_time_env_var("ACCOUNT_OTP_RESEND_INTERVAL", "1m"),
|
|
private_tags_limit: ConfigHelper.parse_integer_env_var("ACCOUNT_PRIVATE_TAGS_LIMIT", 2000),
|
|
watchlist_addresses_limit: ConfigHelper.parse_integer_env_var("ACCOUNT_WATCHLIST_ADDRESSES_LIMIT", 15),
|
|
notifications_limit_for_30_days:
|
|
ConfigHelper.parse_integer_env_var("ACCOUNT_WATCHLIST_NOTIFICATIONS_LIMIT_FOR_30_DAYS", 1000),
|
|
siwe_message: System.get_env("ACCOUNT_SIWE_MESSAGE", "Sign in to Blockscout Account V2")
|
|
|
|
config :explorer, :token_id_migration,
|
|
first_block: ConfigHelper.parse_integer_env_var("TOKEN_ID_MIGRATION_FIRST_BLOCK", 0),
|
|
concurrency: ConfigHelper.parse_integer_env_var("TOKEN_ID_MIGRATION_CONCURRENCY", 1),
|
|
batch_size: ConfigHelper.parse_integer_env_var("TOKEN_ID_MIGRATION_BATCH_SIZE", 500)
|
|
|
|
config :explorer, Explorer.Chain.Cache.MinMissingBlockNumber,
|
|
batch_size: ConfigHelper.parse_integer_env_var("MIN_MISSING_BLOCK_NUMBER_BATCH_SIZE", 100_000)
|
|
|
|
config :explorer, :spandex,
|
|
batch_size: ConfigHelper.parse_integer_env_var("SPANDEX_BATCH_SIZE", 100),
|
|
sync_threshold: ConfigHelper.parse_integer_env_var("SPANDEX_SYNC_THRESHOLD", 100)
|
|
|
|
config :explorer, :datadog, port: ConfigHelper.parse_integer_env_var("DATADOG_PORT", 8126)
|
|
|
|
config :explorer, Explorer.Chain.Cache.TransactionActionTokensData,
|
|
max_cache_size: ConfigHelper.parse_integer_env_var("INDEXER_TX_ACTIONS_MAX_TOKEN_CACHE_SIZE", 100_000)
|
|
|
|
config :explorer, Explorer.Chain.Fetcher.LookUpSmartContractSourcesOnDemand,
|
|
fetch_interval: ConfigHelper.parse_time_env_var("MICROSERVICE_ETH_BYTECODE_DB_INTERVAL_BETWEEN_LOOKUPS", "10m"),
|
|
max_concurrency: ConfigHelper.parse_integer_env_var("MICROSERVICE_ETH_BYTECODE_DB_MAX_LOOKUPS_CONCURRENCY", 10)
|
|
|
|
config :explorer, Explorer.Chain.Cache.MinMissingBlockNumber,
|
|
enabled: !ConfigHelper.parse_bool_env_var("DISABLE_INDEXER")
|
|
|
|
config :explorer, Explorer.TokenInstanceOwnerAddressMigration,
|
|
concurrency: ConfigHelper.parse_integer_env_var("TOKEN_INSTANCE_OWNER_MIGRATION_CONCURRENCY", 5),
|
|
batch_size: ConfigHelper.parse_integer_env_var("TOKEN_INSTANCE_OWNER_MIGRATION_BATCH_SIZE", 50),
|
|
enabled: ConfigHelper.parse_bool_env_var("TOKEN_INSTANCE_OWNER_MIGRATION_ENABLED")
|
|
|
|
config :explorer, Explorer.Chain.Transaction,
|
|
rootstock_remasc_address: System.get_env("ROOTSTOCK_REMASC_ADDRESS"),
|
|
rootstock_bridge_address: System.get_env("ROOTSTOCK_BRIDGE_ADDRESS")
|
|
|
|
config :explorer, Explorer.Chain.Cache.AddressesTabsCounters,
|
|
ttl: ConfigHelper.parse_time_env_var("ADDRESSES_TABS_COUNTERS_TTL", "10m")
|
|
|
|
config :explorer, Explorer.Migrator.TransactionsDenormalization,
|
|
batch_size: ConfigHelper.parse_integer_env_var("DENORMALIZATION_MIGRATION_BATCH_SIZE", 500),
|
|
concurrency: ConfigHelper.parse_integer_env_var("DENORMALIZATION_MIGRATION_CONCURRENCY", 10)
|
|
|
|
config :explorer, Explorer.Migrator.TokenTransferTokenType,
|
|
batch_size: ConfigHelper.parse_integer_env_var("TOKEN_TRANSFER_TOKEN_TYPE_MIGRATION_BATCH_SIZE", 100),
|
|
concurrency: ConfigHelper.parse_integer_env_var("TOKEN_TRANSFER_TOKEN_TYPE_MIGRATION_CONCURRENCY", 1)
|
|
|
|
config :explorer, Explorer.Migrator.SanitizeIncorrectNFTTokenTransfers,
|
|
batch_size: ConfigHelper.parse_integer_env_var("SANITIZE_INCORRECT_NFT_BATCH_SIZE", 100),
|
|
concurrency: ConfigHelper.parse_integer_env_var("SANITIZE_INCORRECT_NFT_CONCURRENCY", 1)
|
|
|
|
config :explorer, Explorer.Migrator.SanitizeIncorrectWETHTokenTransfers,
|
|
batch_size: ConfigHelper.parse_integer_env_var("SANITIZE_INCORRECT_WETH_BATCH_SIZE", 100),
|
|
concurrency: ConfigHelper.parse_integer_env_var("SANITIZE_INCORRECT_WETH_CONCURRENCY", 1)
|
|
|
|
config :explorer, Explorer.Migrator.RestoreOmittedWETHTransfers,
|
|
concurrency: ConfigHelper.parse_integer_env_var("MIGRATION_RESTORE_OMITTED_WETH_TOKEN_TRANSFERS_CONCURRENCY", 5),
|
|
batch_size: ConfigHelper.parse_integer_env_var("MIGRATION_RESTORE_OMITTED_WETH_TOKEN_TRANSFERS_BATCH_SIZE", 50),
|
|
timeout: ConfigHelper.parse_time_env_var("MIGRATION_RESTORE_OMITTED_WETH_TOKEN_TRANSFERS_TIMEOUT", "250ms")
|
|
|
|
config :explorer, Explorer.Migrator.SanitizeDuplicatedLogIndexLogs,
|
|
concurrency: ConfigHelper.parse_integer_env_var("MIGRATION_SANITIZE_DUPLICATED_LOG_INDEX_LOGS_CONCURRENCY", 10),
|
|
batch_size: ConfigHelper.parse_integer_env_var("MIGRATION_SANITIZE_DUPLICATED_LOG_INDEX_LOGS_BATCH_SIZE", 500)
|
|
|
|
config :explorer, Explorer.Migrator.RefetchContractCodes,
|
|
concurrency: ConfigHelper.parse_integer_env_var("MIGRATION_REFETCH_CONTRACT_CODES_CONCURRENCY", 5),
|
|
batch_size: ConfigHelper.parse_integer_env_var("MIGRATION_REFETCH_CONTRACT_CODES_BATCH_SIZE", 100)
|
|
|
|
config :explorer, Explorer.Migrator.ShrinkInternalTransactions,
|
|
enabled: ConfigHelper.parse_bool_env_var("SHRINK_INTERNAL_TRANSACTIONS_ENABLED"),
|
|
batch_size: ConfigHelper.parse_integer_env_var("SHRINK_INTERNAL_TRANSACTIONS_BATCH_SIZE", 100),
|
|
concurrency: ConfigHelper.parse_integer_env_var("SHRINK_INTERNAL_TRANSACTIONS_CONCURRENCY", 10)
|
|
|
|
config :explorer, Explorer.Chain.BridgedToken,
|
|
eth_omni_bridge_mediator: System.get_env("BRIDGED_TOKENS_ETH_OMNI_BRIDGE_MEDIATOR"),
|
|
bsc_omni_bridge_mediator: System.get_env("BRIDGED_TOKENS_BSC_OMNI_BRIDGE_MEDIATOR"),
|
|
poa_omni_bridge_mediator: System.get_env("BRIDGED_TOKENS_POA_OMNI_BRIDGE_MEDIATOR"),
|
|
amb_bridge_mediators: System.get_env("BRIDGED_TOKENS_AMB_BRIDGE_MEDIATORS"),
|
|
foreign_json_rpc: System.get_env("BRIDGED_TOKENS_FOREIGN_JSON_RPC", "")
|
|
|
|
config :explorer, Explorer.Utility.MissingBalanceOfToken,
|
|
window_size: ConfigHelper.parse_integer_env_var("MISSING_BALANCE_OF_TOKENS_WINDOW_SIZE", 100)
|
|
|
|
config :explorer, Explorer.Chain.TokenTransfer,
|
|
whitelisted_weth_contracts: ConfigHelper.parse_list_env_var("WHITELISTED_WETH_CONTRACTS", ""),
|
|
weth_token_transfers_filtering_enabled: ConfigHelper.parse_bool_env_var("WETH_TOKEN_TRANSFERS_FILTERING_ENABLED")
|
|
|
|
config :explorer, Explorer.Chain.Metrics,
|
|
enabled: ConfigHelper.parse_bool_env_var("PUBLIC_METRICS_ENABLED", "false"),
|
|
update_period_hours: ConfigHelper.parse_integer_env_var("PUBLIC_METRICS_UPDATE_PERIOD_HOURS", 24)
|
|
|
|
config :explorer, Explorer.Chain.Filecoin.NativeAddress,
|
|
network_prefix: ConfigHelper.parse_catalog_value("FILECOIN_NETWORK_PREFIX", ["f", "t"], true, "f")
|
|
|
|
config :explorer, Explorer.Migrator.FilecoinPendingAddressOperations,
|
|
enabled: ConfigHelper.chain_type() == :filecoin,
|
|
batch_size: ConfigHelper.parse_integer_env_var("FILECOIN_PENDING_ADDRESS_OPERATIONS_MIGRATION_BATCH_SIZE", 100),
|
|
concurrency: ConfigHelper.parse_integer_env_var("FILECOIN_PENDING_ADDRESS_OPERATIONS_MIGRATION_CONCURRENCY", 1)
|
|
|
|
config :explorer, Explorer.Chain.Blackfort.Validator, api_url: System.get_env("BLACKFORT_VALIDATOR_API_URL")
|
|
|
|
###############
|
|
### Indexer ###
|
|
###############
|
|
|
|
first_block = ConfigHelper.parse_integer_env_var("FIRST_BLOCK", 0)
|
|
|
|
trace_first_block = ConfigHelper.parse_integer_env_var("TRACE_FIRST_BLOCK", 0)
|
|
trace_last_block = ConfigHelper.parse_integer_or_nil_env_var("TRACE_LAST_BLOCK")
|
|
|
|
trace_block_ranges =
|
|
case ConfigHelper.safe_get_env("TRACE_BLOCK_RANGES", nil) do
|
|
"" -> "#{trace_first_block}..#{trace_last_block || "latest"}"
|
|
ranges -> ranges
|
|
end
|
|
|
|
config :indexer,
|
|
block_transformer: ConfigHelper.block_transformer(),
|
|
metadata_updater_milliseconds_interval: ConfigHelper.parse_time_env_var("TOKEN_METADATA_UPDATE_INTERVAL", "48h"),
|
|
block_ranges: System.get_env("BLOCK_RANGES"),
|
|
first_block: first_block,
|
|
last_block: ConfigHelper.parse_integer_or_nil_env_var("LAST_BLOCK"),
|
|
trace_block_ranges: trace_block_ranges,
|
|
trace_first_block: trace_first_block,
|
|
trace_last_block: trace_last_block,
|
|
fetch_rewards_way: System.get_env("FETCH_REWARDS_WAY", "trace_block"),
|
|
memory_limit: ConfigHelper.indexer_memory_limit(),
|
|
system_memory_percentage: ConfigHelper.parse_integer_env_var("INDEXER_SYSTEM_MEMORY_PERCENTAGE", 60),
|
|
receipts_batch_size: ConfigHelper.parse_integer_env_var("INDEXER_RECEIPTS_BATCH_SIZE", 250),
|
|
receipts_concurrency: ConfigHelper.parse_integer_env_var("INDEXER_RECEIPTS_CONCURRENCY", 10),
|
|
hide_indexing_progress_alert: ConfigHelper.parse_bool_env_var("INDEXER_HIDE_INDEXING_PROGRESS_ALERT"),
|
|
fetcher_init_limit: ConfigHelper.parse_integer_env_var("INDEXER_FETCHER_INIT_QUERY_LIMIT", 100),
|
|
token_balances_fetcher_init_limit:
|
|
ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_BALANCES_FETCHER_INIT_QUERY_LIMIT", 100_000),
|
|
coin_balances_fetcher_init_limit:
|
|
ConfigHelper.parse_integer_env_var("INDEXER_COIN_BALANCES_FETCHER_INIT_QUERY_LIMIT", 2000),
|
|
graceful_shutdown_period: ConfigHelper.parse_time_env_var("INDEXER_GRACEFUL_SHUTDOWN_PERIOD", "5m"),
|
|
internal_transactions_fetch_order:
|
|
ConfigHelper.parse_catalog_value("INDEXER_INTERNAL_TRANSACTIONS_FETCH_ORDER", ["asc", "desc"], true, "asc")
|
|
|
|
config :indexer, :ipfs,
|
|
gateway_url: System.get_env("IPFS_GATEWAY_URL", "https://ipfs.io/ipfs"),
|
|
gateway_url_param_key: System.get_env("IPFS_GATEWAY_URL_PARAM_KEY"),
|
|
gateway_url_param_value: System.get_env("IPFS_GATEWAY_URL_PARAM_VALUE"),
|
|
gateway_url_param_location:
|
|
ConfigHelper.parse_catalog_value("IPFS_GATEWAY_URL_PARAM_LOCATION", ["query", "header"], true),
|
|
public_gateway_url: System.get_env("IPFS_PUBLIC_GATEWAY_URL", "https://ipfs.io/ipfs")
|
|
|
|
config :indexer, Indexer.Supervisor, enabled: !ConfigHelper.parse_bool_env_var("DISABLE_INDEXER")
|
|
|
|
config :indexer, Indexer.Fetcher.TransactionAction.Supervisor,
|
|
enabled: ConfigHelper.parse_bool_env_var("INDEXER_TX_ACTIONS_ENABLE")
|
|
|
|
config :indexer, Indexer.Fetcher.TransactionAction,
|
|
reindex_first_block: System.get_env("INDEXER_TX_ACTIONS_REINDEX_FIRST_BLOCK"),
|
|
reindex_last_block: System.get_env("INDEXER_TX_ACTIONS_REINDEX_LAST_BLOCK"),
|
|
reindex_protocols: System.get_env("INDEXER_TX_ACTIONS_REINDEX_PROTOCOLS", ""),
|
|
aave_v3_pool: System.get_env("INDEXER_TX_ACTIONS_AAVE_V3_POOL_CONTRACT"),
|
|
uniswap_v3_factory:
|
|
ConfigHelper.safe_get_env(
|
|
"INDEXER_TX_ACTIONS_UNISWAP_V3_FACTORY_CONTRACT",
|
|
"0x1F98431c8aD98523631AE4a59f267346ea31F984"
|
|
),
|
|
uniswap_v3_nft_position_manager:
|
|
ConfigHelper.safe_get_env(
|
|
"INDEXER_TX_ACTIONS_UNISWAP_V3_NFT_POSITION_MANAGER_CONTRACT",
|
|
"0xC36442b4a4522E871399CD717aBDD847Ab11FE88"
|
|
)
|
|
|
|
config :indexer, Indexer.Fetcher.PendingTransaction.Supervisor,
|
|
disabled?: ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_PENDING_TRANSACTIONS_FETCHER")
|
|
|
|
config :indexer, Indexer.Fetcher.Token, concurrency: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_CONCURRENCY", 10)
|
|
|
|
config :indexer, Indexer.Fetcher.TokenBalance,
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_BALANCES_BATCH_SIZE", 100),
|
|
concurrency: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_BALANCES_CONCURRENCY", 10),
|
|
max_refetch_interval: ConfigHelper.parse_time_env_var("INDEXER_TOKEN_BALANCES_MAX_REFETCH_INTERVAL", "168h"),
|
|
exp_timeout_coeff: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_BALANCES_EXPONENTIAL_TIMEOUT_COEFF", 100)
|
|
|
|
config :indexer, Indexer.Fetcher.OnDemand.TokenBalance,
|
|
threshold: ConfigHelper.parse_time_env_var("TOKEN_BALANCE_ON_DEMAND_FETCHER_THRESHOLD", "1h"),
|
|
fallback_threshold_in_blocks: 500
|
|
|
|
config :indexer, Indexer.Fetcher.OnDemand.CoinBalance,
|
|
threshold: ConfigHelper.parse_time_env_var("COIN_BALANCE_ON_DEMAND_FETCHER_THRESHOLD", "1h"),
|
|
fallback_threshold_in_blocks: 500
|
|
|
|
config :indexer, Indexer.Fetcher.OnDemand.ContractCode,
|
|
threshold: ConfigHelper.parse_time_env_var("CONTRACT_CODE_ON_DEMAND_FETCHER_THRESHOLD", "5s")
|
|
|
|
config :indexer, Indexer.Fetcher.OnDemand.TokenInstanceMetadataRefetch,
|
|
threshold: ConfigHelper.parse_time_env_var("TOKEN_INSTANCE_METADATA_REFETCH_ON_DEMAND_FETCHER_THRESHOLD", "5s")
|
|
|
|
config :indexer, Indexer.Fetcher.BlockReward.Supervisor,
|
|
disabled?: ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_BLOCK_REWARD_FETCHER")
|
|
|
|
config :indexer, Indexer.Fetcher.InternalTransaction.Supervisor,
|
|
disabled?: trace_url_missing? or ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_INTERNAL_TRANSACTIONS_FETCHER")
|
|
|
|
disable_coin_balances_fetcher? = ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_ADDRESS_COIN_BALANCE_FETCHER")
|
|
|
|
config :indexer, Indexer.Fetcher.CoinBalance.Catchup.Supervisor, disabled?: disable_coin_balances_fetcher?
|
|
|
|
config :indexer, Indexer.Fetcher.CoinBalance.Realtime.Supervisor, disabled?: disable_coin_balances_fetcher?
|
|
|
|
config :indexer, Indexer.Fetcher.TokenUpdater.Supervisor,
|
|
disabled?: ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_CATALOGED_TOKEN_UPDATER_FETCHER")
|
|
|
|
config :indexer, Indexer.Fetcher.EmptyBlocksSanitizer.Supervisor,
|
|
disabled?: ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_EMPTY_BLOCKS_SANITIZER")
|
|
|
|
config :indexer, Indexer.Block.Realtime.Supervisor,
|
|
enabled: !ConfigHelper.parse_bool_env_var("DISABLE_REALTIME_INDEXER")
|
|
|
|
config :indexer, Indexer.Block.Catchup.Supervisor, enabled: !ConfigHelper.parse_bool_env_var("DISABLE_CATCHUP_INDEXER")
|
|
|
|
config :indexer, Indexer.Fetcher.ReplacedTransaction.Supervisor,
|
|
disabled?: ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_REPLACED_TRANSACTION_FETCHER")
|
|
|
|
config :indexer, Indexer.Fetcher.TokenInstance.Realtime.Supervisor,
|
|
disabled?: ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_TOKEN_INSTANCE_REALTIME_FETCHER")
|
|
|
|
config :indexer, Indexer.Fetcher.TokenInstance.Retry.Supervisor,
|
|
disabled?: ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_TOKEN_INSTANCE_RETRY_FETCHER")
|
|
|
|
config :indexer, Indexer.Fetcher.TokenInstance.Sanitize.Supervisor,
|
|
disabled?: ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_TOKEN_INSTANCE_SANITIZE_FETCHER")
|
|
|
|
config :indexer, Indexer.Fetcher.TokenInstance.LegacySanitize,
|
|
enabled: !ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_TOKEN_INSTANCE_LEGACY_SANITIZE_FETCHER", "true")
|
|
|
|
config :indexer, Indexer.Fetcher.TokenInstance.SanitizeERC1155,
|
|
enabled: !ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_TOKEN_INSTANCE_ERC_1155_SANITIZE_FETCHER", "false")
|
|
|
|
config :indexer, Indexer.Fetcher.TokenInstance.SanitizeERC721,
|
|
enabled: !ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_TOKEN_INSTANCE_ERC_721_SANITIZE_FETCHER", "false")
|
|
|
|
config :indexer, Indexer.Fetcher.EmptyBlocksSanitizer,
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_EMPTY_BLOCKS_SANITIZER_BATCH_SIZE", 100),
|
|
interval: ConfigHelper.parse_time_env_var("INDEXER_EMPTY_BLOCKS_SANITIZER_INTERVAL", "10s")
|
|
|
|
config :indexer, Indexer.Block.Realtime.Fetcher,
|
|
max_gap: ConfigHelper.parse_integer_env_var("INDEXER_REALTIME_FETCHER_MAX_GAP", 1000)
|
|
|
|
config :indexer, Indexer.Block.Catchup.MissingRangesCollector,
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_CATCHUP_MISSING_RANGES_BATCH_SIZE", 100_000)
|
|
|
|
config :indexer, Indexer.Block.Catchup.Fetcher,
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_CATCHUP_BLOCKS_BATCH_SIZE", 10),
|
|
concurrency: ConfigHelper.parse_integer_env_var("INDEXER_CATCHUP_BLOCKS_CONCURRENCY", 10)
|
|
|
|
config :indexer, Indexer.Fetcher.BlockReward,
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_BLOCK_REWARD_BATCH_SIZE", 10),
|
|
concurrency: ConfigHelper.parse_integer_env_var("INDEXER_BLOCK_REWARD_CONCURRENCY", 4)
|
|
|
|
config :indexer, Indexer.Fetcher.TokenInstance.Helper,
|
|
base_uri_retry?: ConfigHelper.parse_bool_env_var("INDEXER_TOKEN_INSTANCE_USE_BASE_URI_RETRY")
|
|
|
|
config :indexer, Indexer.Fetcher.TokenInstance.Retry,
|
|
concurrency: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_RETRY_CONCURRENCY", 10),
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_RETRY_BATCH_SIZE", 10),
|
|
max_refetch_interval: ConfigHelper.parse_time_env_var("INDEXER_TOKEN_INSTANCE_RETRY_MAX_REFETCH_INTERVAL", "168h"),
|
|
exp_timeout_base: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_RETRY_EXPONENTIAL_TIMEOUT_BASE", 2),
|
|
exp_timeout_coeff: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_RETRY_EXPONENTIAL_TIMEOUT_COEFF", 100)
|
|
|
|
config :indexer, Indexer.Fetcher.TokenInstance.Realtime,
|
|
concurrency: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_REALTIME_CONCURRENCY", 10),
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_REALTIME_BATCH_SIZE", 1),
|
|
retry_with_cooldown?: ConfigHelper.parse_bool_env_var("INDEXER_TOKEN_INSTANCE_REALTIME_RETRY_ENABLED"),
|
|
retry_timeout: ConfigHelper.parse_time_env_var("INDEXER_TOKEN_INSTANCE_REALTIME_RETRY_TIMEOUT", "5s")
|
|
|
|
config :indexer, Indexer.Fetcher.TokenInstance.Sanitize,
|
|
concurrency: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_SANITIZE_CONCURRENCY", 10),
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_SANITIZE_BATCH_SIZE", 10)
|
|
|
|
config :indexer, Indexer.Fetcher.TokenInstance.LegacySanitize,
|
|
concurrency: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_LEGACY_SANITIZE_CONCURRENCY", 2),
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_LEGACY_SANITIZE_BATCH_SIZE", 10)
|
|
|
|
config :indexer, Indexer.Fetcher.TokenInstance.SanitizeERC1155,
|
|
concurrency: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_ERC_1155_SANITIZE_CONCURRENCY", 2),
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_ERC_1155_SANITIZE_BATCH_SIZE", 10)
|
|
|
|
config :indexer, Indexer.Fetcher.TokenInstance.SanitizeERC721,
|
|
concurrency: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_ERC_721_SANITIZE_CONCURRENCY", 2),
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_ERC_721_SANITIZE_BATCH_SIZE", 10),
|
|
tokens_queue_size:
|
|
ConfigHelper.parse_integer_env_var("INDEXER_TOKEN_INSTANCE_ERC_721_SANITIZE_TOKENS_BATCH_SIZE", 100)
|
|
|
|
config :indexer, Indexer.Fetcher.InternalTransaction,
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_INTERNAL_TRANSACTIONS_BATCH_SIZE", 10),
|
|
concurrency: ConfigHelper.parse_integer_env_var("INDEXER_INTERNAL_TRANSACTIONS_CONCURRENCY", 4),
|
|
indexing_finished_threshold:
|
|
ConfigHelper.parse_integer_env_var("API_INTERNAL_TRANSACTIONS_INDEXING_FINISHED_THRESHOLD", 1000)
|
|
|
|
coin_balances_batch_size = ConfigHelper.parse_integer_env_var("INDEXER_COIN_BALANCES_BATCH_SIZE", 100)
|
|
coin_balances_concurrency = ConfigHelper.parse_integer_env_var("INDEXER_COIN_BALANCES_CONCURRENCY", 4)
|
|
|
|
config :indexer, Indexer.Fetcher.CoinBalance.Catchup,
|
|
batch_size: coin_balances_batch_size,
|
|
concurrency: coin_balances_concurrency
|
|
|
|
config :indexer, Indexer.Fetcher.CoinBalance.Realtime,
|
|
batch_size: coin_balances_batch_size,
|
|
concurrency: coin_balances_concurrency
|
|
|
|
config :indexer, Indexer.Fetcher.Optimism.TransactionBatch.Supervisor, enabled: ConfigHelper.chain_type() == :optimism
|
|
config :indexer, Indexer.Fetcher.Optimism.OutputRoot.Supervisor, enabled: ConfigHelper.chain_type() == :optimism
|
|
config :indexer, Indexer.Fetcher.Optimism.DisputeGame.Supervisor, enabled: ConfigHelper.chain_type() == :optimism
|
|
config :indexer, Indexer.Fetcher.Optimism.Deposit.Supervisor, enabled: ConfigHelper.chain_type() == :optimism
|
|
config :indexer, Indexer.Fetcher.Optimism.Withdrawal.Supervisor, enabled: ConfigHelper.chain_type() == :optimism
|
|
config :indexer, Indexer.Fetcher.Optimism.WithdrawalEvent.Supervisor, enabled: ConfigHelper.chain_type() == :optimism
|
|
|
|
config :indexer, Indexer.Fetcher.Optimism,
|
|
optimism_l1_rpc: System.get_env("INDEXER_OPTIMISM_L1_RPC"),
|
|
optimism_l1_system_config: System.get_env("INDEXER_OPTIMISM_L1_SYSTEM_CONFIG_CONTRACT"),
|
|
l1_eth_get_logs_range_size: ConfigHelper.parse_integer_env_var("INDEXER_OPTIMISM_L1_ETH_GET_LOGS_RANGE_SIZE", 250),
|
|
l2_eth_get_logs_range_size: ConfigHelper.parse_integer_env_var("INDEXER_OPTIMISM_L2_ETH_GET_LOGS_RANGE_SIZE", 250),
|
|
block_duration: ConfigHelper.parse_integer_env_var("INDEXER_OPTIMISM_BLOCK_DURATION", 2),
|
|
start_block_l1: ConfigHelper.parse_integer_or_nil_env_var("INDEXER_OPTIMISM_L1_START_BLOCK"),
|
|
portal: System.get_env("INDEXER_OPTIMISM_L1_PORTAL_CONTRACT")
|
|
|
|
config :indexer, Indexer.Fetcher.Optimism.Deposit,
|
|
transaction_type: ConfigHelper.parse_integer_env_var("INDEXER_OPTIMISM_L1_DEPOSITS_TRANSACTION_TYPE", 126)
|
|
|
|
config :indexer, Indexer.Fetcher.Optimism.OutputRoot,
|
|
output_oracle: System.get_env("INDEXER_OPTIMISM_L1_OUTPUT_ORACLE_CONTRACT")
|
|
|
|
config :indexer, Indexer.Fetcher.Optimism.Withdrawal,
|
|
start_block_l2: System.get_env("INDEXER_OPTIMISM_L2_WITHDRAWALS_START_BLOCK", "1"),
|
|
message_passer:
|
|
System.get_env("INDEXER_OPTIMISM_L2_MESSAGE_PASSER_CONTRACT", "0x4200000000000000000000000000000000000016")
|
|
|
|
config :indexer, Indexer.Fetcher.Optimism.TransactionBatch,
|
|
blocks_chunk_size: System.get_env("INDEXER_OPTIMISM_L1_BATCH_BLOCKS_CHUNK_SIZE", "4"),
|
|
eip4844_blobs_api_url: System.get_env("INDEXER_OPTIMISM_L1_BATCH_BLOCKSCOUT_BLOBS_API_URL", ""),
|
|
celestia_blobs_api_url: System.get_env("INDEXER_OPTIMISM_L1_BATCH_CELESTIA_BLOBS_API_URL", ""),
|
|
genesis_block_l2: ConfigHelper.parse_integer_or_nil_env_var("INDEXER_OPTIMISM_L2_BATCH_GENESIS_BLOCK_NUMBER"),
|
|
inbox: System.get_env("INDEXER_OPTIMISM_L1_BATCH_INBOX"),
|
|
submitter: System.get_env("INDEXER_OPTIMISM_L1_BATCH_SUBMITTER")
|
|
|
|
config :indexer, Indexer.Fetcher.Withdrawal.Supervisor,
|
|
disabled?: System.get_env("INDEXER_DISABLE_WITHDRAWALS_FETCHER", "true") == "true"
|
|
|
|
config :indexer, Indexer.Fetcher.Withdrawal, first_block: System.get_env("WITHDRAWALS_FIRST_BLOCK")
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonEdge.Deposit.Supervisor, enabled: ConfigHelper.chain_type() == :polygon_edge
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonEdge.DepositExecute.Supervisor,
|
|
enabled: ConfigHelper.chain_type() == :polygon_edge
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonEdge.Withdrawal.Supervisor, enabled: ConfigHelper.chain_type() == :polygon_edge
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonEdge.WithdrawalExit.Supervisor,
|
|
enabled: ConfigHelper.chain_type() == :polygon_edge
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonEdge,
|
|
polygon_edge_l1_rpc: System.get_env("INDEXER_POLYGON_EDGE_L1_RPC"),
|
|
polygon_edge_eth_get_logs_range_size:
|
|
ConfigHelper.parse_integer_env_var("INDEXER_POLYGON_EDGE_ETH_GET_LOGS_RANGE_SIZE", 1000)
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonEdge.Deposit,
|
|
start_block_l1: System.get_env("INDEXER_POLYGON_EDGE_L1_DEPOSITS_START_BLOCK"),
|
|
state_sender: System.get_env("INDEXER_POLYGON_EDGE_L1_STATE_SENDER_CONTRACT")
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonEdge.DepositExecute,
|
|
start_block_l2: System.get_env("INDEXER_POLYGON_EDGE_L2_DEPOSITS_START_BLOCK"),
|
|
state_receiver: System.get_env("INDEXER_POLYGON_EDGE_L2_STATE_RECEIVER_CONTRACT")
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonEdge.Withdrawal,
|
|
start_block_l2: System.get_env("INDEXER_POLYGON_EDGE_L2_WITHDRAWALS_START_BLOCK"),
|
|
state_sender: System.get_env("INDEXER_POLYGON_EDGE_L2_STATE_SENDER_CONTRACT")
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonEdge.WithdrawalExit,
|
|
start_block_l1: System.get_env("INDEXER_POLYGON_EDGE_L1_WITHDRAWALS_START_BLOCK"),
|
|
exit_helper: System.get_env("INDEXER_POLYGON_EDGE_L1_EXIT_HELPER_CONTRACT")
|
|
|
|
config :indexer, Indexer.Fetcher.ZkSync.TransactionBatch,
|
|
chunk_size: ConfigHelper.parse_integer_env_var("INDEXER_ZKSYNC_BATCHES_CHUNK_SIZE", 50),
|
|
batches_max_range: ConfigHelper.parse_integer_env_var("INDEXER_ZKSYNC_NEW_BATCHES_MAX_RANGE", 50),
|
|
recheck_interval: ConfigHelper.parse_integer_env_var("INDEXER_ZKSYNC_NEW_BATCHES_RECHECK_INTERVAL", 60)
|
|
|
|
config :indexer, Indexer.Fetcher.ZkSync.TransactionBatch.Supervisor,
|
|
enabled: ConfigHelper.parse_bool_env_var("INDEXER_ZKSYNC_BATCHES_ENABLED")
|
|
|
|
config :indexer, Indexer.Fetcher.ZkSync.BatchesStatusTracker,
|
|
zksync_l1_rpc: System.get_env("INDEXER_ZKSYNC_L1_RPC"),
|
|
recheck_interval: ConfigHelper.parse_integer_env_var("INDEXER_ZKSYNC_BATCHES_STATUS_RECHECK_INTERVAL", 60)
|
|
|
|
config :indexer, Indexer.Fetcher.ZkSync.BatchesStatusTracker.Supervisor,
|
|
enabled: ConfigHelper.parse_bool_env_var("INDEXER_ZKSYNC_BATCHES_ENABLED")
|
|
|
|
config :indexer, Indexer.Fetcher.Arbitrum.Messaging,
|
|
arbsys_contract:
|
|
ConfigHelper.safe_get_env("INDEXER_ARBITRUM_ARBSYS_CONTRACT", "0x0000000000000000000000000000000000000064")
|
|
|
|
config :indexer, Indexer.Fetcher.Arbitrum,
|
|
l1_rpc: System.get_env("INDEXER_ARBITRUM_L1_RPC"),
|
|
l1_rpc_chunk_size: ConfigHelper.parse_integer_env_var("INDEXER_ARBITRUM_L1_RPC_CHUNK_SIZE", 20),
|
|
l1_rpc_block_range: ConfigHelper.parse_integer_env_var("INDEXER_ARBITRUM_L1_RPC_HISTORICAL_BLOCKS_RANGE", 1000),
|
|
l1_rollup_address: System.get_env("INDEXER_ARBITRUM_L1_ROLLUP_CONTRACT"),
|
|
l1_rollup_init_block: ConfigHelper.parse_integer_env_var("INDEXER_ARBITRUM_L1_ROLLUP_INIT_BLOCK", 1),
|
|
l1_start_block: ConfigHelper.parse_integer_env_var("INDEXER_ARBITRUM_L1_COMMON_START_BLOCK", 0),
|
|
l1_finalization_threshold: ConfigHelper.parse_integer_env_var("INDEXER_ARBITRUM_L1_FINALIZATION_THRESHOLD", 1000),
|
|
rollup_chunk_size: ConfigHelper.parse_integer_env_var("INDEXER_ARBITRUM_ROLLUP_CHUNK_SIZE", 20)
|
|
|
|
config :indexer, Indexer.Fetcher.Arbitrum.TrackingMessagesOnL1,
|
|
recheck_interval: ConfigHelper.parse_time_env_var("INDEXER_ARBITRUM_TRACKING_MESSAGES_ON_L1_RECHECK_INTERVAL", "20s")
|
|
|
|
config :indexer, Indexer.Fetcher.Arbitrum.TrackingMessagesOnL1.Supervisor,
|
|
enabled: ConfigHelper.parse_bool_env_var("INDEXER_ARBITRUM_BRIDGE_MESSAGES_TRACKING_ENABLED")
|
|
|
|
config :indexer, Indexer.Fetcher.Arbitrum.TrackingBatchesStatuses,
|
|
recheck_interval: ConfigHelper.parse_time_env_var("INDEXER_ARBITRUM_BATCHES_TRACKING_RECHECK_INTERVAL", "20s"),
|
|
track_l1_transaction_finalization:
|
|
ConfigHelper.parse_bool_env_var("INDEXER_ARBITRUM_BATCHES_TRACKING_L1_FINALIZATION_CHECK_ENABLED", "false"),
|
|
messages_to_blocks_shift:
|
|
ConfigHelper.parse_integer_env_var("INDEXER_ARBITRUM_BATCHES_TRACKING_MESSAGES_TO_BLOCKS_SHIFT", 0),
|
|
finalized_confirmations: ConfigHelper.parse_bool_env_var("INDEXER_ARBITRUM_CONFIRMATIONS_TRACKING_FINALIZED", "true"),
|
|
new_batches_limit: ConfigHelper.parse_integer_env_var("INDEXER_ARBITRUM_NEW_BATCHES_LIMIT", 10),
|
|
node_interface_contract:
|
|
ConfigHelper.safe_get_env("INDEXER_ARBITRUM_NODE_INTERFACE_CONTRACT", "0x00000000000000000000000000000000000000C8"),
|
|
missing_batches_range: ConfigHelper.parse_integer_env_var("INDEXER_ARBITRUM_MISSING_BATCHES_RANGE", 10000)
|
|
|
|
config :indexer, Indexer.Fetcher.Arbitrum.TrackingBatchesStatuses.Supervisor,
|
|
enabled: ConfigHelper.parse_bool_env_var("INDEXER_ARBITRUM_BATCHES_TRACKING_ENABLED")
|
|
|
|
config :indexer, Indexer.Fetcher.Arbitrum.RollupMessagesCatchup,
|
|
recheck_interval: ConfigHelper.parse_time_env_var("INDEXER_ARBITRUM_MISSED_MESSAGES_RECHECK_INTERVAL", "1h"),
|
|
missed_messages_blocks_depth:
|
|
ConfigHelper.parse_integer_env_var("INDEXER_ARBITRUM_MISSED_MESSAGES_BLOCKS_DEPTH", 10000)
|
|
|
|
config :indexer, Indexer.Fetcher.Arbitrum.RollupMessagesCatchup.Supervisor,
|
|
enabled: ConfigHelper.parse_bool_env_var("INDEXER_ARBITRUM_BRIDGE_MESSAGES_TRACKING_ENABLED")
|
|
|
|
config :indexer, Indexer.Fetcher.Arbitrum.MessagesToL2Matcher.Supervisor,
|
|
disabled?: not ConfigHelper.parse_bool_env_var("INDEXER_ARBITRUM_BRIDGE_MESSAGES_TRACKING_ENABLED")
|
|
|
|
config :indexer, Indexer.Fetcher.RootstockData.Supervisor,
|
|
disabled?:
|
|
ConfigHelper.chain_type() != :rsk || ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_ROOTSTOCK_DATA_FETCHER")
|
|
|
|
config :indexer, Indexer.Fetcher.RootstockData,
|
|
interval: ConfigHelper.parse_time_env_var("INDEXER_ROOTSTOCK_DATA_FETCHER_INTERVAL", "3s"),
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_ROOTSTOCK_DATA_FETCHER_BATCH_SIZE", 10),
|
|
max_concurrency: ConfigHelper.parse_integer_env_var("INDEXER_ROOTSTOCK_DATA_FETCHER_CONCURRENCY", 5),
|
|
db_batch_size: ConfigHelper.parse_integer_env_var("INDEXER_ROOTSTOCK_DATA_FETCHER_DB_BATCH_SIZE", 300)
|
|
|
|
config :indexer, Indexer.Fetcher.Beacon, beacon_rpc: System.get_env("INDEXER_BEACON_RPC_URL") || "http://localhost:5052"
|
|
|
|
config :indexer, Indexer.Fetcher.Beacon.Blob.Supervisor,
|
|
disabled?:
|
|
ConfigHelper.chain_type() != :ethereum ||
|
|
ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_BEACON_BLOB_FETCHER")
|
|
|
|
config :indexer, Indexer.Fetcher.Beacon.Blob,
|
|
slot_duration: ConfigHelper.parse_integer_env_var("INDEXER_BEACON_BLOB_FETCHER_SLOT_DURATION", 12),
|
|
reference_slot: ConfigHelper.parse_integer_env_var("INDEXER_BEACON_BLOB_FETCHER_REFERENCE_SLOT", 8_000_000),
|
|
reference_timestamp:
|
|
ConfigHelper.parse_integer_env_var("INDEXER_BEACON_BLOB_FETCHER_REFERENCE_TIMESTAMP", 1_702_824_023),
|
|
start_block: ConfigHelper.parse_integer_env_var("INDEXER_BEACON_BLOB_FETCHER_START_BLOCK", 19_200_000),
|
|
end_block: ConfigHelper.parse_integer_env_var("INDEXER_BEACON_BLOB_FETCHER_END_BLOCK", 0)
|
|
|
|
config :indexer, Indexer.Fetcher.Shibarium.L1,
|
|
rpc: System.get_env("INDEXER_SHIBARIUM_L1_RPC"),
|
|
start_block: System.get_env("INDEXER_SHIBARIUM_L1_START_BLOCK"),
|
|
deposit_manager_proxy: System.get_env("INDEXER_SHIBARIUM_L1_DEPOSIT_MANAGER_CONTRACT"),
|
|
ether_predicate_proxy: System.get_env("INDEXER_SHIBARIUM_L1_ETHER_PREDICATE_CONTRACT"),
|
|
erc20_predicate_proxy: System.get_env("INDEXER_SHIBARIUM_L1_ERC20_PREDICATE_CONTRACT"),
|
|
erc721_predicate_proxy: System.get_env("INDEXER_SHIBARIUM_L1_ERC721_PREDICATE_CONTRACT"),
|
|
erc1155_predicate_proxy: System.get_env("INDEXER_SHIBARIUM_L1_ERC1155_PREDICATE_CONTRACT"),
|
|
withdraw_manager_proxy: System.get_env("INDEXER_SHIBARIUM_L1_WITHDRAW_MANAGER_CONTRACT")
|
|
|
|
config :indexer, Indexer.Fetcher.Shibarium.L2,
|
|
start_block: System.get_env("INDEXER_SHIBARIUM_L2_START_BLOCK"),
|
|
child_chain: System.get_env("INDEXER_SHIBARIUM_L2_CHILD_CHAIN_CONTRACT"),
|
|
weth: System.get_env("INDEXER_SHIBARIUM_L2_WETH_CONTRACT"),
|
|
bone_withdraw: System.get_env("INDEXER_SHIBARIUM_L2_BONE_WITHDRAW_CONTRACT")
|
|
|
|
config :indexer, Indexer.Fetcher.Shibarium.L1.Supervisor, enabled: ConfigHelper.chain_type() == :shibarium
|
|
|
|
config :indexer, Indexer.Fetcher.Shibarium.L2.Supervisor, enabled: ConfigHelper.chain_type() == :shibarium
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonZkevm.BridgeL1,
|
|
rpc: System.get_env("INDEXER_POLYGON_ZKEVM_L1_RPC"),
|
|
start_block: System.get_env("INDEXER_POLYGON_ZKEVM_L1_BRIDGE_START_BLOCK"),
|
|
bridge_contract: System.get_env("INDEXER_POLYGON_ZKEVM_L1_BRIDGE_CONTRACT"),
|
|
native_symbol: System.get_env("INDEXER_POLYGON_ZKEVM_L1_BRIDGE_NATIVE_SYMBOL", "ETH"),
|
|
native_decimals: ConfigHelper.parse_integer_env_var("INDEXER_POLYGON_ZKEVM_L1_BRIDGE_NATIVE_DECIMALS", 18),
|
|
rollup_network_id_l1: ConfigHelper.parse_integer_or_nil_env_var("INDEXER_POLYGON_ZKEVM_L1_BRIDGE_NETWORK_ID"),
|
|
rollup_index_l1: ConfigHelper.parse_integer_or_nil_env_var("INDEXER_POLYGON_ZKEVM_L1_BRIDGE_ROLLUP_INDEX")
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonZkevm.BridgeL1.Supervisor, enabled: ConfigHelper.chain_type() == :polygon_zkevm
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonZkevm.BridgeL1Tokens.Supervisor,
|
|
enabled: ConfigHelper.chain_type() == :polygon_zkevm
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonZkevm.BridgeL2,
|
|
start_block: System.get_env("INDEXER_POLYGON_ZKEVM_L2_BRIDGE_START_BLOCK"),
|
|
bridge_contract: System.get_env("INDEXER_POLYGON_ZKEVM_L2_BRIDGE_CONTRACT"),
|
|
rollup_network_id_l2: ConfigHelper.parse_integer_or_nil_env_var("INDEXER_POLYGON_ZKEVM_L2_BRIDGE_NETWORK_ID"),
|
|
rollup_index_l2: ConfigHelper.parse_integer_or_nil_env_var("INDEXER_POLYGON_ZKEVM_L2_BRIDGE_ROLLUP_INDEX")
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonZkevm.BridgeL2.Supervisor, enabled: ConfigHelper.chain_type() == :polygon_zkevm
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonZkevm.TransactionBatch,
|
|
chunk_size: ConfigHelper.parse_integer_env_var("INDEXER_POLYGON_ZKEVM_BATCHES_CHUNK_SIZE", 20),
|
|
recheck_interval: ConfigHelper.parse_integer_env_var("INDEXER_POLYGON_ZKEVM_BATCHES_RECHECK_INTERVAL", 60)
|
|
|
|
config :indexer, Indexer.Fetcher.PolygonZkevm.TransactionBatch.Supervisor,
|
|
enabled:
|
|
ConfigHelper.chain_type() == :polygon_zkevm &&
|
|
ConfigHelper.parse_bool_env_var("INDEXER_POLYGON_ZKEVM_BATCHES_ENABLED")
|
|
|
|
config :indexer, Indexer.Fetcher.Celo.ValidatorGroupVotes,
|
|
batch_size: ConfigHelper.parse_integer_env_var("INDEXER_CELO_VALIDATOR_GROUP_VOTES_BATCH_SIZE", 200_000)
|
|
|
|
config :indexer, Indexer.Fetcher.Celo.ValidatorGroupVotes.Supervisor,
|
|
enabled:
|
|
ConfigHelper.chain_type() == :celo and
|
|
not ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_CELO_VALIDATOR_GROUP_VOTES_FETCHER")
|
|
|
|
celo_epoch_fetchers_enabled? =
|
|
ConfigHelper.chain_type() == :celo and
|
|
not ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_CELO_EPOCH_FETCHER")
|
|
|
|
config :indexer, Indexer.Fetcher.Celo.EpochBlockOperations.Supervisor,
|
|
enabled: celo_epoch_fetchers_enabled?,
|
|
disabled?: not celo_epoch_fetchers_enabled?
|
|
|
|
config :indexer, Indexer.Fetcher.Filecoin.BeryxAPI,
|
|
base_url: ConfigHelper.safe_get_env("BERYX_API_BASE_URL", "https://api.zondax.ch/fil/data/v3/mainnet"),
|
|
api_token: System.get_env("BERYX_API_TOKEN")
|
|
|
|
filecoin_native_address_fetcher_enabled? =
|
|
ConfigHelper.chain_type() == :filecoin and
|
|
not ConfigHelper.parse_bool_env_var("INDEXER_DISABLE_FILECOIN_ADDRESS_INFO_FETCHER")
|
|
|
|
config :indexer, Indexer.Fetcher.Filecoin.AddressInfo.Supervisor,
|
|
enabled: filecoin_native_address_fetcher_enabled?,
|
|
disabled?: not filecoin_native_address_fetcher_enabled?
|
|
|
|
config :indexer, Indexer.Fetcher.Filecoin.AddressInfo,
|
|
concurrency: ConfigHelper.parse_integer_env_var("INDEXER_FILECOIN_ADDRESS_INFO_CONCURRENCY", 1)
|
|
|
|
config :indexer, Indexer.Fetcher.Scroll,
|
|
l1_eth_get_logs_range_size: ConfigHelper.parse_integer_env_var("INDEXER_SCROLL_L1_ETH_GET_LOGS_RANGE_SIZE", 250),
|
|
l2_eth_get_logs_range_size: ConfigHelper.parse_integer_env_var("INDEXER_SCROLL_L2_ETH_GET_LOGS_RANGE_SIZE", 1000),
|
|
rpc: System.get_env("INDEXER_SCROLL_L1_RPC")
|
|
|
|
config :indexer, Indexer.Fetcher.Scroll.L1FeeParam, gas_oracle: System.get_env("INDEXER_SCROLL_L2_GAS_ORACLE_CONTRACT")
|
|
|
|
config :explorer, Explorer.Chain.Scroll.L1FeeParam,
|
|
curie_upgrade_block: ConfigHelper.parse_integer_env_var("SCROLL_L2_CURIE_UPGRADE_BLOCK", 0),
|
|
scalar_init: ConfigHelper.parse_integer_env_var("SCROLL_L1_SCALAR_INIT", 0),
|
|
overhead_init: ConfigHelper.parse_integer_env_var("SCROLL_L1_OVERHEAD_INIT", 0),
|
|
commit_scalar_init: ConfigHelper.parse_integer_env_var("SCROLL_L1_COMMIT_SCALAR_INIT", 0),
|
|
blob_scalar_init: ConfigHelper.parse_integer_env_var("SCROLL_L1_BLOB_SCALAR_INIT", 0),
|
|
l1_base_fee_init: ConfigHelper.parse_integer_env_var("SCROLL_L1_BASE_FEE_INIT", 0),
|
|
l1_blob_base_fee_init: ConfigHelper.parse_integer_env_var("SCROLL_L1_BLOB_BASE_FEE_INIT", 0)
|
|
|
|
config :indexer, Indexer.Fetcher.Scroll.L1FeeParam.Supervisor, disabled?: ConfigHelper.chain_type() != :scroll
|
|
|
|
config :indexer, Indexer.Fetcher.Scroll.BridgeL1,
|
|
messenger_contract: System.get_env("INDEXER_SCROLL_L1_MESSENGER_CONTRACT"),
|
|
start_block: ConfigHelper.parse_integer_or_nil_env_var("INDEXER_SCROLL_L1_MESSENGER_START_BLOCK")
|
|
|
|
config :indexer, Indexer.Fetcher.Scroll.BridgeL2,
|
|
messenger_contract: System.get_env("INDEXER_SCROLL_L2_MESSENGER_CONTRACT"),
|
|
start_block: ConfigHelper.parse_integer_env_var("INDEXER_SCROLL_L2_MESSENGER_START_BLOCK", first_block)
|
|
|
|
config :indexer, Indexer.Fetcher.Scroll.Batch,
|
|
scroll_chain_contract: System.get_env("INDEXER_SCROLL_L1_CHAIN_CONTRACT"),
|
|
start_block: ConfigHelper.parse_integer_or_nil_env_var("INDEXER_SCROLL_L1_BATCH_START_BLOCK")
|
|
|
|
config :indexer, Indexer.Fetcher.Scroll.BridgeL1.Supervisor, disabled?: ConfigHelper.chain_type() != :scroll
|
|
|
|
config :indexer, Indexer.Fetcher.Scroll.BridgeL2.Supervisor, disabled?: ConfigHelper.chain_type() != :scroll
|
|
|
|
config :indexer, Indexer.Fetcher.Scroll.Batch.Supervisor, disabled?: ConfigHelper.chain_type() != :scroll
|
|
|
|
Code.require_file("#{config_env()}.exs", "config/runtime")
|
|
|
|
for config <- "../apps/*/config/runtime/#{config_env()}.exs" |> Path.expand(__DIR__) |> Path.wildcard() do
|
|
Code.require_file("#{config_env()}.exs", Path.dirname(config))
|
|
end
|
|
|