Move parameters configuration to Ansible
This commit is contained in:
parent
e64ba18820
commit
fec2784897
|
@ -13,7 +13,7 @@
|
||||||
- name: Use role in loop
|
- name: Use role in loop
|
||||||
include_role:
|
include_role:
|
||||||
name: main_software
|
name: main_software
|
||||||
loop: "{{ chains.keys() }}"
|
loop: "{{ chain_custom_environment.keys() }}"
|
||||||
loop_control:
|
loop_control:
|
||||||
loop_var: chain
|
loop_var: chain
|
||||||
index_var: index
|
index_var: index
|
||||||
|
|
|
@ -17,12 +17,46 @@ upload_config_to_s3: true
|
||||||
bucket: "poa-terraform-state"
|
bucket: "poa-terraform-state"
|
||||||
|
|
||||||
## All resources will be prefixed with this one
|
## All resources will be prefixed with this one
|
||||||
prefix: "sokol"
|
prefix: "poa"
|
||||||
|
|
||||||
## This variable represents network RPC endpoint:
|
## This variable represents network RPC endpoint:
|
||||||
chains:
|
chain_custom_environment:
|
||||||
core: "http://10.10.10.10:8545"
|
core:
|
||||||
sokol: "https://192.168.0.1:8545"
|
NETWORK: "(POA)" # Name of the organization/community that hosts the chain
|
||||||
|
SUBNETWORK: "Core Network" # Actual name of the particular network
|
||||||
|
NETWORK_ICON: "_network_icon.html" # Either _test_network_icon.html or _network_icon.html, depending on the type of the network (prod/test).
|
||||||
|
LOGO: "/images/blockscout_logo.svg" # Chain logo
|
||||||
|
ETHEREUM_JSONRPC_VARIANT: "parity" # Chain client installed at ETHEREUM_JSONRPC_HTTP_URL
|
||||||
|
ETHEREUM_JSONRPC_HTTP_URL: "http://localhost:8545" # Network RPC endpoint
|
||||||
|
ETHEREUM_JSONRPC_TRACE_URL: "http://localhost:8545" # Network RPC endpoint in trace mode. Can be the same as the previous variable
|
||||||
|
ETHEREUM_JSONRPC_WS_URL: "ws://localhost:8546" # Network RPC endpoint in websocket mode
|
||||||
|
NETWORK_PATH: "/poa/core" # relative URL path, for example: blockscout.com/$NETWORK_PATH
|
||||||
|
SECRET_KEY_BASE: "TPGMvGK0iIwlXBQuQDA5KRqk77VETbEBlG4gAWeb93TvBsYAjvoAvdODMd6ZeguPwf2YTRY3n7uvxXzQP4WayQ==" # Secret key for production assets protection. Use mix phx.gen.secret to generate
|
||||||
|
CHECK_ORIGIN: false # Used to check the origin of requests when the origin header is present
|
||||||
|
PORT: 4000 # Port the application runs on
|
||||||
|
COIN: "POA" # Coin name at the Coinmarketcap, used to display current exchange rate
|
||||||
|
#METADATA_CONTRACT: # Address of metadata smart contract. Used by POA Network to obtain Validators information to display in the UI
|
||||||
|
#VALIDATORS_CONTRACT: #Address of the EMission Fund smart contract
|
||||||
|
SUPPLY_MODULE: false # Used by the xDai Chain to calculate the total supply of the chain
|
||||||
|
SOURCE_MODULE: false # Used to calculate the total supply
|
||||||
|
#DATABASE_URL: # Database URL. Usually generated automatically, but this variable can be used to modify the URL of the databases during the updates.
|
||||||
|
POOL_SIZE: 20 # Defines the number of database connections allowed
|
||||||
|
ECTO_USE_SSL: false # Specifies whether or not to use SSL on Ecto queries
|
||||||
|
#DATADOG_HOST: # Host configuration variable for Datadog integration
|
||||||
|
#DATADOG_PORT: # Port configuration variable for Datadog integration
|
||||||
|
#SPANDEX_BATCH_SIZE: # Spandex and Datadog configuration setting.
|
||||||
|
#SPANDEX_SYNC_THRESHOLD: # Spandex and Datadog configuration setting.
|
||||||
|
HEART_BEAT_TIMEOUT: 30 # Heartbeat is an Erlang monitoring service that will restart BlockScout if it becomes unresponsive. This variables configures the timeout before Blockscout will be restarted.
|
||||||
|
HEART_COMMAND: "sudo systemctl restart explorer.service" # This variable represents a command that is used to restart the service
|
||||||
|
BLOCKSCOUT_VERSION: "v1.3.9" # Added to the footer to signify the current BlockScout version
|
||||||
|
RELEASE_LINK: "https://github.com/poanetwork/blockscout/releases/tag/v1.3.9-beta" # The link to Blockscout release notes in the footer.
|
||||||
|
ELIXIR_VERSION: "v1.8.1" # Elixir version to install on the node before Blockscout deploy
|
||||||
|
BLOCK_TRANSFORMER: "base" # Transformer for blocks: base or clique.
|
||||||
|
GRAPHIQL_TRANSACTION: "0xbc426b4792c48d8ca31ec9786e403866e14e7f3e4d39c7f2852e518fae529ab4" # Random tx hash on the network, used as default for graphiql tx.
|
||||||
|
FIRST_BLOCK: 0 # The block number, where indexing begins from.
|
||||||
|
TXS_COUNT_CACHE_PERIOD: 7200 # Interval in seconds to restart the task, which calculates the total txs count.
|
||||||
|
ADDRESS_WITH_BALANCES_UPDATE_INTERVAL: 1800 #Interval in seconds to restart the task, which calculates addresses with balances
|
||||||
|
LINK_TO_OTHER_EXPLORERS: "false" # If true, links to other explorers are added in the footer
|
||||||
|
|
||||||
## Region. It is recommended to deploy to us-east-1 as some of the other regions fails due to varied reasons
|
## Region. It is recommended to deploy to us-east-1 as some of the other regions fails due to varied reasons
|
||||||
region: "us-east-1"
|
region: "us-east-1"
|
||||||
|
|
|
@ -21,14 +21,3 @@ ps_host: localhost
|
||||||
ps_user: myuser
|
ps_user: myuser
|
||||||
ps_password: mypass
|
ps_password: mypass
|
||||||
ps_db: mydb
|
ps_db: mydb
|
||||||
|
|
||||||
## Custom environment variables that will be exported when testing the Blockscout instance
|
|
||||||
chain_custom_environment:
|
|
||||||
core:
|
|
||||||
METADATA_CONTRACT: 0xE3FfFD154931EB80b2aCE096EC32D6df23661203
|
|
||||||
VALIDATORS_CONTRACT: 0xa105Db0e6671C7B5f4f350ff1Af6460E6C696e71
|
|
||||||
LINK_TO_OTHER_EXPLORERS: false
|
|
||||||
sokol:
|
|
||||||
METADATA_CONTRACT: 0x81c47A798226e1b90A1b4C9dBDd844033B528D06
|
|
||||||
VALIDATORS_CONTRACT: 0x4c6a159659CCcb033F4b2e2Be0C16ACC62b89DDB
|
|
||||||
LINK_TO_OTHER_EXPLORERS: false
|
|
|
@ -21,8 +21,7 @@ db_subnet_cidr: "10.0.1.0/16"
|
||||||
## Internal DNS zone will looks like:
|
## Internal DNS zone will looks like:
|
||||||
dns_zone_name: "poa.internal"
|
dns_zone_name: "poa.internal"
|
||||||
|
|
||||||
## The following settngs are related to SSL of Application Load Balancer that will be deployed to AWS. If use_ssl is set to false, alb_* variables can be omitted
|
## The following settngs are related to SSL of Application Load Balancer that will be deployed to AWS. If ECTO_USE_SSL is set to false, alb_* variables can be omitted
|
||||||
use_ssl: "false"
|
|
||||||
alb_ssl_policy: "ELBSecurityPolicy-2016-08"
|
alb_ssl_policy: "ELBSecurityPolicy-2016-08"
|
||||||
alb_certificate_arn: "arn:aws:acm:us-east-1:290379793816:certificate/6d1bab74-fb46-4244-aab2-832bf519ab24"
|
alb_certificate_arn: "arn:aws:acm:us-east-1:290379793816:certificate/6d1bab74-fb46-4244-aab2-832bf519ab24"
|
||||||
|
|
||||||
|
@ -32,83 +31,10 @@ root_block_size: 120
|
||||||
## Number of connections allowed by EC2 instance
|
## Number of connections allowed by EC2 instance
|
||||||
pool_size: 30
|
pool_size: 30
|
||||||
|
|
||||||
## Secret key of Explorer. Please, generate your own key here. For example, you can use the following command: openssl rand -base64 64 | tr -d '\n'
|
## The following variable represents the elixir version that will be used to run BlockScout instance. Will be used to download the Elixir at the following link: https://github.com/elixir-lang/elixir/releases/download/{{ elixir_version }}/Precompiled.zip
|
||||||
secret_key_base: "TPGMvGK0iIwlXBQuQDA5KRqk77VETbEBlG4gAWeb93TvBsYAjvoAvdODMd6ZeguPwf2YTRY3n7uvxXzQP4WayQ=="
|
elixir_version: "v1.7.4"
|
||||||
|
|
||||||
## New Relic related configs. Usually you want this empty
|
# DB related variables
|
||||||
new_relic_app_name: ""
|
|
||||||
new_relic_license_key: ""
|
|
||||||
|
|
||||||
# Network related variables
|
|
||||||
|
|
||||||
## This variable represents network RPC endpoint in trace mode. Can be the same as the previous variable:
|
|
||||||
chain_trace_endpoint:
|
|
||||||
core: "http://10.10.10.11:8545"
|
|
||||||
sokol: "http://192.168.0.1:8546"
|
|
||||||
|
|
||||||
## This variable represents network RPC endpoint in websocket mode:
|
|
||||||
chain_ws_endpoint:
|
|
||||||
core: "ws://10.10.10.10/ws"
|
|
||||||
sokol: "ws://192.168.0.1/ws"
|
|
||||||
|
|
||||||
## Next variable represents the client that is used to connect to the chain.
|
|
||||||
chain_jsonrpc_variant:
|
|
||||||
core: "parity"
|
|
||||||
sokol: "geth"
|
|
||||||
|
|
||||||
## Place your own logo at apps/block_scout_web/assets/static folder of blockscout repo and specify a relative path here
|
|
||||||
chain_logo:
|
|
||||||
core: "/images/core.svg"
|
|
||||||
sokol: "/images/sokol.svg"
|
|
||||||
|
|
||||||
## The following variables represents a name of the coin that will be shown at blockchain explorer
|
|
||||||
chain_coin:
|
|
||||||
core: "POA"
|
|
||||||
sokol: "POA"
|
|
||||||
|
|
||||||
## Next variable usually represents the name of the organization/community that hosts the chain
|
|
||||||
chain_network:
|
|
||||||
core: "POA Network"
|
|
||||||
sokol: "POA Network"
|
|
||||||
|
|
||||||
## Next variable represents the actual name of the particular network
|
|
||||||
chain_subnetwork:
|
|
||||||
core: "POA Core Network"
|
|
||||||
sokol: "POA Sokol test network"
|
|
||||||
|
|
||||||
## The next variable represent a relative URL path which will be used as an endpoint for defined chain. For example, if we will have our blockscout at blockscout.com domain and place "core" network at "/poa/core", then the resulting endpoint will be blockscout.com/poa/core for this network.
|
|
||||||
chain_network_path:
|
|
||||||
core: "/poa/core"
|
|
||||||
sokol: "/poa/sokol"
|
|
||||||
|
|
||||||
## The following variable maps the chain name to the network navigation icon at apps/block_scout_web/lib/block_scout_web/templates/icons without .eex extension
|
|
||||||
chain_network_icon:
|
|
||||||
core: "_test_network_icon.html"
|
|
||||||
sokol: "_test_network_icon.html"
|
|
||||||
|
|
||||||
## The following variable maps the chain names to random transaction hash on that chain. "chain_graphiql_transaction" is a variable that takes a transaction hash from a network to provide a sample query in the GraphIQL Playground.
|
|
||||||
chain_graphiql_transaction:
|
|
||||||
core: "0xbc426b4792c48d8ca31ec9786e403866e14e7f3e4d39c7f2852e518fae529ab4"
|
|
||||||
sokol: "0xbc426b4792c48d8ca31ec9786e403866e14e7f3e4d39c7f2852e518fae529ab5"
|
|
||||||
|
|
||||||
## A variable required in indexer configuration files. Can be either base or clique. Usually you don't want to change this value unless you know what are you doing.
|
|
||||||
chain_block_transformer:
|
|
||||||
core: "base"
|
|
||||||
sokol: "base"
|
|
||||||
|
|
||||||
## Heartbeat is an Erlang monitoring service that will restart BlockScout if it becomes unresponsive. The following two variables configures the timeout before Blockscout will be restarted and command to restart. Usually you don't want to change these values.
|
|
||||||
chain_heart_beat_timeout:
|
|
||||||
core: 30
|
|
||||||
sokol: 30
|
|
||||||
|
|
||||||
chain_heart_command:
|
|
||||||
core: "systemctl restart explorer.service"
|
|
||||||
sokol: "systemctl restart explorer.service"
|
|
||||||
|
|
||||||
## This value describes a version of Blockscout that will be shown at the footer. You can write any text there you want to see at the footer.
|
|
||||||
chain_blockscout_version:
|
|
||||||
core: "v1.3.7-beta"
|
|
||||||
sokol: "v1.3.7-beta"
|
|
||||||
|
|
||||||
## This value represents the name of the DB that will be created/attached. Must be unique. Will be prefixed with `prefix` variable.
|
## This value represents the name of the DB that will be created/attached. Must be unique. Will be prefixed with `prefix` variable.
|
||||||
chain_db_id:
|
chain_db_id:
|
||||||
|
@ -152,6 +78,3 @@ chain_db_storage_type:
|
||||||
chain_db_version:
|
chain_db_version:
|
||||||
core: "10.5"
|
core: "10.5"
|
||||||
sokol: "10.6"
|
sokol: "10.6"
|
||||||
|
|
||||||
## The following variable represents the elixir version that will be used to run BlockScout instance. Will be used to download the Elixir at the following link: https://github.com/elixir-lang/elixir/releases/download/{{ elixir_version }}/Precompiled.zip
|
|
||||||
elixir_version: "v1.7.4"
|
|
|
@ -1,232 +0,0 @@
|
||||||
resource "aws_ssm_parameter" "elixir_version" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/elixir_version"
|
|
||||||
value = "${var.elixir_version}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "block_transformer" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/block_transformer"
|
|
||||||
value = "${lookup(var.chain_block_transformer,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "new_relic_app_name" {
|
|
||||||
count = "${var.new_relic_app_name == "" ? 0 : length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/new_relic_app_name"
|
|
||||||
value = "${var.new_relic_app_name}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "new_relic_license_key" {
|
|
||||||
count = "${var.new_relic_license_key == "" ? 0 : length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/new_relic_license_key"
|
|
||||||
value = "${var.new_relic_license_key}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "pool_size" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/pool_size"
|
|
||||||
value = "${var.pool_size}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "ecto_use_ssl" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/ecto_use_ssl"
|
|
||||||
value = "false"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "ethereum_jsonrpc_variant" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/ethereum_jsonrpc_variant"
|
|
||||||
value = "${lookup(var.chain_jsonrpc_variant,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
resource "aws_ssm_parameter" "ethereum_url" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/ethereum_jsonrpc_http_url"
|
|
||||||
value = "${element(values(var.chains),count.index)}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "trace_url" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/ethereum_jsonrpc_trace_url"
|
|
||||||
value = "${lookup(var.chain_trace_endpoint,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
resource "aws_ssm_parameter" "ws_url" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/ethereum_jsonrpc_ws_url"
|
|
||||||
value = "${lookup(var.chain_ws_endpoint,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "logo" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/logo"
|
|
||||||
value = "${lookup(var.chain_logo,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "coin" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/coin"
|
|
||||||
value = "${lookup(var.chain_coin,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "network" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/network"
|
|
||||||
value = "${lookup(var.chain_network,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "subnetwork" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/subnetwork"
|
|
||||||
value = "${lookup(var.chain_subnetwork,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "network_path" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/network_path"
|
|
||||||
value = "${lookup(var.chain_network_path,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "network_icon" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/network_icon"
|
|
||||||
value = "${lookup(var.chain_network_icon,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "graphiql_transaction" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/graphiql_transaction"
|
|
||||||
value = "${lookup(var.chain_graphiql_transaction,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "exq_blocks_concurrency" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/exq_blocks_concurrency"
|
|
||||||
value = "1"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "exq_concurrency" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/exq_concurrency"
|
|
||||||
value = "1"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "exq_internal_transactions_concurrency" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/exq_internal_transactions_concurrency"
|
|
||||||
value = "1"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "exq_receipts_concurrency" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/exq_receipts_concurrency"
|
|
||||||
value = "1"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "exq_transactions_concurrency" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/exq_transactions_concurrency"
|
|
||||||
value = "1"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "secret_key_base" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/secret_key_base"
|
|
||||||
value = "${var.secret_key_base}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "port" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/port"
|
|
||||||
value = "4000"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "db_username" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/db_username"
|
|
||||||
value = "${lookup(var.chain_db_username,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "db_password" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/db_password"
|
|
||||||
value = "${lookup(var.chain_db_password,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "db_host" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/db_host"
|
|
||||||
value = "${aws_route53_record.db.*.fqdn[count.index]}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "db_port" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/db_port"
|
|
||||||
value = "${aws_db_instance.default.*.port[count.index]}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
resource "aws_ssm_parameter" "alb_ssl_policy" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/alb_ssl_policy"
|
|
||||||
value = "${var.alb_ssl_policy}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
resource "aws_ssm_parameter" "alb_certificate_arn" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/alb_certificate_arn"
|
|
||||||
value = "${var.alb_certificate_arn}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
resource "aws_ssm_parameter" "heart_beat_timeout" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/heart_beat_timeout"
|
|
||||||
value = "${lookup(var.chain_heart_beat_timeout,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "heart_command" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/heart_command"
|
|
||||||
value = "${lookup(var.chain_heart_command,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "blockscout_version" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/blockscout_version"
|
|
||||||
value = "${lookup(var.chain_blockscout_version,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_ssm_parameter" "db_name" {
|
|
||||||
count = "${length(var.chains)}"
|
|
||||||
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/db_name"
|
|
||||||
value = "${lookup(var.chain_db_name,element(keys(var.chains),count.index))}"
|
|
||||||
type = "String"
|
|
||||||
}
|
|
|
@ -187,9 +187,7 @@ log "Creating pgsql database for $CHAIN"
|
||||||
|
|
||||||
if ! which psql >/dev/null; then
|
if ! which psql >/dev/null; then
|
||||||
log "Installing psql.."
|
log "Installing psql.."
|
||||||
yum install -y https://download.postgresql.org/pub/repos/yum/10/redhat/rhel-7-x86_64/pgdg-redhat10-10-2.noarch.rpm
|
amazon-linux-extras install postgresql10 >"$LOG"
|
||||||
sed -i "s/rhel-\$releasever-\$basearch/rhel-latest-x86_64/g" "/etc/yum.repos.d/pgdg-10-redhat.repo"
|
|
||||||
yum install -y postgresql10 >"$LOG"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if ! which g++ >/dev/null; then
|
if ! which g++ >/dev/null; then
|
||||||
|
|
|
@ -1,3 +1,10 @@
|
||||||
|
resource "aws_ssm_parameter" "db_host" {
|
||||||
|
count = "${length(var.chains)}"
|
||||||
|
name = "/${var.prefix}/${element(keys(var.chains),count.index)}/db_host"
|
||||||
|
value = "${aws_route53_record.db.*.fqdn[count.index]}"
|
||||||
|
type = "String"
|
||||||
|
}
|
||||||
|
|
||||||
resource "aws_db_instance" "default" {
|
resource "aws_db_instance" "default" {
|
||||||
count = "${length(var.chains)}"
|
count = "${length(var.chains)}"
|
||||||
name = "${lookup(var.chain_db_name,element(keys(var.chains),count.index))}"
|
name = "${lookup(var.chain_db_name,element(keys(var.chains),count.index))}"
|
||||||
|
|
|
@ -62,20 +62,27 @@
|
||||||
when: user_answer.user_input|bool == True
|
when: user_answer.user_input|bool == True
|
||||||
ignore_errors: True
|
ignore_errors: True
|
||||||
|
|
||||||
- name: Ensure Terraform resources being provisioned
|
- name: Ensure Terraform resources has been provisioned
|
||||||
shell: "echo yes | {{ terraform_location }} apply"
|
shell: "echo yes | {{ terraform_location }} apply"
|
||||||
args:
|
args:
|
||||||
chdir: "roles/main_infra/files"
|
chdir: "roles/main_infra/files"
|
||||||
when: user_answer.user_input|bool == True
|
when: user_answer.user_input|bool == True
|
||||||
|
|
||||||
- name: Terraform output info into variable
|
- name: Terraform output info into variable
|
||||||
shell: "{{ terraform_location }} output"
|
shell: "{{ terraform_location }} output -json"
|
||||||
register: output
|
register: output
|
||||||
args:
|
args:
|
||||||
chdir: "roles/main_infra/files"
|
chdir: "roles/main_infra/files"
|
||||||
when: user_answer.user_input|bool == True
|
when: user_answer.user_input|bool == True
|
||||||
|
|
||||||
|
- name: Use role in loop
|
||||||
|
include: parameter_store.yml
|
||||||
|
loop: "{{ chain_custom_environment.keys() }}"
|
||||||
|
loop_control:
|
||||||
|
loop_var: chain
|
||||||
|
index_var: index
|
||||||
|
|
||||||
- name: Output info from Terraform
|
- name: Output info from Terraform
|
||||||
debug:
|
debug:
|
||||||
var: output.stdout_lines
|
value: output.stdout_lines.instructions.value
|
||||||
when: user_answer.user_input|bool == True
|
when: user_answer.user_input|bool == True
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
- name: Prepare variables for Parameter Store
|
||||||
|
set_fact:
|
||||||
|
chain_upper_env: "{{ chain_ps_env | combine ({item.key|lower : item.value}) }}"
|
||||||
|
with_dict: "{{ chain_custom_environment[chain] }}"
|
||||||
|
vars:
|
||||||
|
chain_ps_env: {}
|
||||||
|
|
||||||
|
- name: Insert variables in PS
|
||||||
|
aws_ssm_parameter_store:
|
||||||
|
name: "/{{ prefix }}/{{ chain }}/{{ item.key }}"
|
||||||
|
value: "{{ item.value }}"
|
||||||
|
with_dict: "{{ chain_ps_env }}"
|
||||||
|
environment:
|
||||||
|
AWS_ACCESS_KEY_ID: "{{ aws_access_key }}"
|
||||||
|
AWS_SECRET_ACCESS_KEY: "{{ aws_secret_key }}"
|
||||||
|
AWS_REGION: "{{ region }}"
|
|
@ -8,105 +8,34 @@ db_subnet_cidr = "{{ db_subnet_cidr }}"
|
||||||
dns_zone_name = "{{ dns_zone_name }}"
|
dns_zone_name = "{{ dns_zone_name }}"
|
||||||
instance_type = "{{ instance_type }}"
|
instance_type = "{{ instance_type }}"
|
||||||
root_block_size = "{{ root_block_size }}"
|
root_block_size = "{{ root_block_size }}"
|
||||||
pool_size = "{{ pool_size }}"
|
|
||||||
|
|
||||||
alb_ssl_policy = "{{ alb_ssl_policy }}"
|
alb_ssl_policy = "{{ alb_ssl_policy }}"
|
||||||
alb_certificate_arn = "{{ alb_certificate_arn }}"
|
alb_certificate_arn = "{{ alb_certificate_arn }}"
|
||||||
use_ssl = "{{ use_ssl }}"
|
|
||||||
new_relic_app_name = "{{ new_relic_app_name }}"
|
|
||||||
new_relic_license_key = "{{ new_relic_license_key }}"
|
|
||||||
secret_key_base = "{{ secret_key_base }}"
|
|
||||||
elixir_version = "{{ elixir_version }}"
|
elixir_version = "{{ elixir_version }}"
|
||||||
|
|
||||||
chains = {
|
pool_size = {
|
||||||
{% for key, value in chains.iteritems() %}
|
{% for key, value in chain_custom_environment.iteritems() %}
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
{{ key }}={{ value['POOL_SIZE'] }}{% if not loop.last %},{% endif %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
}
|
}
|
||||||
|
|
||||||
chain_trace_endpoint = {
|
secret_key_base = {
|
||||||
{% for key, value in chain_trace_endpoint.iteritems() %}
|
{% for key, value in chain_custom_environment.iteritems() %}
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
{{ key }}={{ value['SECRET_KEY_BASE'] }}{% if not loop.last %},{% endif %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
}
|
}
|
||||||
|
|
||||||
chain_ws_endpoint = {
|
use_ssl = {
|
||||||
{% for key, value in chain_ws_endpoint.iteritems() %}
|
{% for key, value in chain_custom_environment.iteritems() %}
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
{{ key }}={{ value['ECTO_USE_SSL'] }}{% if not loop.last %},{% endif %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
}
|
}
|
||||||
|
|
||||||
chain_jsonrpc_variant = {
|
chains = [
|
||||||
{% for key, value in chain_jsonrpc_variant.iteritems() %}
|
{% for key in chain_custom_environment.iteritems() %}
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
{{ key }}{% if not loop.last %},{% endif %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
}
|
]
|
||||||
|
|
||||||
chain_logo = {
|
|
||||||
{% for key, value in chain_logo.iteritems() %}
|
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
}
|
|
||||||
|
|
||||||
chain_coin = {
|
|
||||||
{% for key, value in chain_coin.iteritems() %}
|
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
}
|
|
||||||
|
|
||||||
chain_network = {
|
|
||||||
{% for key, value in chain_network.iteritems() %}
|
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
}
|
|
||||||
|
|
||||||
chain_subnetwork = {
|
|
||||||
{% for key, value in chain_subnetwork.iteritems() %}
|
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
}
|
|
||||||
|
|
||||||
chain_network_path = {
|
|
||||||
{% for key, value in chain_network_path.iteritems() %}
|
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
}
|
|
||||||
|
|
||||||
chain_network_icon = {
|
|
||||||
{% for key, value in chain_network_icon.iteritems() %}
|
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
}
|
|
||||||
|
|
||||||
chain_graphiql_transaction = {
|
|
||||||
{% for key, value in chain_graphiql_transaction.iteritems() %}
|
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
}
|
|
||||||
|
|
||||||
chain_block_transformer = {
|
|
||||||
{% for key, value in chain_block_transformer.iteritems() %}
|
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
}
|
|
||||||
|
|
||||||
chain_heart_beat_timeout = {
|
|
||||||
{% for key, value in chain_heart_beat_timeout.iteritems() %}
|
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
}
|
|
||||||
|
|
||||||
chain_heart_command = {
|
|
||||||
{% for key, value in chain_heart_command.iteritems() %}
|
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
}
|
|
||||||
|
|
||||||
chain_blockscout_version = {
|
|
||||||
{% for key, value in chain_blockscout_version.iteritems() %}
|
|
||||||
{{ key }} = "{{ value }}"{% if not loop.last %},{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
}
|
|
||||||
|
|
||||||
chain_db_id = {
|
chain_db_id = {
|
||||||
{% for key, value in chain_db_id.iteritems() %}
|
{% for key, value in chain_db_id.iteritems() %}
|
||||||
|
|
|
@ -122,7 +122,7 @@
|
||||||
|
|
||||||
- name: User prompt
|
- name: User prompt
|
||||||
pause:
|
pause:
|
||||||
prompt: "Would you like to remove staging dependencies? [Yes/No] Default: No"
|
prompt: "Would you like to remove staging dependencies? [Yes/No] Default: Yes"
|
||||||
register: user_answer
|
register: user_answer
|
||||||
|
|
||||||
- name: Remove dev dependencies
|
- name: Remove dev dependencies
|
||||||
|
@ -135,7 +135,7 @@
|
||||||
- "blockscout-{{ chain }}/apps/block_scout_web/assets/node_modules/"
|
- "blockscout-{{ chain }}/apps/block_scout_web/assets/node_modules/"
|
||||||
- "blockscout-{{ chain }}/apps/explorer/node_modules/"
|
- "blockscout-{{ chain }}/apps/explorer/node_modules/"
|
||||||
- "blockscout-{{ chain }}/logs/dev/"
|
- "blockscout-{{ chain }}/logs/dev/"
|
||||||
when: user_answer.user_input|bool == true
|
when: user_answer.user_input|default(true)|bool != false
|
||||||
|
|
||||||
- name: Fix bug with favicon
|
- name: Fix bug with favicon
|
||||||
copy:
|
copy:
|
||||||
|
@ -158,28 +158,36 @@
|
||||||
|
|
||||||
- name: User prompt
|
- name: User prompt
|
||||||
pause:
|
pause:
|
||||||
prompt: "Do you want to update the Parameter Store variables? [Yes/No] Default: No"
|
prompt: "Do you want to update the Parameter Store variables? [Yes/No] Default: Yes"
|
||||||
register: user_answer
|
register: user_answer
|
||||||
|
|
||||||
|
- name: Prepare variables for Parameter Store
|
||||||
|
set_fact:
|
||||||
|
chain_lower_env: "{{ chain_lower_env | combine ({item.key|lower : item.value}) }}"
|
||||||
|
with_dict: "{{ chain_upper_env }}"
|
||||||
|
vars:
|
||||||
|
chain_lower_env: {}
|
||||||
|
when: user_answer.user_input|default(true)|bool != false
|
||||||
|
|
||||||
- name: Update chain variables
|
- name: Update chain variables
|
||||||
aws_ssm_parameter_store:
|
aws_ssm_parameter_store:
|
||||||
name: "/{{ prefix }}/{{ chain }}/{{ item.key }}"
|
name: "/{{ prefix }}/{{ chain }}/{{ item.key }}"
|
||||||
value: "{{ item.value }}"
|
value: "{{ item.value }}"
|
||||||
with_dict: "{{ chain_env }}"
|
with_dict: "{{ chain_lower_env }}"
|
||||||
environment:
|
environment:
|
||||||
AWS_ACCESS_KEY_ID: "{{ aws_access_key }}"
|
AWS_ACCESS_KEY_ID: "{{ aws_access_key }}"
|
||||||
AWS_SECRET_ACCESS_KEY: "{{ aws_secret_key }}"
|
AWS_SECRET_ACCESS_KEY: "{{ aws_secret_key }}"
|
||||||
AWS_REGION: "{{ region }}"
|
AWS_REGION: "{{ region }}"
|
||||||
when: user_answer.user_input|bool == true
|
when: user_answer.user_input|default(true)|bool != false
|
||||||
|
|
||||||
- name: User prompt
|
- name: User prompt
|
||||||
pause:
|
pause:
|
||||||
prompt: "Do you want to deploy BlockScout? [Yes/No] Default: No"
|
prompt: "Do you want to deploy BlockScout? [Yes/No] Default: Yes"
|
||||||
register: user_answer
|
register: user_answer
|
||||||
|
|
||||||
- name: Deploy Blockscout
|
- name: Deploy Blockscout
|
||||||
command: "{{ push_output.stdout_lines[1] }} --deployment-group-name {{ prefix }}-explorer-dg{{ index }} --deployment-config-name CodeDeployDefault.OneAtATime --description '{{ chain_env['blockscout_version'] }}'"
|
command: "{{ push_output.stdout_lines[1] }} --deployment-group-name {{ prefix }}-explorer-dg{{ index }} --deployment-config-name CodeDeployDefault.OneAtATime --description '{{ chain_upper_env['BLOCKSCOUT_VERSION'] }}'"
|
||||||
when: user_answer.user_input|bool == true
|
when: user_answer.user_input|default(true)|bool != false
|
||||||
environment:
|
environment:
|
||||||
AWS_ACCESS_KEY_ID: "{{ aws_access_key }}"
|
AWS_ACCESS_KEY_ID: "{{ aws_access_key }}"
|
||||||
AWS_SECRET_ACCESS_KEY: "{{ aws_secret_key }}"
|
AWS_SECRET_ACCESS_KEY: "{{ aws_secret_key }}"
|
||||||
|
|
Loading…
Reference in New Issue