From 899785ccafd555fc50a1eebc20fe2a9264136d42 Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Fri, 5 Jul 2024 12:21:23 -0700 Subject: [PATCH 01/16] only use root_domain variable for local dev --- README.md | 4 ++-- ansible/deploy.yaml | 1 - ansible/inventory.ini | 1 - ansible/provision.yaml | 1 - etc/start_helper_sidecar.sh | 13 ++++++------- sidecar/cli/cli.py | 30 ++++++++++++------------------ 6 files changed, 20 insertions(+), 30 deletions(-) diff --git a/README.md b/README.md index fb60a85..10ece52 100644 --- a/README.md +++ b/README.md @@ -68,10 +68,10 @@ Once you know these: ### Run draft ``` -draft start-helper-sidecar --identity --root_domain example.com --config_path config +draft start-helper-sidecar --identity --helper_domain helper.example.com --sidecar_domain sidecar.example.com --config_path config ``` -This will start the sidecar in the background. To confirm, visit `example.com/status`. +This will start the sidecar in the background. To confirm, visit `sidecar.example.com/status`. ## Local Dev diff --git a/ansible/deploy.yaml b/ansible/deploy.yaml index 0431743..aba7830 100644 --- a/ansible/deploy.yaml +++ b/ansible/deploy.yaml @@ -23,7 +23,6 @@ source .venv/bin/activate && draft start-helper-sidecar --identity {{ identity }} - --root_domain {{ root_domain }} --helper_domain {{ helper_domain }} --sidecar_domain {{ sidecar_domain }} --config_path {{ ansible_env.HOME }}/draft/config diff --git a/ansible/inventory.ini b/ansible/inventory.ini index b1c1cc7..0667312 100644 --- a/ansible/inventory.ini +++ b/ansible/inventory.ini @@ -5,4 +5,3 @@ ipa-2 identity=2 helper_domain=helper2.ipa-helper.dev sidecar_ ipa-3 identity=3 helper_domain=helper3.ipa-helper.dev sidecar_domain=sidecar3.ipa-helper.dev [myhosts:vars] ansible_python_interpreter=/usr/bin/python3 -root_domain=ipa-helper.dev diff --git a/ansible/provision.yaml b/ansible/provision.yaml index cd7f70e..49500d8 100644 --- a/ansible/provision.yaml +++ b/ansible/provision.yaml @@ -113,7 +113,6 @@ source .venv/bin/activate && draft start-helper-sidecar --identity {{ identity }} - --root_domain {{ root_domain }} --helper_domain {{ helper_domain }} --sidecar_domain {{ sidecar_domain }} --config_path {{ ansible_env.HOME }}/draft/config diff --git a/etc/start_helper_sidecar.sh b/etc/start_helper_sidecar.sh index fcc54af..56f3cd8 100755 --- a/etc/start_helper_sidecar.sh +++ b/etc/start_helper_sidecar.sh @@ -9,11 +9,10 @@ fi config_path=$1 root_path=$2 -root_domain=$3 -helper_domain=$4 -sidecar_domain=$5 -helper_port=$6 -sidecar_port=$7 -identity=$8 +helper_domain=$3 +sidecar_domain=$4 +helper_port=$5 +sidecar_port=$6 +identity=$7 -nohup draft run-helper-sidecar --config_path "$config_path" --root_path "$root_path" --root_domain "$root_domain" --helper_domain "$helper_domain" --sidecar_domain "$sidecar_domain" --helper_port "$helper_port" --sidecar_port "$sidecar_port" --identity "$identity" > .draft/logs/helper_sidecar.log 2>&1 & echo $! > $pid_file +nohup draft run-helper-sidecar --config_path "$config_path" --root_path "$root_path" --helper_domain "$helper_domain" --sidecar_domain "$sidecar_domain" --helper_port "$helper_port" --sidecar_port "$sidecar_port" --identity "$identity" > .draft/logs/helper_sidecar.log 2>&1 & echo $! > $pid_file diff --git a/sidecar/cli/cli.py b/sidecar/cli/cli.py index a9d3850..91dc1c0 100644 --- a/sidecar/cli/cli.py +++ b/sidecar/cli/cli.py @@ -77,14 +77,11 @@ def start_helper_sidecar_command( # pylint: disable=too-many-arguments def start_traefik_command( config_path: Path, - root_domain: str, - helper_domain: str | None, - sidecar_domain: str | None, + helper_domain: str, + sidecar_domain: str, helper_port: int, sidecar_port: int, ): - sidecar_domain = sidecar_domain or f"sidecar.{root_domain}" - helper_domain = helper_domain or f"helper.{root_domain}" env = { **os.environ, "SIDECAR_DOMAIN": sidecar_domain, @@ -136,18 +133,16 @@ def start_traefik_local_command( show_default=True, ) @click.option("--root_path", type=click_pathlib.Path(), default=None) -@click.option("--root_domain", type=str, default="ipa-helper.dev") -@click.option("--helper_domain", type=str, default=None) -@click.option("--sidecar_domain", type=str, default=None) +@click.option("--helper_domain", required=True, type=str) +@click.option("--sidecar_domain", required=True, type=str) @click.option("--helper_port", type=int, default=7430) @click.option("--sidecar_port", type=int, default=17430) @click.option("--identity", required=True, type=int) def run_helper_sidecar( config_path: Path, root_path: Path, - root_domain: str, - helper_domain: str | None, - sidecar_domain: str | None, + helper_domain: str, + sidecar_domain: str, helper_port: int, sidecar_port: int, identity: int, @@ -161,7 +156,6 @@ def run_helper_sidecar( ) traefik_command = start_traefik_command( config_path=config_path, - root_domain=root_domain, helper_domain=helper_domain, sidecar_domain=sidecar_domain, helper_port=helper_port, @@ -179,16 +173,14 @@ def run_helper_sidecar( show_default=True, ) @click.option("--root_path", type=click_pathlib.Path(), default=Path(".")) -@click.option("--root_domain", type=str, default="ipa-helper.dev") -@click.option("--helper_domain", type=str, default="") -@click.option("--sidecar_domain", type=str, default="") +@click.option("--helper_domain", required=True, type=str) +@click.option("--sidecar_domain", required=True, type=str) @click.option("--helper_port", type=int, default=7430) @click.option("--sidecar_port", type=int, default=17430) @click.option("--identity", required=True, type=int) def start_helper_sidecar( config_path: Path, root_path: Path, - root_domain: str, helper_domain: str, sidecar_domain: str, helper_port: int, @@ -205,8 +197,10 @@ def start_helper_sidecar( script_path = root_path / Path("etc/start_helper_sidecar.sh") start_command = Command( - cmd=f"{script_path} {config_path} {root_path} {root_domain} " - f"{helper_domain} {sidecar_domain} {helper_port} {sidecar_port} {identity}", + cmd=( + f"{script_path} {config_path} {root_path} {helper_domain} {sidecar_domain} " + f"{helper_port} {sidecar_port} {identity}" + ), ) start_command.run_blocking_no_output_capture() print("draft helper_sidecar started") From 80c801b596a8f5a42e17a207aa2ec60d4759e6ff Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Fri, 5 Jul 2024 16:10:23 -0700 Subject: [PATCH 02/16] move existing helper deployment scripts into sidecar subdirectory --- README.md | 6 +++--- ansible/{ => sidecar}/deploy.yaml | 0 ansible/{ => sidecar}/inventory.ini | 0 ansible/{ => sidecar}/keygen.yaml | 0 ansible/{ => sidecar}/provision.yaml | 0 ansible/{ => sidecar}/upload_pub_keys.yaml | 0 6 files changed, 3 insertions(+), 3 deletions(-) rename ansible/{ => sidecar}/deploy.yaml (100%) rename ansible/{ => sidecar}/inventory.ini (100%) rename ansible/{ => sidecar}/keygen.yaml (100%) rename ansible/{ => sidecar}/provision.yaml (100%) rename ansible/{ => sidecar}/upload_pub_keys.yaml (100%) diff --git a/README.md b/README.md index 10ece52..beca485 100644 --- a/README.md +++ b/README.md @@ -24,10 +24,10 @@ Host ipa User ec2-user IdentityFile ~/.ssh/ ``` -4. Update the `draft/ansible/inventory.ini` file to only include a single host. (Unless you are running all 4 servers.) -5. Provision your machine: `ansible-playbook -i ansible/inventory.ini ansible/provision.yaml` +4. Update the `draft/ansible/sidecar/inventory.ini` file to only include a single host. (Unless you are running all 4 servers.) +5. Provision your machine: `ansible-playbook -i ansible/sidecar/inventory.ini ansible/sidecar/provision.yaml` -To deploy new changes in draft, run: `ansible-playbook -i ansible/inventory.ini ansible/deploy.yaml` +To deploy new changes in draft, run: `ansible-playbook -i ansible/sidecar/inventory.ini ansible/sidecar/deploy.yaml` ### Generating TLS certs with Let's Encrypt diff --git a/ansible/deploy.yaml b/ansible/sidecar/deploy.yaml similarity index 100% rename from ansible/deploy.yaml rename to ansible/sidecar/deploy.yaml diff --git a/ansible/inventory.ini b/ansible/sidecar/inventory.ini similarity index 100% rename from ansible/inventory.ini rename to ansible/sidecar/inventory.ini diff --git a/ansible/keygen.yaml b/ansible/sidecar/keygen.yaml similarity index 100% rename from ansible/keygen.yaml rename to ansible/sidecar/keygen.yaml diff --git a/ansible/provision.yaml b/ansible/sidecar/provision.yaml similarity index 100% rename from ansible/provision.yaml rename to ansible/sidecar/provision.yaml diff --git a/ansible/upload_pub_keys.yaml b/ansible/sidecar/upload_pub_keys.yaml similarity index 100% rename from ansible/upload_pub_keys.yaml rename to ansible/sidecar/upload_pub_keys.yaml From d45e2d7a1518e64f138ce0bd0869cd80c0613587 Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Fri, 5 Jul 2024 16:13:10 -0700 Subject: [PATCH 03/16] add traefik config for draft frontend server --- server/traefik/dynamic/dynamic.yaml | 14 ++++++++++++++ server/traefik/dynamic/tls.yaml | 4 ++++ server/traefik/traefik.yaml | 9 +++++++++ 3 files changed, 27 insertions(+) create mode 100644 server/traefik/dynamic/dynamic.yaml create mode 100644 server/traefik/dynamic/tls.yaml create mode 100644 server/traefik/traefik.yaml diff --git a/server/traefik/dynamic/dynamic.yaml b/server/traefik/dynamic/dynamic.yaml new file mode 100644 index 0000000..f069739 --- /dev/null +++ b/server/traefik/dynamic/dynamic.yaml @@ -0,0 +1,14 @@ +http: + routers: + draft-router: + entryPoints: + - "web" + - "web-secure" + rule: "Host(`{{ env "DRAFT_DOMAIN"}}`)" + service: "draft-service" + tls: {} + services: + draft-service: + loadBalancer: + servers: + - url: "http://localhost:{{ env "DRAFT_PORT"}}" diff --git a/server/traefik/dynamic/tls.yaml b/server/traefik/dynamic/tls.yaml new file mode 100644 index 0000000..e59cc17 --- /dev/null +++ b/server/traefik/dynamic/tls.yaml @@ -0,0 +1,4 @@ +tls: + certificates: + - certFile: {{ env "CERT_DIR" }}/cert.pem + keyFile: {{ env "CERT_DIR" }}/key.pem diff --git a/server/traefik/traefik.yaml b/server/traefik/traefik.yaml new file mode 100644 index 0000000..12da075 --- /dev/null +++ b/server/traefik/traefik.yaml @@ -0,0 +1,9 @@ +entryPoints: + web: + address: ":80" + web-secure: + address: ":443" + +providers: + file: + directory: "server/traefik/dynamic" From 976f6fec51290744275eb695a07fe23fa1b8cf11 Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Fri, 5 Jul 2024 16:52:12 -0700 Subject: [PATCH 04/16] add ansible deployment for draft frontend --- ansible/draft/deploy.yaml | 49 ++ ansible/draft/inventory.ini | 5 + ansible/draft/provision.yaml | 137 +++++ ansible/sidecar/provision.yaml | 2 +- server/.prettierignore | 2 +- server/package-lock.json | 943 ++++++++++++++++++++++++++++++++- server/package.json | 6 +- server/pm2.json | 10 + 8 files changed, 1124 insertions(+), 30 deletions(-) create mode 100644 ansible/draft/deploy.yaml create mode 100644 ansible/draft/inventory.ini create mode 100644 ansible/draft/provision.yaml create mode 100644 server/pm2.json diff --git a/ansible/draft/deploy.yaml b/ansible/draft/deploy.yaml new file mode 100644 index 0000000..a18d2a2 --- /dev/null +++ b/ansible/draft/deploy.yaml @@ -0,0 +1,49 @@ +- name: Deploy updates to Draft + hosts: all + tasks: + + - name: Pull new commits from GitHub + git: + repo: 'https://github.com/private-attribution/draft.git' + dest: '{{ ansible_env.HOME }}/draft' + update: yes + + - name: Checkout and pull main branch + command: git pull origin main + args: + chdir: '{{ ansible_env.HOME }}/draft' + + - name: Install packages based on package-lock.json via npm + npm: + path: '{{ ansible_env.HOME}}/draft/server' + state: present + ci: true + + - name: Load .env file + shell: > + aws secretsmanager get-secret-value + --secret-id {{ secret_id }} + --region {{ aws_region }} + --query SecretString + --output text | + jq -r 'to_entries|map("\(.key)=\"\(.value|tostring)\"")|.[]' > + .env + args: + chdir: '{{ ansible_env.HOME }}/draft/server' + executable: /bin/bash + + + - name: Rebuild draft website + shell: > + npm run build + args: + chdir: '{{ ansible_env.HOME }}/draft/server' + executable: /bin/bash + + + - name: Restart draft website + shell: > + npm run pm2-restart + args: + chdir: '{{ ansible_env.HOME }}/draft/server' + executable: /bin/bash diff --git a/ansible/draft/inventory.ini b/ansible/draft/inventory.ini new file mode 100644 index 0000000..f2b9d73 --- /dev/null +++ b/ansible/draft/inventory.ini @@ -0,0 +1,5 @@ +[myhosts] +draft-ipa secret_id=prod-draft-env aws_region=us-west-2 + +[myhosts:vars] +ansible_python_interpreter=/usr/bin/python3 diff --git a/ansible/draft/provision.yaml b/ansible/draft/provision.yaml new file mode 100644 index 0000000..8ea3b21 --- /dev/null +++ b/ansible/draft/provision.yaml @@ -0,0 +1,137 @@ +- name: Setup Draft frontend + hosts: all + tasks: + - name: Store HOME directory + debug: + var: ansible_env.HOME + + - name: Check if Node.js is installed + command: node --version + register: node_installed + failed_when: false + changed_when: false + + - name: Install Node.js Package Manager + yum: + name: nodejs + state: latest + become: yes + when: node_installed.rc != 0 + + - name: Check if npm is installed + command: npm --version + register: npm_installed + failed_when: false + changed_when: false + + - name: Install Node.js Package Manager + yum: + name: npm + state: latest + become: yes + when: npm_installed.rc != 0 + + - name: Check if nginx is installed + command: nginx --version + register: nginx_installed + failed_when: false + changed_when: false + + - name: Install nginx + yum: + name: nginx + state: latest + become: yes + when: nginx_installed.rc != 0 + + - name: Check if Git is installed + command: git --version + register: git_installed + failed_when: false + changed_when: false + + - name: Install Git + yum: + name: git + state: latest + become: yes + when: git_installed.rc != 0 + + - name: Clone repository if it doesn't exist + git: + repo: 'https://github.com/private-attribution/draft.git' + dest: '{{ ansible_env.HOME }}/draft' + update: no + + - name: Check if Traefik is installed + command: '{{ ansible_env.HOME }}/draft/traefik version' + register: traefik_installed + failed_when: false + changed_when: false + + - name: Download Traefik + get_url: + url: 'https://github.com/traefik/traefik/releases/download/v2.11.0/traefik_v2.11.0_linux_amd64.tar.gz' + dest: '{{ ansible_env.HOME }}/traefik_v2.11.0_linux_amd64.tar.gz' + checksum: 'sha256:7f31f1cc566bd094f038579fc36e354fd545cf899523eb507c3cfcbbdb8b9552' + when: traefik_installed.rc != 0 + + - name: Ensure extraction directory exists + file: + path: '{{ ansible_env.HOME }}/traefix_extract/' + state: directory + + - name: Extract Traefik + unarchive: + src: '{{ ansible_env.HOME }}/traefik_v2.11.0_linux_amd64.tar.gz' + dest: '{{ ansible_env.HOME }}/traefix_extract/' + remote_src: yes + when: traefik_installed.rc != 0 + + - name: Copy Traefik binary into draft directory + copy: + src: '{{ ansible_env.HOME }}/traefix_extract/traefik' + dest: '{{ ansible_env.HOME }}/draft' + mode: '0775' + remote_src: yes + + - name: Grant CAP_NET_BIND_SERVICE capability to traefik binary + command: 'setcap cap_net_bind_service=+ep {{ ansible_env.HOME }}/draft/traefik' + become: yes + + - name: Create cert directory + file: + path: '{{ ansible_env.HOME }}/cert' + state: directory + + - name: Load cert.pem file + shell: > + aws secretsmanager get-secret-value + --secret-id cert.pem + --region {{ aws_region }} + --query SecretString + --output text > cert.pem + args: + chdir: '{{ ansible_env.HOME }}/cert' + executable: /bin/bash + + + - name: Load key.pem file + shell: > + aws secretsmanager get-secret-value + --secret-id key.pem + --region {{ aws_region }} + --query SecretString + --output text > key.pem + args: + chdir: '{{ ansible_env.HOME }}/cert' + executable: /bin/bash + + - name: start traefik + shell: > + systemd-run --user + --setenv=CERT_DIR={{ ansible_env.HOME }}/cert + --setenv=DRAFT_DOMAIN={{ draft_domain }} + --setenv=DRAFT_PORT={{ draft_port }} + {{ ansible_env.HOME }}/draft/traefik + --config_file={{ ansible_env.HOME }}/draft/server/traefik/traefik.yaml diff --git a/ansible/sidecar/provision.yaml b/ansible/sidecar/provision.yaml index 49500d8..f0e6f6f 100644 --- a/ansible/sidecar/provision.yaml +++ b/ansible/sidecar/provision.yaml @@ -1,7 +1,7 @@ - name: Setup IPA Helper hosts: all tasks: - - name: Print HOME directory + - name: Store HOME directory debug: var: ansible_env.HOME diff --git a/server/.prettierignore b/server/.prettierignore index 478675f..07182c4 100644 --- a/server/.prettierignore +++ b/server/.prettierignore @@ -10,7 +10,7 @@ coverage/* next.config.js tsconfig.json babel.config.js - +traefik/* # Not JS README.md diff --git a/server/package-lock.json b/server/package-lock.json index 908a5f5..313cb51 100644 --- a/server/package-lock.json +++ b/server/package-lock.json @@ -19,6 +19,7 @@ "haikunator": "^2.1.2", "next": "14.1.1", "octokit": "^3.1.2", + "pm2": "^5.4.1", "react": "^18", "react-chartjs-2": "^5.2.0", "react-dom": "^18", @@ -3210,6 +3211,160 @@ "resolved": "https://registry.npmjs.org/@octokit/webhooks-types/-/webhooks-types-7.1.0.tgz", "integrity": "sha512-y92CpG4kFFtBBjni8LHoV12IegJ+KFxLgKRengrVjKmGE5XMeCuGvlfRe75lTRrgXaG6XIWJlFpIDTlkoJsU8w==" }, + "node_modules/@pm2/agent": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/@pm2/agent/-/agent-2.0.4.tgz", + "integrity": "sha512-n7WYvvTJhHLS2oBb1PjOtgLpMhgImOq8sXkPBw6smeg9LJBWZjiEgPKOpR8mn9UJZsB5P3W4V/MyvNnp31LKeA==", + "dependencies": { + "async": "~3.2.0", + "chalk": "~3.0.0", + "dayjs": "~1.8.24", + "debug": "~4.3.1", + "eventemitter2": "~5.0.1", + "fast-json-patch": "^3.0.0-1", + "fclone": "~1.0.11", + "nssocket": "0.6.0", + "pm2-axon": "~4.0.1", + "pm2-axon-rpc": "~0.7.0", + "proxy-agent": "~6.3.0", + "semver": "~7.5.0", + "ws": "~7.5.10" + } + }, + "node_modules/@pm2/agent/node_modules/chalk": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", + "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/@pm2/agent/node_modules/dayjs": { + "version": "1.8.36", + "resolved": "https://registry.npmjs.org/dayjs/-/dayjs-1.8.36.tgz", + "integrity": "sha512-3VmRXEtw7RZKAf+4Tv1Ym9AGeo8r8+CjDi26x+7SYQil1UqtqdaokhzoEJohqlzt0m5kacJSDhJQkG/LWhpRBw==" + }, + "node_modules/@pm2/agent/node_modules/ws": { + "version": "7.5.10", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.10.tgz", + "integrity": "sha512-+dbF1tHwZpXcbOJdVOkzLDxZP1ailvSxM6ZweXTegylPny803bFhA+vqBYw4s31NSAk4S2Qz+AKXK9a4wkdjcQ==", + "engines": { + "node": ">=8.3.0" + }, + "peerDependencies": { + "bufferutil": "^4.0.1", + "utf-8-validate": "^5.0.2" + }, + "peerDependenciesMeta": { + "bufferutil": { + "optional": true + }, + "utf-8-validate": { + "optional": true + } + } + }, + "node_modules/@pm2/io": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/@pm2/io/-/io-6.0.1.tgz", + "integrity": "sha512-KiA+shC6sULQAr9mGZ1pg+6KVW9MF8NpG99x26Lf/082/Qy8qsTCtnJy+HQReW1A9Rdf0C/404cz0RZGZro+IA==", + "dependencies": { + "async": "~2.6.1", + "debug": "~4.3.1", + "eventemitter2": "^6.3.1", + "require-in-the-middle": "^5.0.0", + "semver": "~7.5.4", + "shimmer": "^1.2.0", + "signal-exit": "^3.0.3", + "tslib": "1.9.3" + }, + "engines": { + "node": ">=6.0" + } + }, + "node_modules/@pm2/io/node_modules/async": { + "version": "2.6.4", + "resolved": "https://registry.npmjs.org/async/-/async-2.6.4.tgz", + "integrity": "sha512-mzo5dfJYwAn29PeiJ0zvwTo04zj8HDJj0Mn8TD7sno7q12prdbnasKJHhkm2c1LgrhlJ0teaea8860oxi51mGA==", + "dependencies": { + "lodash": "^4.17.14" + } + }, + "node_modules/@pm2/io/node_modules/eventemitter2": { + "version": "6.4.9", + "resolved": "https://registry.npmjs.org/eventemitter2/-/eventemitter2-6.4.9.tgz", + "integrity": "sha512-JEPTiaOt9f04oa6NOkc4aH+nVp5I3wEjpHbIPqfgCdD5v5bUzy7xQqwcVO2aDQgOWhI28da57HksMrzK9HlRxg==" + }, + "node_modules/@pm2/io/node_modules/signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==" + }, + "node_modules/@pm2/io/node_modules/tslib": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz", + "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==" + }, + "node_modules/@pm2/js-api": { + "version": "0.8.0", + "resolved": "https://registry.npmjs.org/@pm2/js-api/-/js-api-0.8.0.tgz", + "integrity": "sha512-nmWzrA/BQZik3VBz+npRcNIu01kdBhWL0mxKmP1ciF/gTcujPTQqt027N9fc1pK9ERM8RipFhymw7RcmCyOEYA==", + "dependencies": { + "async": "^2.6.3", + "debug": "~4.3.1", + "eventemitter2": "^6.3.1", + "extrareqp2": "^1.0.0", + "ws": "^7.0.0" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/@pm2/js-api/node_modules/async": { + "version": "2.6.4", + "resolved": "https://registry.npmjs.org/async/-/async-2.6.4.tgz", + "integrity": "sha512-mzo5dfJYwAn29PeiJ0zvwTo04zj8HDJj0Mn8TD7sno7q12prdbnasKJHhkm2c1LgrhlJ0teaea8860oxi51mGA==", + "dependencies": { + "lodash": "^4.17.14" + } + }, + "node_modules/@pm2/js-api/node_modules/eventemitter2": { + "version": "6.4.9", + "resolved": "https://registry.npmjs.org/eventemitter2/-/eventemitter2-6.4.9.tgz", + "integrity": "sha512-JEPTiaOt9f04oa6NOkc4aH+nVp5I3wEjpHbIPqfgCdD5v5bUzy7xQqwcVO2aDQgOWhI28da57HksMrzK9HlRxg==" + }, + "node_modules/@pm2/js-api/node_modules/ws": { + "version": "7.5.10", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.10.tgz", + "integrity": "sha512-+dbF1tHwZpXcbOJdVOkzLDxZP1ailvSxM6ZweXTegylPny803bFhA+vqBYw4s31NSAk4S2Qz+AKXK9a4wkdjcQ==", + "engines": { + "node": ">=8.3.0" + }, + "peerDependencies": { + "bufferutil": "^4.0.1", + "utf-8-validate": "^5.0.2" + }, + "peerDependenciesMeta": { + "bufferutil": { + "optional": true + }, + "utf-8-validate": { + "optional": true + } + } + }, + "node_modules/@pm2/pm2-version-check": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/@pm2/pm2-version-check/-/pm2-version-check-1.0.4.tgz", + "integrity": "sha512-SXsM27SGH3yTWKc2fKR4SYNxsmnvuBQ9dd6QHtEWmiZ/VqaOYPAIlS8+vMcn27YLtAEBGvNRSh3TPNvtjZgfqA==", + "dependencies": { + "debug": "^4.3.1" + } + }, "node_modules/@rushstack/eslint-patch": { "version": "1.6.0", "resolved": "https://registry.npmjs.org/@rushstack/eslint-patch/-/eslint-patch-1.6.0.tgz", @@ -3465,6 +3620,11 @@ "node": ">= 10" } }, + "node_modules/@tootallnate/quickjs-emscripten": { + "version": "0.23.0", + "resolved": "https://registry.npmjs.org/@tootallnate/quickjs-emscripten/-/quickjs-emscripten-0.23.0.tgz", + "integrity": "sha512-C5Mc6rdnsaJDjO3UpGW/CQTHtCKaYlScZTly4JIu97Jxo/odCiH0ITnDXSJPTOrEKk/ycSZ0AOgTmkDtkOsvIA==" + }, "node_modules/@tsconfig/node10": { "version": "1.0.11", "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.11.tgz", @@ -3907,9 +4067,9 @@ } }, "node_modules/agent-base": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.0.tgz", - "integrity": "sha512-o/zjMZRhJxny7OyEF+Op8X+efiELC7k7yOjMzgfzVqOzXqkBkWI79YoTdOtsuWd5BWhAGAuOY/Xa6xpiaWXiNg==", + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.1.tgz", + "integrity": "sha512-H0TSyFNDMomMNJQBn8wFV5YC/2eJ+VXECwOadZJT554xP6cODZHPX3H9QMQECxvrgiSOP1pHjy1sMWQVYJOUOA==", "dependencies": { "debug": "^4.3.4" }, @@ -3945,6 +4105,27 @@ "url": "https://github.com/sponsors/epoberezkin" } }, + "node_modules/amp": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/amp/-/amp-0.3.1.tgz", + "integrity": "sha512-OwIuC4yZaRogHKiuU5WlMR5Xk/jAcpPtawWL05Gj8Lvm2F6mwoJt4O/bHI+DHwG79vWd+8OFYM4/BzYqyRd3qw==" + }, + "node_modules/amp-message": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/amp-message/-/amp-message-0.1.2.tgz", + "integrity": "sha512-JqutcFwoU1+jhv7ArgW38bqrE+LQdcRv4NxNw0mp0JHQyB6tXesWRjtYKlDgHRY2o3JE5UTaBGUK8kSWUdxWUg==", + "dependencies": { + "amp": "0.3.1" + } + }, + "node_modules/ansi-colors": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.3.tgz", + "integrity": "sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==", + "engines": { + "node": ">=6" + } + }, "node_modules/ansi-escapes": { "version": "4.3.2", "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", @@ -3984,7 +4165,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, "dependencies": { "color-convert": "^2.0.1" }, @@ -4038,8 +4218,7 @@ "node_modules/argparse": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", - "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", - "dev": true + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==" }, "node_modules/aria-query": { "version": "5.3.0", @@ -4180,12 +4359,28 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/ast-types": { + "version": "0.13.4", + "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.13.4.tgz", + "integrity": "sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w==", + "dependencies": { + "tslib": "^2.0.1" + }, + "engines": { + "node": ">=4" + } + }, "node_modules/ast-types-flow": { "version": "0.0.8", "resolved": "https://registry.npmjs.org/ast-types-flow/-/ast-types-flow-0.0.8.tgz", "integrity": "sha512-OH/2E5Fg20h2aPrbe+QL8JZQFko0YZaF+j4mnQ7BGhfavO7OpSLa8a0y9sBwomHdSbkhTS8TQNayBfnW5DwbvQ==", "dev": true }, + "node_modules/async": { + "version": "3.2.5", + "resolved": "https://registry.npmjs.org/async/-/async-3.2.5.tgz", + "integrity": "sha512-baNZyqaaLhyLVKm/DlvdW051MSgO6b8eVfIezl9E5PqWxFgzLm/wQntEW4zOytVburDEr0JlALEpdOFwvErLsg==" + }, "node_modules/asynciterator.prototype": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/asynciterator.prototype/-/asynciterator.prototype-1.0.0.tgz", @@ -4446,6 +4641,14 @@ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" }, + "node_modules/basic-ftp": { + "version": "5.0.5", + "resolved": "https://registry.npmjs.org/basic-ftp/-/basic-ftp-5.0.5.tgz", + "integrity": "sha512-4Bcg1P8xhUuqcii/S0Z9wiHIrQVPMermM1any+MX5GeGD7faD3/msQUDGLol9wOcz4/jbg/WJnGqoJF6LiBdtg==", + "engines": { + "node": ">=10.0.0" + } + }, "node_modules/bcrypt": { "version": "5.1.1", "resolved": "https://registry.npmjs.org/bcrypt/-/bcrypt-5.1.1.tgz", @@ -4486,6 +4689,22 @@ "node": ">=8" } }, + "node_modules/blessed": { + "version": "0.1.81", + "resolved": "https://registry.npmjs.org/blessed/-/blessed-0.1.81.tgz", + "integrity": "sha512-LoF5gae+hlmfORcG1M5+5XZi4LBmvlXTzwJWzUlPryN/SJdSflZvROM2TwkT0GMpq7oqT48NRd4GS7BiVBc5OQ==", + "bin": { + "blessed": "bin/tput.js" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/bodec": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/bodec/-/bodec-0.1.0.tgz", + "integrity": "sha512-Ylo+MAo5BDUq1KA3f3R/MFhh+g8cnHmo8bz3YPGhI1znrMaf77ol1sfvYJzsw3nTE+Y2GryfDxBaR+AqpAkEHQ==" + }, "node_modules/bottleneck": { "version": "2.19.5", "resolved": "https://registry.npmjs.org/bottleneck/-/bottleneck-2.19.5.tgz", @@ -4565,8 +4784,7 @@ "node_modules/buffer-from": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", - "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", - "dev": true + "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" }, "node_modules/busboy": { "version": "1.6.0", @@ -4663,6 +4881,11 @@ "node": ">=10" } }, + "node_modules/charm": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/charm/-/charm-0.1.2.tgz", + "integrity": "sha512-syedaZ9cPe7r3hoQA9twWYKu5AIyCswN5+szkmPBe9ccdLrj4bYaCnLVPTLd2kgVRc7+zoX4tyPgRnFKCj5YjQ==" + }, "node_modules/chart.js": { "version": "4.4.1", "resolved": "https://registry.npmjs.org/chart.js/-/chart.js-4.4.1.tgz", @@ -4758,6 +4981,29 @@ "node": ">=6" } }, + "node_modules/cli-tableau": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/cli-tableau/-/cli-tableau-2.0.1.tgz", + "integrity": "sha512-he+WTicka9cl0Fg/y+YyxcN6/bfQ/1O3QmgxRXDhABKqLzvoOSM4fMzp39uMyLBulAFuywD2N7UaoQE7WaADxQ==", + "dependencies": { + "chalk": "3.0.0" + }, + "engines": { + "node": ">=8.10.0" + } + }, + "node_modules/cli-tableau/node_modules/chalk": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", + "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=8" + } + }, "node_modules/client-only": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/client-only/-/client-only-0.0.1.tgz", @@ -4813,7 +5059,6 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, "dependencies": { "color-name": "~1.1.4" }, @@ -4824,8 +5069,7 @@ "node_modules/color-name": { "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" }, "node_modules/color-support": { "version": "1.1.3", @@ -4928,6 +5172,11 @@ "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==" }, + "node_modules/croner": { + "version": "4.1.97", + "resolved": "https://registry.npmjs.org/croner/-/croner-4.1.97.tgz", + "integrity": "sha512-/f6gpQuxDaqXu+1kwQYSckUglPaOrHdbIlBAu0YuW8/Cdb45XwXYNUBXg3r/9Mo6n540Kn/smKcZWko5x99KrQ==" + }, "node_modules/cross-spawn": { "version": "7.0.3", "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", @@ -4989,6 +5238,11 @@ "integrity": "sha512-I7K1Uu0MBPzaFKg4nI5Q7Vs2t+3gWWW648spaF+Rg7pI9ds18Ugn+lvg4SHczUdKlHI5LWBXyqfS8+DufyBsgQ==", "dev": true }, + "node_modules/culvert": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/culvert/-/culvert-0.1.2.tgz", + "integrity": "sha512-yi1x3EAWKjQTreYWeSd98431AV+IEE0qoDyOoaHJ7KJ21gv6HtBXHVLX74opVSGqcR8/AbjJBHAHpcOy2bj5Gg==" + }, "node_modules/damerau-levenshtein": { "version": "1.0.8", "resolved": "https://registry.npmjs.org/damerau-levenshtein/-/damerau-levenshtein-1.0.8.tgz", @@ -5051,6 +5305,11 @@ "node": ">=12" } }, + "node_modules/dayjs": { + "version": "1.11.11", + "resolved": "https://registry.npmjs.org/dayjs/-/dayjs-1.11.11.tgz", + "integrity": "sha512-okzr3f11N6WuqYtZSvm+F776mB41wRZMhKP+hc34YdW+KmtYYK9iqvHSwo2k9FEH3fhGXvOPV6yz2IcSrfRUDg==" + }, "node_modules/debug": { "version": "4.3.4", "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", @@ -5133,6 +5392,19 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/degenerator": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/degenerator/-/degenerator-5.0.1.tgz", + "integrity": "sha512-TllpMR/t0M5sqCXfj85i4XaAzxmS5tVA16dqvdkMwGmzI+dXLXnw3J+3Vdv7VKw+ThlTMboK6i9rnZ6Nntj5CQ==", + "dependencies": { + "ast-types": "^0.13.4", + "escodegen": "^2.1.0", + "esprima": "^4.0.1" + }, + "engines": { + "node": ">= 14" + } + }, "node_modules/delayed-stream": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", @@ -5314,6 +5586,17 @@ "node": ">=10.13.0" } }, + "node_modules/enquirer": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", + "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", + "dependencies": { + "ansi-colors": "^4.1.1" + }, + "engines": { + "node": ">=8.6" + } + }, "node_modules/entities": { "version": "4.5.0", "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz", @@ -5463,7 +5746,6 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", - "dev": true, "engines": { "node": ">=10" }, @@ -5475,7 +5757,6 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-2.1.0.tgz", "integrity": "sha512-2NlIDTwUWJN0mRPQOdtQBzbUHvdGY2P1VXSyU83Q3xKxM7WHX2Ql8dKq782Q9TgQUNOLEzEYu9bzLNj1q88I5w==", - "dev": true, "dependencies": { "esprima": "^4.0.1", "estraverse": "^5.2.0", @@ -5880,7 +6161,6 @@ "version": "4.0.1", "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", - "dev": true, "bin": { "esparse": "bin/esparse.js", "esvalidate": "bin/esvalidate.js" @@ -5917,7 +6197,6 @@ "version": "5.3.0", "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", - "dev": true, "engines": { "node": ">=4.0" } @@ -5926,11 +6205,15 @@ "version": "2.0.3", "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", - "dev": true, "engines": { "node": ">=0.10.0" } }, + "node_modules/eventemitter2": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/eventemitter2/-/eventemitter2-5.0.1.tgz", + "integrity": "sha512-5EM1GHXycJBS6mauYAbVKT1cVs7POKWb2NXD4Vyt8dDqeZa7LaDK1/sjtL+Zb0lzTpSNil4596Dyu97hz37QLg==" + }, "node_modules/execa": { "version": "5.1.1", "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", @@ -5985,6 +6268,14 @@ "node": "^14.15.0 || ^16.10.0 || >=18.0.0" } }, + "node_modules/extrareqp2": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/extrareqp2/-/extrareqp2-1.0.0.tgz", + "integrity": "sha512-Gum0g1QYb6wpPJCVypWP3bbIuaibcFiJcpuPM10YSXp/tzqi84x9PJageob+eN4xVRIOto4wjSGNLyMD54D2xA==", + "dependencies": { + "follow-redirects": "^1.14.0" + } + }, "node_modules/fast-decode-uri-component": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/fast-decode-uri-component/-/fast-decode-uri-component-1.0.1.tgz", @@ -6023,6 +6314,11 @@ "node": ">= 6" } }, + "node_modules/fast-json-patch": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/fast-json-patch/-/fast-json-patch-3.1.1.tgz", + "integrity": "sha512-vf6IHUX2SBcA+5/+4883dsIjpBTqmfBjmYiWK1savxQmFk4JfBMLa7ynTYOs1Rolp/T1betJxHiGD3g1Mn8lUQ==" + }, "node_modules/fast-json-stable-stringify": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", @@ -6061,6 +6357,11 @@ "bser": "2.1.1" } }, + "node_modules/fclone": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/fclone/-/fclone-1.0.11.tgz", + "integrity": "sha512-GDqVQezKzRABdeqflsgMr7ktzgF9CyS+p2oe0jJqUY6izSSbhPIQJDpoU4PtGcD7VPM9xh/dVrTu6z1nwgmEGw==" + }, "node_modules/fetch-blob": { "version": "3.2.0", "resolved": "https://registry.npmjs.org/fetch-blob/-/fetch-blob-3.2.0.tgz", @@ -6207,6 +6508,27 @@ "url": "https://github.com/sponsors/rawify" } }, + "node_modules/fs-extra": { + "version": "11.2.0", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-11.2.0.tgz", + "integrity": "sha512-PmDi3uwK5nFuXh7XDTlVnS17xJS7vW36is2+w3xcv8SVxiB4NyATf4ctkVY5bkSjX0Y4nbvZCq1/EjtEyr9ktw==", + "dependencies": { + "graceful-fs": "^4.2.0", + "jsonfile": "^6.0.1", + "universalify": "^2.0.0" + }, + "engines": { + "node": ">=14.14" + } + }, + "node_modules/fs-extra/node_modules/universalify": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", + "integrity": "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==", + "engines": { + "node": ">= 10.0.0" + } + }, "node_modules/fs-minipass": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz", @@ -6389,6 +6711,38 @@ "url": "https://github.com/privatenumber/get-tsconfig?sponsor=1" } }, + "node_modules/get-uri": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/get-uri/-/get-uri-6.0.3.tgz", + "integrity": "sha512-BzUrJBS9EcUb4cFol8r4W3v1cPsSyajLSthNkz5BxbpDcHN5tIrM10E2eNvfnvBn3DaT3DUgx0OpsBKkaOpanw==", + "dependencies": { + "basic-ftp": "^5.0.2", + "data-uri-to-buffer": "^6.0.2", + "debug": "^4.3.4", + "fs-extra": "^11.2.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/get-uri/node_modules/data-uri-to-buffer": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-6.0.2.tgz", + "integrity": "sha512-7hvf7/GW8e86rW0ptuwS3OcBGDjIi6SZva7hCyWC0yYry2cOPmLIjXAUHI6DK2HsnwJd9ifmt57i8eV2n4YNpw==", + "engines": { + "node": ">= 14" + } + }, + "node_modules/git-node-fs": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/git-node-fs/-/git-node-fs-1.0.0.tgz", + "integrity": "sha512-bLQypt14llVXBg0S0u8q8HmU7g9p3ysH+NvVlae5vILuUvs759665HvmR5+wb04KjHyjFcDRxdYb4kyNnluMUQ==" + }, + "node_modules/git-sha1": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/git-sha1/-/git-sha1-0.1.2.tgz", + "integrity": "sha512-2e/nZezdVlyCopOCYHeW0onkbZg7xP1Ad6pndPy1rCygeRykefUS6r7oA5cJRGEFvseiaz5a/qUHFVX1dd6Isg==" + }, "node_modules/glob": { "version": "7.1.7", "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", @@ -6515,7 +6869,6 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, "engines": { "node": ">=8" } @@ -6632,9 +6985,9 @@ } }, "node_modules/https-proxy-agent": { - "version": "7.0.2", - "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-7.0.2.tgz", - "integrity": "sha512-NmLNjm6ucYwtcUmL7JQC1ZQ57LmHP4lT15FQ8D61nak1rO6DH+fz5qNK2Ap5UN4ZapYICE3/0KodcLYSPsPbaA==", + "version": "7.0.5", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-7.0.5.tgz", + "integrity": "sha512-1e4Wqeblerz+tMKPIq2EMGiiWW1dIjZOksyHWSUm1rmuvw/how9hBHZ38lAGj5ID4Ik6EdkOw7NmWPy6LAwalw==", "dependencies": { "agent-base": "^7.0.2", "debug": "4" @@ -6738,6 +7091,11 @@ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" }, + "node_modules/ini": { + "version": "1.3.8", + "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", + "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==" + }, "node_modules/internal-slot": { "version": "1.0.6", "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.6.tgz", @@ -6752,6 +7110,23 @@ "node": ">= 0.4" } }, + "node_modules/ip-address": { + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/ip-address/-/ip-address-9.0.5.tgz", + "integrity": "sha512-zHtQzGojZXTwZTHQqra+ETKd4Sn3vgi7uBmlPoXVWZqYvuKmtI0l/VZTjqGmJY9x88GGOaZ9+G9ES8hC4T4X8g==", + "dependencies": { + "jsbn": "1.1.0", + "sprintf-js": "^1.1.3" + }, + "engines": { + "node": ">= 12" + } + }, + "node_modules/ip-address/node_modules/sprintf-js": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.1.3.tgz", + "integrity": "sha512-Oo+0REFV59/rz3gfJNKQiBlwfHaSESl1pcGyABQsnnIfWOFt6JNj5gCog2U6MLZ//IGYD+nA8nI+mTShREReaA==" + }, "node_modules/is-array-buffer": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.2.tgz", @@ -8107,6 +8482,17 @@ "jiti": "bin/jiti.js" } }, + "node_modules/js-git": { + "version": "0.7.8", + "resolved": "https://registry.npmjs.org/js-git/-/js-git-0.7.8.tgz", + "integrity": "sha512-+E5ZH/HeRnoc/LW0AmAyhU+mNcWBzAKE+30+IDMLSLbbK+Tdt02AdkOKq9u15rlJsDEGFqtgckc8ZM59LhhiUA==", + "dependencies": { + "bodec": "^0.1.0", + "culvert": "^0.1.2", + "git-sha1": "^0.1.2", + "pako": "^0.2.5" + } + }, "node_modules/js-tokens": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", @@ -8116,7 +8502,6 @@ "version": "4.1.0", "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", - "dev": true, "dependencies": { "argparse": "^2.0.1" }, @@ -8124,6 +8509,11 @@ "js-yaml": "bin/js-yaml.js" } }, + "node_modules/jsbn": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-1.1.0.tgz", + "integrity": "sha512-4bYVV3aAMtDTTu4+xsDYa6sy9GyJ69/amsu9sYF2zqjiEoZA5xJi3BrfX3uY+/IekIu7MwdObdbDWpoZdBv3/A==" + }, "node_modules/jsdom": { "version": "20.0.3", "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-20.0.3.tgz", @@ -8281,6 +8671,25 @@ "json5": "lib/cli.js" } }, + "node_modules/jsonfile": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.1.0.tgz", + "integrity": "sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==", + "dependencies": { + "universalify": "^2.0.0" + }, + "optionalDependencies": { + "graceful-fs": "^4.1.6" + } + }, + "node_modules/jsonfile/node_modules/universalify": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", + "integrity": "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==", + "engines": { + "node": ">= 10.0.0" + } + }, "node_modules/jsonwebtoken": { "version": "9.0.2", "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-9.0.2.tgz", @@ -8372,6 +8781,14 @@ "node": ">=0.10" } }, + "node_modules/lazy": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/lazy/-/lazy-1.0.11.tgz", + "integrity": "sha512-Y+CjUfLmIpoUCCRl0ub4smrYtGGr5AOa2AKOaWelGHOGz33X/Y/KizefGqbkwfz44+cnq/+9habclf8vOmu2LA==", + "engines": { + "node": ">=0.2.0" + } + }, "node_modules/leven": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", @@ -8425,8 +8842,7 @@ "node_modules/lodash": { "version": "4.17.21", "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", - "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", - "dev": true + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" }, "node_modules/lodash.debounce": { "version": "4.0.8", @@ -8681,11 +9097,21 @@ "node": ">=10" } }, + "node_modules/module-details-from-path": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/module-details-from-path/-/module-details-from-path-1.0.3.tgz", + "integrity": "sha512-ySViT69/76t8VhE1xXHK6Ch4NcDd26gx0MzKXLO+F7NOtnqH68d9zF94nT8ZWSxXh8ELOERsnJO/sWt1xZYw5A==" + }, "node_modules/ms": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" }, + "node_modules/mute-stream": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", + "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==" + }, "node_modules/mz": { "version": "2.7.0", "resolved": "https://registry.npmjs.org/mz/-/mz-2.7.0.tgz", @@ -8719,6 +9145,49 @@ "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", "dev": true }, + "node_modules/needle": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/needle/-/needle-2.4.0.tgz", + "integrity": "sha512-4Hnwzr3mi5L97hMYeNl8wRW/Onhy4nUKR/lVemJ8gJedxxUyBLm9kkrDColJvoSfwi0jCNhD+xCdOtiGDQiRZg==", + "dependencies": { + "debug": "^3.2.6", + "iconv-lite": "^0.4.4", + "sax": "^1.2.4" + }, + "bin": { + "needle": "bin/needle" + }, + "engines": { + "node": ">= 4.4.x" + } + }, + "node_modules/needle/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/needle/node_modules/iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/netmask": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/netmask/-/netmask-2.0.2.tgz", + "integrity": "sha512-dBpDMdxv9Irdq66304OLfEmQ9tbNRFnFTuZiLo+bD+r332bBmMJ8GBLXklIXXgxd3+v9+KUnZaUR5PJMa75Gsg==", + "engines": { + "node": ">= 0.4.0" + } + }, "node_modules/next": { "version": "14.1.1", "resolved": "https://registry.npmjs.org/next/-/next-14.1.1.tgz", @@ -8905,6 +9374,23 @@ "set-blocking": "^2.0.0" } }, + "node_modules/nssocket": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/nssocket/-/nssocket-0.6.0.tgz", + "integrity": "sha512-a9GSOIql5IqgWJR3F/JXG4KpJTA3Z53Cj0MeMvGpglytB1nxE4PdFNC0jINe27CS7cGivoynwc054EzCcT3M3w==", + "dependencies": { + "eventemitter2": "~0.4.14", + "lazy": "~1.0.11" + }, + "engines": { + "node": ">= 0.10.x" + } + }, + "node_modules/nssocket/node_modules/eventemitter2": { + "version": "0.4.14", + "resolved": "https://registry.npmjs.org/eventemitter2/-/eventemitter2-0.4.14.tgz", + "integrity": "sha512-K7J4xq5xAD5jHsGM5ReWXRTFa3JRGofHiMcVgQ8PRwgWxzjHpMWCIzsmyf60+mh8KLsqYPcjUMa0AC4hd6lPyQ==" + }, "node_modules/nwsapi": { "version": "2.2.10", "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.10.tgz", @@ -9135,6 +9621,53 @@ "node": ">=6" } }, + "node_modules/pac-proxy-agent": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/pac-proxy-agent/-/pac-proxy-agent-7.0.2.tgz", + "integrity": "sha512-BFi3vZnO9X5Qt6NRz7ZOaPja3ic0PhlsmCRYLOpN11+mWBCR6XJDqW5RF3j8jm4WGGQZtBA+bTfxYzeKW73eHg==", + "dependencies": { + "@tootallnate/quickjs-emscripten": "^0.23.0", + "agent-base": "^7.0.2", + "debug": "^4.3.4", + "get-uri": "^6.0.1", + "http-proxy-agent": "^7.0.0", + "https-proxy-agent": "^7.0.5", + "pac-resolver": "^7.0.1", + "socks-proxy-agent": "^8.0.4" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/pac-proxy-agent/node_modules/http-proxy-agent": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.2.tgz", + "integrity": "sha512-T1gkAiYYDWYx3V5Bmyu7HcfcvL7mUrTWiM6yOfa3PIphViJ/gFPbvidQ+veqSOHci/PxBcDabeUNCzpOODJZig==", + "dependencies": { + "agent-base": "^7.1.0", + "debug": "^4.3.4" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/pac-resolver": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/pac-resolver/-/pac-resolver-7.0.1.tgz", + "integrity": "sha512-5NPgf87AT2STgwa2ntRMr45jTKrYBGkVU36yT0ig/n/GMAa3oPqhZfIQ2kMEimReg0+t9kZViDVZ83qfVUlckg==", + "dependencies": { + "degenerator": "^5.0.0", + "netmask": "^2.0.2" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/pako": { + "version": "0.2.9", + "resolved": "https://registry.npmjs.org/pako/-/pako-0.2.9.tgz", + "integrity": "sha512-NUcwaKxUxWrZLpDG+z/xZaCgQITkA/Dv4V/T6bw7VON6l1Xz/VnrBqrYjZQ12TamKHzITTfOEIYUj48y2KXImA==" + }, "node_modules/parent-module": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", @@ -9233,6 +9766,17 @@ "url": "https://github.com/sponsors/jonschlinkert" } }, + "node_modules/pidusage": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/pidusage/-/pidusage-3.0.2.tgz", + "integrity": "sha512-g0VU+y08pKw5M8EZ2rIGiEBaB8wrQMjYGFfW2QVIfyT8V+fq8YFLkvlz4bz5ljvFDJYNFCWT3PWqcRr2FKO81w==", + "dependencies": { + "safe-buffer": "^5.2.1" + }, + "engines": { + "node": ">=10" + } + }, "node_modules/pify": { "version": "2.3.0", "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", @@ -9313,6 +9857,155 @@ "node": ">=8" } }, + "node_modules/pm2": { + "version": "5.4.1", + "resolved": "https://registry.npmjs.org/pm2/-/pm2-5.4.1.tgz", + "integrity": "sha512-y9ndADjy78XfzdbVHISn4WiUTrcvmsO7ieCtM/oC80rwPgBDg+bHkkz1e4eaLOW5a7sJsnDfQjJe4AqxNnIw5Q==", + "dependencies": { + "@pm2/agent": "~2.0.0", + "@pm2/io": "~6.0.0", + "@pm2/js-api": "~0.8.0", + "@pm2/pm2-version-check": "latest", + "async": "~3.2.0", + "blessed": "0.1.81", + "chalk": "3.0.0", + "chokidar": "^3.5.3", + "cli-tableau": "^2.0.0", + "commander": "2.15.1", + "croner": "~4.1.92", + "dayjs": "~1.11.5", + "debug": "^4.3.1", + "enquirer": "2.3.6", + "eventemitter2": "5.0.1", + "fclone": "1.0.11", + "js-yaml": "~4.1.0", + "mkdirp": "1.0.4", + "needle": "2.4.0", + "pidusage": "~3.0", + "pm2-axon": "~4.0.1", + "pm2-axon-rpc": "~0.7.1", + "pm2-deploy": "~1.0.2", + "pm2-multimeter": "^0.1.2", + "promptly": "^2", + "semver": "^7.2", + "source-map-support": "0.5.21", + "sprintf-js": "1.1.2", + "vizion": "~2.2.1" + }, + "bin": { + "pm2": "bin/pm2", + "pm2-dev": "bin/pm2-dev", + "pm2-docker": "bin/pm2-docker", + "pm2-runtime": "bin/pm2-runtime" + }, + "engines": { + "node": ">=12.0.0" + }, + "optionalDependencies": { + "pm2-sysmonit": "^1.2.8" + } + }, + "node_modules/pm2-axon": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pm2-axon/-/pm2-axon-4.0.1.tgz", + "integrity": "sha512-kES/PeSLS8orT8dR5jMlNl+Yu4Ty3nbvZRmaAtROuVm9nYYGiaoXqqKQqQYzWQzMYWUKHMQTvBlirjE5GIIxqg==", + "dependencies": { + "amp": "~0.3.1", + "amp-message": "~0.1.1", + "debug": "^4.3.1", + "escape-string-regexp": "^4.0.0" + }, + "engines": { + "node": ">=5" + } + }, + "node_modules/pm2-axon-rpc": { + "version": "0.7.1", + "resolved": "https://registry.npmjs.org/pm2-axon-rpc/-/pm2-axon-rpc-0.7.1.tgz", + "integrity": "sha512-FbLvW60w+vEyvMjP/xom2UPhUN/2bVpdtLfKJeYM3gwzYhoTEEChCOICfFzxkxuoEleOlnpjie+n1nue91bDQw==", + "dependencies": { + "debug": "^4.3.1" + }, + "engines": { + "node": ">=5" + } + }, + "node_modules/pm2-deploy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/pm2-deploy/-/pm2-deploy-1.0.2.tgz", + "integrity": "sha512-YJx6RXKrVrWaphEYf++EdOOx9EH18vM8RSZN/P1Y+NokTKqYAca/ejXwVLyiEpNju4HPZEk3Y2uZouwMqUlcgg==", + "dependencies": { + "run-series": "^1.1.8", + "tv4": "^1.3.0" + }, + "engines": { + "node": ">=4.0.0" + } + }, + "node_modules/pm2-multimeter": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/pm2-multimeter/-/pm2-multimeter-0.1.2.tgz", + "integrity": "sha512-S+wT6XfyKfd7SJIBqRgOctGxaBzUOmVQzTAS+cg04TsEUObJVreha7lvCfX8zzGVr871XwCSnHUU7DQQ5xEsfA==", + "dependencies": { + "charm": "~0.1.1" + } + }, + "node_modules/pm2-sysmonit": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/pm2-sysmonit/-/pm2-sysmonit-1.2.8.tgz", + "integrity": "sha512-ACOhlONEXdCTVwKieBIQLSi2tQZ8eKinhcr9JpZSUAL8Qy0ajIgRtsLxG/lwPOW3JEKqPyw/UaHmTWhUzpP4kA==", + "optional": true, + "dependencies": { + "async": "^3.2.0", + "debug": "^4.3.1", + "pidusage": "^2.0.21", + "systeminformation": "^5.7", + "tx2": "~1.0.4" + } + }, + "node_modules/pm2-sysmonit/node_modules/pidusage": { + "version": "2.0.21", + "resolved": "https://registry.npmjs.org/pidusage/-/pidusage-2.0.21.tgz", + "integrity": "sha512-cv3xAQos+pugVX+BfXpHsbyz/dLzX+lr44zNMsYiGxUw+kV5sgQCIcLd1z+0vq+KyC7dJ+/ts2PsfgWfSC3WXA==", + "optional": true, + "dependencies": { + "safe-buffer": "^5.2.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/pm2/node_modules/chalk": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", + "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/pm2/node_modules/commander": { + "version": "2.15.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.15.1.tgz", + "integrity": "sha512-VlfT9F3V0v+jr4yxPc5gg9s62/fIVWsd2Bk2iD435um1NlGMYdVCq+MjcXnhYq2icNOizHr1kK+5TI6H0Hy0ag==" + }, + "node_modules/pm2/node_modules/source-map-support": { + "version": "0.5.21", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", + "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", + "dependencies": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + } + }, + "node_modules/pm2/node_modules/sprintf-js": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.1.2.tgz", + "integrity": "sha512-VE0SOVEHCk7Qc8ulkWw3ntAzXuqf7S2lvwQaDLRnUeIEaKNQJzV6BwmLKhOqT61aGhfUMrXeaBk+oDGCzvhcug==" + }, "node_modules/postcss": { "version": "8.4.31", "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.31.tgz", @@ -9510,6 +10203,14 @@ "dev": true, "peer": true }, + "node_modules/promptly": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/promptly/-/promptly-2.2.0.tgz", + "integrity": "sha512-aC9j+BZsRSSzEsXBNBwDnAxujdx19HycZoKgRgzWnS8eOHg1asuf9heuLprfbe739zY3IdUQx+Egv6Jn135WHA==", + "dependencies": { + "read": "^1.0.4" + } + }, "node_modules/prompts": { "version": "2.4.2", "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", @@ -9534,6 +10235,44 @@ "react-is": "^16.13.1" } }, + "node_modules/proxy-agent": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/proxy-agent/-/proxy-agent-6.3.1.tgz", + "integrity": "sha512-Rb5RVBy1iyqOtNl15Cw/llpeLH8bsb37gM1FUfKQ+Wck6xHlbAhWGUFiTRHtkjqGTA5pSHz6+0hrPW/oECihPQ==", + "dependencies": { + "agent-base": "^7.0.2", + "debug": "^4.3.4", + "http-proxy-agent": "^7.0.0", + "https-proxy-agent": "^7.0.2", + "lru-cache": "^7.14.1", + "pac-proxy-agent": "^7.0.1", + "proxy-from-env": "^1.1.0", + "socks-proxy-agent": "^8.0.2" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/proxy-agent/node_modules/http-proxy-agent": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.2.tgz", + "integrity": "sha512-T1gkAiYYDWYx3V5Bmyu7HcfcvL7mUrTWiM6yOfa3PIphViJ/gFPbvidQ+veqSOHci/PxBcDabeUNCzpOODJZig==", + "dependencies": { + "agent-base": "^7.1.0", + "debug": "^4.3.4" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/proxy-agent/node_modules/lru-cache": { + "version": "7.18.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-7.18.3.tgz", + "integrity": "sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA==", + "engines": { + "node": ">=12" + } + }, "node_modules/proxy-from-env": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", @@ -9653,6 +10392,17 @@ "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", "dev": true }, + "node_modules/read": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/read/-/read-1.0.7.tgz", + "integrity": "sha512-rSOKNYUmaxy0om1BNjMN4ezNT6VKK+2xF4GBhc81mkH7L60i6dp8qPYrkndNLT3QPphoII3maL9PVC9XmhHwVQ==", + "dependencies": { + "mute-stream": "~0.0.4" + }, + "engines": { + "node": ">=0.8" + } + }, "node_modules/read-cache": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/read-cache/-/read-cache-1.0.0.tgz", @@ -9823,6 +10573,19 @@ "node": ">=0.10.0" } }, + "node_modules/require-in-the-middle": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/require-in-the-middle/-/require-in-the-middle-5.2.0.tgz", + "integrity": "sha512-efCx3b+0Z69/LGJmm9Yvi4cqEdxnoGnxYxGxBghkkTTFeXRtTCmmhO0AnAfHz59k957uTSuy8WaHqOs8wbYUWg==", + "dependencies": { + "debug": "^4.1.1", + "module-details-from-path": "^1.0.3", + "resolve": "^1.22.1" + }, + "engines": { + "node": ">=6" + } + }, "node_modules/requires-port": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", @@ -9938,6 +10701,25 @@ "queue-microtask": "^1.2.2" } }, + "node_modules/run-series": { + "version": "1.1.9", + "resolved": "https://registry.npmjs.org/run-series/-/run-series-1.1.9.tgz", + "integrity": "sha512-Arc4hUN896vjkqCYrUXquBFtRZdv1PfLbTYP71efP6butxyQ0kWpiNJyAgsxscmQg1cqvHY32/UCBzXedTpU2g==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, "node_modules/safe-array-concat": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.0.1.tgz", @@ -9992,8 +10774,12 @@ "node_modules/safer-buffer": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", - "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", - "dev": true + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" + }, + "node_modules/sax": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.4.1.tgz", + "integrity": "sha512-+aWOz7yVScEGoKNd4PA10LZ8sk0A/z5+nXQG5giUO5rprX9jgYsTdov9qCchZiPIZezbZH+jRut8nPodFAX4Jg==" }, "node_modules/saxes": { "version": "6.0.0", @@ -10084,6 +10870,11 @@ "node": ">=8" } }, + "node_modules/shimmer": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/shimmer/-/shimmer-1.2.1.tgz", + "integrity": "sha512-sQTKC1Re/rM6XyFM6fIAGHRPVGvyXfgzIDvzoq608vM+jeyVD0Tu1E6Np0Kc2zAIFWIj963V2800iF/9LPieQw==" + }, "node_modules/side-channel": { "version": "1.0.4", "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", @@ -10124,11 +10915,45 @@ "node": ">=8" } }, + "node_modules/smart-buffer": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", + "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==", + "engines": { + "node": ">= 6.0.0", + "npm": ">= 3.0.0" + } + }, + "node_modules/socks": { + "version": "2.8.3", + "resolved": "https://registry.npmjs.org/socks/-/socks-2.8.3.tgz", + "integrity": "sha512-l5x7VUUWbjVFbafGLxPWkYsHIhEvmF85tbIeFZWc8ZPtoMyybuEhL7Jye/ooC4/d48FgOjSJXgsF/AJPYCW8Zw==", + "dependencies": { + "ip-address": "^9.0.5", + "smart-buffer": "^4.2.0" + }, + "engines": { + "node": ">= 10.0.0", + "npm": ">= 3.0.0" + } + }, + "node_modules/socks-proxy-agent": { + "version": "8.0.4", + "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-8.0.4.tgz", + "integrity": "sha512-GNAq/eg8Udq2x0eNiFkr9gRg5bA7PXEWagQdeRX4cPSG+X/8V38v637gim9bjFptMk1QWsCTr0ttrJEiXbNnRw==", + "dependencies": { + "agent-base": "^7.1.1", + "debug": "^4.3.4", + "socks": "^2.8.3" + }, + "engines": { + "node": ">= 14" + } + }, "node_modules/source-map": { "version": "0.6.1", "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, "engines": { "node": ">=0.10.0" } @@ -10432,7 +11257,6 @@ "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, "dependencies": { "has-flag": "^4.0.0" }, @@ -10457,6 +11281,32 @@ "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==", "dev": true }, + "node_modules/systeminformation": { + "version": "5.22.11", + "resolved": "https://registry.npmjs.org/systeminformation/-/systeminformation-5.22.11.tgz", + "integrity": "sha512-aLws5yi4KCHTb0BVvbodQY5bY8eW4asMRDTxTW46hqw9lGjACX6TlLdJrkdoHYRB0qs+MekqEq1zG7WDnWE8Ug==", + "optional": true, + "os": [ + "darwin", + "linux", + "win32", + "freebsd", + "openbsd", + "netbsd", + "sunos", + "android" + ], + "bin": { + "systeminformation": "lib/cli.js" + }, + "engines": { + "node": ">=8.0.0" + }, + "funding": { + "type": "Buy me a coffee", + "url": "https://www.buymeacoffee.com/systeminfo" + } + }, "node_modules/tailwindcss": { "version": "3.4.4", "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-3.4.4.tgz", @@ -10684,6 +11534,23 @@ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==" }, + "node_modules/tv4": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/tv4/-/tv4-1.3.0.tgz", + "integrity": "sha512-afizzfpJgvPr+eDkREK4MxJ/+r8nEEHcmitwgnPUqpaP+FpwQyadnxNoSACbgc/b1LsZYtODGoPiFxQrgJgjvw==", + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/tx2": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/tx2/-/tx2-1.0.5.tgz", + "integrity": "sha512-sJ24w0y03Md/bxzK4FU8J8JveYYUbSs2FViLJ2D/8bytSiyPRbuE3DyL/9UKYXTZlV3yXq0L8GLlhobTnekCVg==", + "optional": true, + "dependencies": { + "json-stringify-safe": "^5.0.1" + } + }, "node_modules/type-check": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", @@ -10956,6 +11823,28 @@ "node": ">=10.12.0" } }, + "node_modules/vizion": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/vizion/-/vizion-2.2.1.tgz", + "integrity": "sha512-sfAcO2yeSU0CSPFI/DmZp3FsFE9T+8913nv1xWBOyzODv13fwkn6Vl7HqxGpkr9F608M+8SuFId3s+BlZqfXww==", + "dependencies": { + "async": "^2.6.3", + "git-node-fs": "^1.0.0", + "ini": "^1.3.5", + "js-git": "^0.7.8" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/vizion/node_modules/async": { + "version": "2.6.4", + "resolved": "https://registry.npmjs.org/async/-/async-2.6.4.tgz", + "integrity": "sha512-mzo5dfJYwAn29PeiJ0zvwTo04zj8HDJj0Mn8TD7sno7q12prdbnasKJHhkm2c1LgrhlJ0teaea8860oxi51mGA==", + "dependencies": { + "lodash": "^4.17.14" + } + }, "node_modules/w3c-xmlserializer": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-4.0.0.tgz", diff --git a/server/package.json b/server/package.json index 60e74c1..7b5aeed 100644 --- a/server/package.json +++ b/server/package.json @@ -9,7 +9,10 @@ "lint": "next lint --max-warnings 0", "lint:fix": "next lint --fix", "//": "run in band to avoid db overlap. not ideal but works for now", - "test": "jest --runInBand" + "test": "jest --runInBand", + "pm2-start": "pm2 start pm2.json", + "pm2-restart": "pm2 restart pm2.json", + "pm2-stop": "pm2 stop pm2.json" }, "dependencies": { "@headlessui/react": "^1.7.17", @@ -23,6 +26,7 @@ "haikunator": "^2.1.2", "next": "14.1.1", "octokit": "^3.1.2", + "pm2": "^5.4.1", "react": "^18", "react-chartjs-2": "^5.2.0", "react-dom": "^18", diff --git a/server/pm2.json b/server/pm2.json new file mode 100644 index 0000000..fed0e2e --- /dev/null +++ b/server/pm2.json @@ -0,0 +1,10 @@ +{ + "apps": [ + { + "name": "draft-website", + "script": "node_modules/next/dist/bin/next", + "args": "dev", + "cwd": "./" + } + ] +} From d4635ae50a706b34aaa8e147e1267c024f0b9e8e Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Fri, 5 Jul 2024 17:09:05 -0700 Subject: [PATCH 05/16] move ansible directory as subdirectory of server and sidecar directories --- README.md | 6 +++--- {ansible/draft => server/ansible}/deploy.yaml | 0 {ansible/draft => server/ansible}/inventory.ini | 0 {ansible/draft => server/ansible}/provision.yaml | 0 {ansible/sidecar => sidecar/ansible}/deploy.yaml | 0 {ansible/sidecar => sidecar/ansible}/inventory.ini | 0 {ansible/sidecar => sidecar/ansible}/keygen.yaml | 0 {ansible/sidecar => sidecar/ansible}/provision.yaml | 0 {ansible/sidecar => sidecar/ansible}/upload_pub_keys.yaml | 0 9 files changed, 3 insertions(+), 3 deletions(-) rename {ansible/draft => server/ansible}/deploy.yaml (100%) rename {ansible/draft => server/ansible}/inventory.ini (100%) rename {ansible/draft => server/ansible}/provision.yaml (100%) rename {ansible/sidecar => sidecar/ansible}/deploy.yaml (100%) rename {ansible/sidecar => sidecar/ansible}/inventory.ini (100%) rename {ansible/sidecar => sidecar/ansible}/keygen.yaml (100%) rename {ansible/sidecar => sidecar/ansible}/provision.yaml (100%) rename {ansible/sidecar => sidecar/ansible}/upload_pub_keys.yaml (100%) diff --git a/README.md b/README.md index beca485..423fa00 100644 --- a/README.md +++ b/README.md @@ -24,10 +24,10 @@ Host ipa User ec2-user IdentityFile ~/.ssh/ ``` -4. Update the `draft/ansible/sidecar/inventory.ini` file to only include a single host. (Unless you are running all 4 servers.) -5. Provision your machine: `ansible-playbook -i ansible/sidecar/inventory.ini ansible/sidecar/provision.yaml` +4. Update the `draft/sidecar/ansible/inventory.ini` file to only include a single host. (Unless you are running all 4 servers.) +5. Provision your machine: `ansible-playbook -i sidecar/ansible/inventory.ini sidecar/ansible/provision.yaml` -To deploy new changes in draft, run: `ansible-playbook -i ansible/sidecar/inventory.ini ansible/sidecar/deploy.yaml` +To deploy new changes in draft, run: `ansible-playbook -i sidecar/ansible/inventory.ini sidecar/ansible/deploy.yaml` ### Generating TLS certs with Let's Encrypt diff --git a/ansible/draft/deploy.yaml b/server/ansible/deploy.yaml similarity index 100% rename from ansible/draft/deploy.yaml rename to server/ansible/deploy.yaml diff --git a/ansible/draft/inventory.ini b/server/ansible/inventory.ini similarity index 100% rename from ansible/draft/inventory.ini rename to server/ansible/inventory.ini diff --git a/ansible/draft/provision.yaml b/server/ansible/provision.yaml similarity index 100% rename from ansible/draft/provision.yaml rename to server/ansible/provision.yaml diff --git a/ansible/sidecar/deploy.yaml b/sidecar/ansible/deploy.yaml similarity index 100% rename from ansible/sidecar/deploy.yaml rename to sidecar/ansible/deploy.yaml diff --git a/ansible/sidecar/inventory.ini b/sidecar/ansible/inventory.ini similarity index 100% rename from ansible/sidecar/inventory.ini rename to sidecar/ansible/inventory.ini diff --git a/ansible/sidecar/keygen.yaml b/sidecar/ansible/keygen.yaml similarity index 100% rename from ansible/sidecar/keygen.yaml rename to sidecar/ansible/keygen.yaml diff --git a/ansible/sidecar/provision.yaml b/sidecar/ansible/provision.yaml similarity index 100% rename from ansible/sidecar/provision.yaml rename to sidecar/ansible/provision.yaml diff --git a/ansible/sidecar/upload_pub_keys.yaml b/sidecar/ansible/upload_pub_keys.yaml similarity index 100% rename from ansible/sidecar/upload_pub_keys.yaml rename to sidecar/ansible/upload_pub_keys.yaml From a3af04b0d0da063b3817c677a0ccdca0c8150fe7 Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Fri, 5 Jul 2024 17:12:49 -0700 Subject: [PATCH 06/16] add inventory variables --- server/ansible/inventory.ini | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/server/ansible/inventory.ini b/server/ansible/inventory.ini index f2b9d73..45afd3b 100644 --- a/server/ansible/inventory.ini +++ b/server/ansible/inventory.ini @@ -1,5 +1,5 @@ [myhosts] -draft-ipa secret_id=prod-draft-env aws_region=us-west-2 +draft-ipa draft_domain=draft.ipa-helper-dev draft_port=3000 env_secret_id=prod-draft-env aws_region=us-west-2 [myhosts:vars] ansible_python_interpreter=/usr/bin/python3 From fd88465bb55d215e8a4a057c93ce849cd705116c Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Fri, 5 Jul 2024 17:18:29 -0700 Subject: [PATCH 07/16] fix variable name for env variable, remove unneeded nginx --- server/ansible/deploy.yaml | 2 +- server/ansible/provision.yaml | 13 ------------- 2 files changed, 1 insertion(+), 14 deletions(-) diff --git a/server/ansible/deploy.yaml b/server/ansible/deploy.yaml index a18d2a2..b3037b7 100644 --- a/server/ansible/deploy.yaml +++ b/server/ansible/deploy.yaml @@ -22,7 +22,7 @@ - name: Load .env file shell: > aws secretsmanager get-secret-value - --secret-id {{ secret_id }} + --secret-id {{ env_secret_id }} --region {{ aws_region }} --query SecretString --output text | diff --git a/server/ansible/provision.yaml b/server/ansible/provision.yaml index 8ea3b21..94ff44c 100644 --- a/server/ansible/provision.yaml +++ b/server/ansible/provision.yaml @@ -31,19 +31,6 @@ become: yes when: npm_installed.rc != 0 - - name: Check if nginx is installed - command: nginx --version - register: nginx_installed - failed_when: false - changed_when: false - - - name: Install nginx - yum: - name: nginx - state: latest - become: yes - when: nginx_installed.rc != 0 - - name: Check if Git is installed command: git --version register: git_installed From f4d2c1250c25a7950aba4aea932ebcb6b52955db Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Fri, 5 Jul 2024 17:57:13 -0700 Subject: [PATCH 08/16] bug hunt --- server/.prettierignore | 1 + server/ansible/deploy.yaml | 1 + server/ansible/provision.yaml | 9 ++++++--- server/pm2.json | 2 +- 4 files changed, 9 insertions(+), 4 deletions(-) diff --git a/server/.prettierignore b/server/.prettierignore index 07182c4..e4008cf 100644 --- a/server/.prettierignore +++ b/server/.prettierignore @@ -11,6 +11,7 @@ next.config.js tsconfig.json babel.config.js traefik/* +ansible/* # Not JS README.md diff --git a/server/ansible/deploy.yaml b/server/ansible/deploy.yaml index b3037b7..18c3261 100644 --- a/server/ansible/deploy.yaml +++ b/server/ansible/deploy.yaml @@ -7,6 +7,7 @@ repo: 'https://github.com/private-attribution/draft.git' dest: '{{ ansible_env.HOME }}/draft' update: yes + version: self-host - name: Checkout and pull main branch command: git pull origin main diff --git a/server/ansible/provision.yaml b/server/ansible/provision.yaml index 94ff44c..5e95bb6 100644 --- a/server/ansible/provision.yaml +++ b/server/ansible/provision.yaml @@ -48,7 +48,7 @@ git: repo: 'https://github.com/private-attribution/draft.git' dest: '{{ ansible_env.HOME }}/draft' - update: no + version: self-host - name: Check if Traefik is installed command: '{{ ansible_env.HOME }}/draft/traefik version' @@ -120,5 +120,8 @@ --setenv=CERT_DIR={{ ansible_env.HOME }}/cert --setenv=DRAFT_DOMAIN={{ draft_domain }} --setenv=DRAFT_PORT={{ draft_port }} - {{ ansible_env.HOME }}/draft/traefik - --config_file={{ ansible_env.HOME }}/draft/server/traefik/traefik.yaml + {{ansible_env.HOME }}/draft/traefik + --configFile={{ ansible_env.HOME }}/draft/server/traefik/traefik.yaml + args: + chdir: '{{ ansible_env.HOME }}/draft' + executable: /bin/bash diff --git a/server/pm2.json b/server/pm2.json index fed0e2e..fead18b 100644 --- a/server/pm2.json +++ b/server/pm2.json @@ -3,7 +3,7 @@ { "name": "draft-website", "script": "node_modules/next/dist/bin/next", - "args": "dev", + "args": "start", "cwd": "./" } ] From faf2a2a97e9174e877d2951c0454d414ffe95578 Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Fri, 5 Jul 2024 18:29:48 -0700 Subject: [PATCH 09/16] try pm2 instead of systemctl --- server/ansible/deploy.yaml | 5 ----- server/ansible/provision.yaml | 20 +++++++++++++------- server/pm2.json | 6 ++++++ 3 files changed, 19 insertions(+), 12 deletions(-) diff --git a/server/ansible/deploy.yaml b/server/ansible/deploy.yaml index 18c3261..713a7c1 100644 --- a/server/ansible/deploy.yaml +++ b/server/ansible/deploy.yaml @@ -9,11 +9,6 @@ update: yes version: self-host - - name: Checkout and pull main branch - command: git pull origin main - args: - chdir: '{{ ansible_env.HOME }}/draft' - - name: Install packages based on package-lock.json via npm npm: path: '{{ ansible_env.HOME}}/draft/server' diff --git a/server/ansible/provision.yaml b/server/ansible/provision.yaml index 5e95bb6..d7bf8e8 100644 --- a/server/ansible/provision.yaml +++ b/server/ansible/provision.yaml @@ -50,6 +50,12 @@ dest: '{{ ansible_env.HOME }}/draft' version: self-host + - name: Install packages based on package-lock.json via npm + npm: + path: '{{ ansible_env.HOME}}/draft/server' + state: present + ci: true + - name: Check if Traefik is installed command: '{{ ansible_env.HOME }}/draft/traefik version' register: traefik_installed @@ -116,12 +122,12 @@ - name: start traefik shell: > - systemd-run --user - --setenv=CERT_DIR={{ ansible_env.HOME }}/cert - --setenv=DRAFT_DOMAIN={{ draft_domain }} - --setenv=DRAFT_PORT={{ draft_port }} - {{ansible_env.HOME }}/draft/traefik - --configFile={{ ansible_env.HOME }}/draft/server/traefik/traefik.yaml + npm run pm2-start + environment: + CERT_DIR: '{{ ansible_env.HOME }}/cert/' + DRAFT_DOMAIN: '{{ draft_domain }}' + DRAFT_PORT: '{{ draft_port }}' + args: - chdir: '{{ ansible_env.HOME }}/draft' + chdir: '{{ ansible_env.HOME }}/draft/server' executable: /bin/bash diff --git a/server/pm2.json b/server/pm2.json index fead18b..f8d13dc 100644 --- a/server/pm2.json +++ b/server/pm2.json @@ -5,6 +5,12 @@ "script": "node_modules/next/dist/bin/next", "args": "start", "cwd": "./" + }, + { + "name": "traefik", + "script": "../traefik", + "args": "--configFile=traefik/traefik.yaml", + "cwd": "./" } ] } From 3dc4b7deb2e2ac3de8af1e76aab81b5321ff9657 Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Fri, 5 Jul 2024 20:25:49 -0700 Subject: [PATCH 10/16] traefik running location bug --- server/traefik/traefik.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/server/traefik/traefik.yaml b/server/traefik/traefik.yaml index 12da075..bc79f9e 100644 --- a/server/traefik/traefik.yaml +++ b/server/traefik/traefik.yaml @@ -6,4 +6,4 @@ entryPoints: providers: file: - directory: "server/traefik/dynamic" + directory: "traefik/dynamic" From b5460cfe402dbe2835d106306d82fbc1fec334df Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Fri, 5 Jul 2024 22:20:42 -0700 Subject: [PATCH 11/16] fat finger domain name --- server/ansible/deploy.yaml | 1 - server/ansible/inventory.ini | 2 +- server/ansible/provision.yaml | 3 +-- 3 files changed, 2 insertions(+), 4 deletions(-) diff --git a/server/ansible/deploy.yaml b/server/ansible/deploy.yaml index 713a7c1..fc3e5ce 100644 --- a/server/ansible/deploy.yaml +++ b/server/ansible/deploy.yaml @@ -7,7 +7,6 @@ repo: 'https://github.com/private-attribution/draft.git' dest: '{{ ansible_env.HOME }}/draft' update: yes - version: self-host - name: Install packages based on package-lock.json via npm npm: diff --git a/server/ansible/inventory.ini b/server/ansible/inventory.ini index 45afd3b..82b7c31 100644 --- a/server/ansible/inventory.ini +++ b/server/ansible/inventory.ini @@ -1,5 +1,5 @@ [myhosts] -draft-ipa draft_domain=draft.ipa-helper-dev draft_port=3000 env_secret_id=prod-draft-env aws_region=us-west-2 +draft-ipa draft_domain=draft.ipa-helper.dev draft_port=3000 env_secret_id=prod-draft-env aws_region=us-west-2 [myhosts:vars] ansible_python_interpreter=/usr/bin/python3 diff --git a/server/ansible/provision.yaml b/server/ansible/provision.yaml index d7bf8e8..561c827 100644 --- a/server/ansible/provision.yaml +++ b/server/ansible/provision.yaml @@ -48,7 +48,6 @@ git: repo: 'https://github.com/private-attribution/draft.git' dest: '{{ ansible_env.HOME }}/draft' - version: self-host - name: Install packages based on package-lock.json via npm npm: @@ -120,7 +119,7 @@ chdir: '{{ ansible_env.HOME }}/cert' executable: /bin/bash - - name: start traefik + - name: start traefik and nextjs shell: > npm run pm2-start environment: From 44da939103a59bbe307f6320c6f19528b6e0e3e8 Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Fri, 5 Jul 2024 22:21:45 -0700 Subject: [PATCH 12/16] use ansible git module correctly --- sidecar/ansible/deploy.yaml | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/sidecar/ansible/deploy.yaml b/sidecar/ansible/deploy.yaml index aba7830..0fc94d2 100644 --- a/sidecar/ansible/deploy.yaml +++ b/sidecar/ansible/deploy.yaml @@ -14,10 +14,8 @@ repo: 'https://github.com/private-attribution/draft.git' dest: '{{ ansible_env.HOME }}/draft' update: yes - - name: Checkout and pull main branch - command: git pull origin main - args: - chdir: '{{ ansible_env.HOME }}/draft' + version: main + - name: Start helper sidecar shell: > source .venv/bin/activate && From 135fd9baaba9e11efb6a84f92d09b87c09622199 Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Tue, 9 Jul 2024 11:10:25 -0700 Subject: [PATCH 13/16] update ansible to load put secrets in environment not .env file --- server/ansible/deploy.yaml | 26 ++++++++---------------- server/ansible/load_secrets.sh | 36 ++++++++++++++++++++++++++++++++++ server/ansible/provision.yaml | 29 ++++----------------------- 3 files changed, 48 insertions(+), 43 deletions(-) create mode 100644 server/ansible/load_secrets.sh diff --git a/server/ansible/deploy.yaml b/server/ansible/deploy.yaml index fc3e5ce..9c8d27f 100644 --- a/server/ansible/deploy.yaml +++ b/server/ansible/deploy.yaml @@ -14,31 +14,21 @@ state: present ci: true - - name: Load .env file - shell: > - aws secretsmanager get-secret-value - --secret-id {{ env_secret_id }} - --region {{ aws_region }} - --query SecretString - --output text | - jq -r 'to_entries|map("\(.key)=\"\(.value|tostring)\"")|.[]' > - .env - args: - chdir: '{{ ansible_env.HOME }}/draft/server' - executable: /bin/bash - - - - name: Rebuild draft website + - name: Build draft website shell: > npm run build args: chdir: '{{ ansible_env.HOME }}/draft/server' executable: /bin/bash - - - name: Restart draft website + - name: start traefik and nextjs shell: > - npm run pm2-restart + source ansible/load_secrets.sh && npm run pm2-start + environment: + CERT_DIR: '{{ ansible_env.HOME }}/cert/' + DRAFT_DOMAIN: '{{ draft_domain }}' + DRAFT_PORT: '{{ draft_port }}' + args: chdir: '{{ ansible_env.HOME }}/draft/server' executable: /bin/bash diff --git a/server/ansible/load_secrets.sh b/server/ansible/load_secrets.sh new file mode 100644 index 0000000..75060e0 --- /dev/null +++ b/server/ansible/load_secrets.sh @@ -0,0 +1,36 @@ +#!/bin/bash + +# Check if the CERT_DIR environment variable is set +if [ -z "$CERT_DIR" ]; then + echo "Error: CERT_DIR environment variable is not set." + exit 1 +fi + +# Directory where the cert files will be written +CERT_DIR="$1" +# Ensure the directory exists +mkdir -p "$CERT_DIR" + +# load cert.pem file +aws secretsmanager get-secret-value \ + --secret-id cert.pem \ + --region {{ aws_region }} \ + --query SecretString \ + --output text \ + > "${CERT_DIR}"/cert.pem + +# load key.pem file +aws secretsmanager get-secret-value \ + --secret-id key.pem \ + --region {{ aws_region }} \ + --query SecretString \ + --output text \ + > ${CERT_DIR}/key.pem + +# set environmental variables +aws secretsmanager get-secret-value \ + --secret-id {{ env_secret_id }} \ + --region {{ aws_region }} \ + --query SecretString \ + | jq -r 'fromjson | to_entries | .[] | "export \(.key)=\(.value|tostring)"' \ + | while read -r line; do eval "$line"; done diff --git a/server/ansible/provision.yaml b/server/ansible/provision.yaml index 561c827..ad400a1 100644 --- a/server/ansible/provision.yaml +++ b/server/ansible/provision.yaml @@ -91,37 +91,16 @@ command: 'setcap cap_net_bind_service=+ep {{ ansible_env.HOME }}/draft/traefik' become: yes - - name: Create cert directory - file: - path: '{{ ansible_env.HOME }}/cert' - state: directory - - - name: Load cert.pem file + - name: Build draft website shell: > - aws secretsmanager get-secret-value - --secret-id cert.pem - --region {{ aws_region }} - --query SecretString - --output text > cert.pem + npm run build args: - chdir: '{{ ansible_env.HOME }}/cert' - executable: /bin/bash - - - - name: Load key.pem file - shell: > - aws secretsmanager get-secret-value - --secret-id key.pem - --region {{ aws_region }} - --query SecretString - --output text > key.pem - args: - chdir: '{{ ansible_env.HOME }}/cert' + chdir: '{{ ansible_env.HOME }}/draft/server' executable: /bin/bash - name: start traefik and nextjs shell: > - npm run pm2-start + source ansible/load_secrets.sh && npm run pm2-start environment: CERT_DIR: '{{ ansible_env.HOME }}/cert/' DRAFT_DOMAIN: '{{ draft_domain }}' From dbbcfe9457891ac413fe2624050e9d9c5eba2d91 Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Tue, 9 Jul 2024 11:34:43 -0700 Subject: [PATCH 14/16] fix bugs in load_secrets script --- server/ansible/load_secrets.sh | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) diff --git a/server/ansible/load_secrets.sh b/server/ansible/load_secrets.sh index 75060e0..a2726c0 100644 --- a/server/ansible/load_secrets.sh +++ b/server/ansible/load_secrets.sh @@ -3,18 +3,16 @@ # Check if the CERT_DIR environment variable is set if [ -z "$CERT_DIR" ]; then echo "Error: CERT_DIR environment variable is not set." - exit 1 + return 1 2>/dev/null || exit 1 # return when sourced, exit otherwise fi -# Directory where the cert files will be written -CERT_DIR="$1" # Ensure the directory exists mkdir -p "$CERT_DIR" # load cert.pem file aws secretsmanager get-secret-value \ --secret-id cert.pem \ - --region {{ aws_region }} \ + --region us-west-2 \ --query SecretString \ --output text \ > "${CERT_DIR}"/cert.pem @@ -22,15 +20,16 @@ aws secretsmanager get-secret-value \ # load key.pem file aws secretsmanager get-secret-value \ --secret-id key.pem \ - --region {{ aws_region }} \ + --region us-west-2 \ --query SecretString \ --output text \ > ${CERT_DIR}/key.pem # set environmental variables -aws secretsmanager get-secret-value \ - --secret-id {{ env_secret_id }} \ - --region {{ aws_region }} \ +env_vars=$(aws secretsmanager get-secret-value \ + --secret-id prod-draft-env \ + --region us-west-2 \ --query SecretString \ - | jq -r 'fromjson | to_entries | .[] | "export \(.key)=\(.value|tostring)"' \ - | while read -r line; do eval "$line"; done + | jq -r 'fromjson | to_entries | .[] | "export \(.key)=\(.value|tostring)"') + +eval "$env_vars" From c3adf6fb24f2f4869993d6eb1095d543aa591d61 Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Tue, 9 Jul 2024 11:46:04 -0700 Subject: [PATCH 15/16] restart in deploy.yaml --- server/ansible/deploy.yaml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/server/ansible/deploy.yaml b/server/ansible/deploy.yaml index 9c8d27f..9853aac 100644 --- a/server/ansible/deploy.yaml +++ b/server/ansible/deploy.yaml @@ -21,9 +21,9 @@ chdir: '{{ ansible_env.HOME }}/draft/server' executable: /bin/bash - - name: start traefik and nextjs + - name: restart traefik and nextjs shell: > - source ansible/load_secrets.sh && npm run pm2-start + source ansible/load_secrets.sh && npm run pm2-restart environment: CERT_DIR: '{{ ansible_env.HOME }}/cert/' DRAFT_DOMAIN: '{{ draft_domain }}' From de07957d44bdd34a1586631754f99bc9228cc8a7 Mon Sep 17 00:00:00 2001 From: Erik Taubeneck Date: Tue, 9 Jul 2024 11:46:33 -0700 Subject: [PATCH 16/16] make sure git checks out main branch --- server/ansible/deploy.yaml | 1 + 1 file changed, 1 insertion(+) diff --git a/server/ansible/deploy.yaml b/server/ansible/deploy.yaml index 9853aac..5e5c991 100644 --- a/server/ansible/deploy.yaml +++ b/server/ansible/deploy.yaml @@ -7,6 +7,7 @@ repo: 'https://github.com/private-attribution/draft.git' dest: '{{ ansible_env.HOME }}/draft' update: yes + version: main - name: Install packages based on package-lock.json via npm npm: