Skip to content

Commit

Permalink
Changed deployment files and secrets to be able to support deployex 0…
Browse files Browse the repository at this point in the history
….2.0
  • Loading branch information
thiagoesteves committed May 22, 2024
1 parent 1fdaa43 commit e9ff6e6
Show file tree
Hide file tree
Showing 8 changed files with 103 additions and 28 deletions.
4 changes: 2 additions & 2 deletions .github/workflows/release.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ jobs:
aws_secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws_region: "sa-east-1"
source: '_build/prod/*.tar.gz'
dest: 's3://${{ secrets.S3_DIST_URL }}/dist/calori/calori-${CALORI_VERSION}.tar.gz'
dest: 's3://calori-${{ secrets.CLOUD_ENV_NAME }}-distribution/dist/calori/calori-${CALORI_VERSION}.tar.gz'

- name: Copy a version file to the s3 version folder
uses: prewk/s3-cp-action@v2
Expand All @@ -63,4 +63,4 @@ jobs:
aws_secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws_region: "sa-east-1"
source: 'current.json'
dest: 's3://${{ secrets.S3_DIST_URL }}/versions/calori/prod/current.json'
dest: 's3://calori-${{ secrets.CLOUD_ENV_NAME }}-distribution/versions/calori/${{ secrets.CLOUD_ENV_NAME }}/current.json'
13 changes: 11 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ Create an SSH key pair named, e. g. `calori-web-ec2` by visiting the [AWS Key Pa
Ensure you have access to the following secrets for storage in AWS Secrets Manager:

- CALORI_SECRET_KEY_BASE
- ERLANG_COOKIE
- CALORI_ERLANG_COOKIE

### 3. CALORI_PHX_HOST Configuration

Expand Down Expand Up @@ -54,7 +54,7 @@ Wait for the environment to be created. Afterward, update the variables in the *
```bash
# Update the secrets
CALORI_SECRET_KEY_BASE=xxxxxxxxxx
ERLANG_COOKIE=xxxxxxxxxx
CALORI_ERLANG_COOKIE=xxxxxxxxxx
```

Additionally, create the TLS certificates for the OTP distribution using the [Deployex app](https://github.com/thiagoesteves/deployex?tab=readme-ov-file#enhancing-otp-distribution-security-with-mtls)
Expand Down Expand Up @@ -170,6 +170,15 @@ sudo ln -s /snap/bin/certbot /usr/bin/certbot
sudo certbot --nginx
```

The Nginx will modify your file and create the certificates. After the installation, check if the content is the same as proposed in the original [nginx file ](devops/terraform/modules/standard-account/cloud-config.tpl) and if not, just edit the content and restart it.

```bash
sudo su
vi /etc/nginx/sites-available/default
# modify and save file
systemctl reload nginx
```

The comands above will modify nginx file for the correct routing. Once it is all set, you need to check if the [runtime.exs](apps/calori/config/runtime.exs) is pointing to the correct SCHEME/HOST/PORT, e. g.:

```elixir
Expand Down
1 change: 1 addition & 0 deletions devops/terraform/environments/prod/main_example.tf_
Original file line number Diff line number Diff line change
Expand Up @@ -9,4 +9,5 @@ module "standard_account" {
source = "../../modules/standard-account"
account_name = "stage"
server_dns = "example.com"
deployex_dns = "deployex.example.com"
}
97 changes: 75 additions & 22 deletions devops/terraform/modules/standard-account/cloud-config.tpl
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ write_files:
echo "Retrieving and saving ......"
aws secretsmanager get-secret-value --secret-id calori-${account_name}-otp-tls-ca | jq -r .SecretString > /usr/local/share/ca-certificates/ca.crt
aws secretsmanager get-secret-value --secret-id calori-${account_name}-otp-tls-key | jq -r .SecretString > /usr/local/share/ca-certificates/deployex.key
aws secretsmanager get-secret-value --secret-id holidex-${account_name}-otp-tls-key | jq -r .SecretString > /usr/local/share/ca-certificates/calori.key
aws secretsmanager get-secret-value --secret-id calori-${account_name}-otp-tls-key | jq -r .SecretString > /usr/local/share/ca-certificates/calori.key
aws secretsmanager get-secret-value --secret-id calori-${account_name}-otp-tls-crt | jq -r .SecretString > /usr/local/share/ca-certificates/deployex.crt
aws secretsmanager get-secret-value --secret-id calori-${account_name}-otp-tls-crt | jq -r .SecretString > /usr/local/share/ca-certificates/calori.crt
echo "[OK]"
Expand Down Expand Up @@ -108,31 +108,81 @@ write_files:
owner: root:root
permissions: "0644"
content: |
upstream phoenix {
server 127.0.0.1:4000 max_fails=5 fail_timeout=60s;
}

server {
server_name ${hostname};
listen 80;
upstream phoenix {
server 127.0.0.1:4000 max_fails=5 fail_timeout=60s;
}

client_max_body_size 30M;
location / {
allow all;
upstream deployex {
server 127.0.0.1:5001 max_fails=5 fail_timeout=60s;
}

# Proxy Headers
proxy_http_version 1.1;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-Cluster-Client-Ip $remote_addr;
server {
listen 80;
server_name calori.com.br deployex.calori.com.br;
# The Important Websocket Bits!
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
if ($host = calori.com.br) {
return 301 https://$host$request_uri;
} # managed by Certbot

proxy_pass http://phoenix;
}
}

if ($host = deployex.calori.com.br) {
return 301 https://$host$request_uri;
} # managed by Certbot

return 404; # managed by Certbot
}

server {
server_name deployex.calori.com.br;
client_max_body_size 30M;
location / {
allow all;
# Proxy Headers
proxy_http_version 1.1;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-Cluster-Client-Ip $remote_addr;
# The Important Websocket Bits!
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_pass http://deployex;
}

ssl_certificate /etc/letsencrypt/live/calori.com.br/fullchain.pem; # managed by Certbot
ssl_certificate_key /etc/letsencrypt/live/calori.com.br/privkey.pem; # managed by Certbot
include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
}

server {
server_name calori.com.br;
client_max_body_size 30M;
location / {
allow all;
# Proxy Headers
proxy_http_version 1.1;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-Cluster-Client-Ip $remote_addr;
# The Important Websocket Bits!
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_pass http://phoenix;
}

ssl_certificate /etc/letsencrypt/live/calori.com.br/fullchain.pem; # managed by Certbot
ssl_certificate_key /etc/letsencrypt/live/calori.com.br/privkey.pem; # managed by Certbot
include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
}
- path: /etc/systemd/system/deployex.service
owner: root:root
permissions: "0644"
Expand All @@ -153,6 +203,9 @@ write_files:
Environment=DEPLOYEX_OTP_TLS_CERT_PATH=/usr/local/share/ca-certificates
Environment=DEPLOYEX_STORAGE_ADAPTER=s3
Environment=DEPLOYEX_MONITORED_APP_NAME=calori
Environment=DEPLOYEX_PHX_SERVER=true
Environment=DEPLOYEX_PHX_HOST=${deployex_hostname}
Environment=DEPLOYEX_PHX_PORT=5001
ExecStart=/opt/deployex/bin/deployex start
StandardOutput=append:/var/log/deployex.log
KillMode=process
Expand Down
1 change: 1 addition & 0 deletions devops/terraform/modules/standard-account/ec2.tf
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,7 @@ data "cloudinit_config" "server_config" {
content_type = "text/cloud-config"
content = templatefile("${path.module}/cloud-config.tpl", {
hostname = "${var.server_dns}"
deployex_hostname = "${var.deployex_dns}"
log_group_name = aws_cloudwatch_log_group.ec2_instance_logs.name
account_name = "${var.account_name}"
aws_region = "${var.aws_region}"
Expand Down
8 changes: 8 additions & 0 deletions devops/terraform/modules/standard-account/secrets.tf
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,13 @@ locals {
}
}

resource "aws_secretsmanager_secret" "deployex_secrets" {
name = "deployex-${var.account_name}-secrets"
description = "All Deployex Secrets"
recovery_window_in_days = 0
tags = local.secret_tag
}

resource "aws_secretsmanager_secret" "calori_secrets" {
name = "calori-${var.account_name}-secrets"
description = "All Calori Secrets"
Expand Down Expand Up @@ -55,6 +62,7 @@ resource "aws_iam_policy" "calori_secrets_manager_policy" {
aws_secretsmanager_secret.calori_otp_tls_ca.arn,
aws_secretsmanager_secret.calori_otp_tls_key.arn,
aws_secretsmanager_secret.calori_otp_tls_crt.arn,
aws_secretsmanager_secret.deployex_secrets.arn,
],
},
],
Expand Down
5 changes: 4 additions & 1 deletion lib/calori_web/components/core_components.ex
Original file line number Diff line number Diff line change
Expand Up @@ -702,7 +702,10 @@ defmodule CaloriWeb.CoreComponents do
end

slot :logo
slot :link, default: [%{__slot__: :link, inner_block: nil, label: "Home", to: "/home"}]
slot(:link, required: true) do
attr :to, :string
attr :label, :string
end

@doc """
Copied/Modified from https://fullstackphoenix.com/tutorials/tailwind-navbar-new-liveview-0-18-components
Expand Down
2 changes: 1 addition & 1 deletion lib/config_provider/aws_secrets_manager.ex
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ defmodule Calori.AwsSecretsManagerProvider do
secrets = fetch_aws_secret_id("calori-#{env}-secrets", request_opts)

secret_key_base = keyword(:secret_key_base, secrets["CALORI_SECRET_KEY_BASE"])
erlang_cookie = secrets["ERLANG_COOKIE"] |> String.to_atom()
erlang_cookie = secrets["CALORI_ERLANG_COOKIE"] |> String.to_atom()

# Config Erlang Cookie if the node exist
node = :erlang.node()
Expand Down

0 comments on commit e9ff6e6

Please sign in to comment.