refacto: Rename variables and names containing item into items

This commit is contained in:
Mangiang 2021-10-28 18:23:54 -04:00
parent 22daa666fc
commit 6bfb64cf56
No known key found for this signature in database
GPG Key ID: DAE9B92A692CD55C
9 changed files with 51 additions and 58 deletions

View File

@ -1,2 +1,2 @@
[host] [host]
{{ DEPLOYMENT_USER }}@{{ DEPLOY_HOST }} ansible_connection=ssh ansible_user={{ DEPLOYMENT_USER }} {{ DEPLOYMENT_USER }}@{{ DEPLOY_HOSTNAME }} ansible_connection=ssh ansible_user={{ DEPLOYMENT_USER }}

View File

@ -6,7 +6,7 @@
- name: Debug - name: Debug
debug: debug:
msg: "{{ lookup('env', 'SPT_ITEMS_PATH') }}" msg: "{{ lookup('env', 'SPT_ITEMS_PATH') }}"
- name: Delete spt-item-finder before adding everything again - name: Delete spt-items-api before adding everything again
file: file:
state: absent state: absent
path: "{{ lookup('env', 'SPT_ITEMS_PATH') }}" path: "{{ lookup('env', 'SPT_ITEMS_PATH') }}"
@ -46,7 +46,7 @@
- name: Initialize database - name: Initialize database
uri: uri:
url: "https://{{ lookup('env', 'SPT_HOSTNAME') }}/api/refresh" url: "https://{{ lookup('env', 'SPT_ITEM_HOSTNAME') }}/api/refresh"
method: GET method: GET
status_code: [200, 204] status_code: [200, 204]
timeout: 60 timeout: 60

View File

@ -2,7 +2,7 @@ APP_NAME="Item Finder"
APP_ENV=production APP_ENV=production
APP_KEY= APP_KEY=
APP_DEBUG=false APP_DEBUG=false
APP_URL="https://{{ lookup('env', 'SPT_HOSTNAME') }}" APP_URL="https://{{ lookup('env', 'SPT_ITEMS_HOSTNAME') }}"
APP_TIMEZONE=UTC APP_TIMEZONE=UTC
LOG_CHANNEL=stack LOG_CHANNEL=stack

View File

@ -3,12 +3,11 @@
<head> <head>
<meta charset="utf-8" /> <meta charset="utf-8" />
<link rel="icon" <link rel="icon" href="/favico.svg" />
href="" />
<meta name="viewport" content="width=device-width,initial-scale=1" /> <meta name="viewport" content="width=device-width,initial-scale=1" />
<meta name="theme-color" content="#000000" /> <meta name="theme-color" content="#000000" />
<meta name="description" content="item finder" /> <meta name="description" content="items finder" />
<link rel="apple-touch-icon" href="/logo192.png" /> <link rel="apple-touch-icon" href="/favico.ico" />
<link rel="manifest" href="/manifest.json" /> <link rel="manifest" href="/manifest.json" />
<title>Item Finder</title> <title>Item Finder</title>
</head> </head>

View File

@ -6,7 +6,7 @@ concurrency:
limit: 1 limit: 1
environment: environment:
SPT_ITEMS_PATH: /var/www/html/aki/spt-item-api SPT_ITEMS_PATH: /var/www/html/aki/spt-items-api
trigger: trigger:
event: event:
@ -23,15 +23,15 @@ steps:
- name: replace hosts and user variables - name: replace hosts and user variables
image: ubuntu:impish image: ubuntu:impish
environment: environment:
DEPLOY_HOST: DEPLOY_HOSTNAME:
from_secret: deploy_host from_secret: deploy_hostname
SPT_HOSTNAME: SPT_ITEMS_HOSTNAME:
from_secret: spt_hostname from_secret: spt_items_hostname
DEPLOYMENT_USER: DEPLOYMENT_USER:
from_secret: deploy_username from_secret: deploy_username
commands: commands:
- sed -i 's/{{ SPT_HOSTNAME }}/'"$SPT_HOSTNAME"'/g' ./frontend/.env - sed -i 's/{{ SPT_ITEMS_HOSTNAME }}/'"$SPT_ITEMS_HOSTNAME"'/g' ./frontend/.env
- sed -i 's/{{ DEPLOY_HOST }}/'"$DEPLOY_HOST"'/g' ./.ansible/inventory - sed -i 's/{{ DEPLOY_HOSTNAME }}/'"$DEPLOY_HOSTNAME"'/g' ./.ansible/inventory
- sed -i 's/{{ DEPLOYMENT_USER }}/'"$DEPLOYMENT_USER"'/g' ./.ansible/inventory - sed -i 's/{{ DEPLOYMENT_USER }}/'"$DEPLOYMENT_USER"'/g' ./.ansible/inventory
- name: build frontend - name: build frontend
@ -62,10 +62,10 @@ steps:
private_key: private_key:
from_secret: deploy_ssh_key from_secret: deploy_ssh_key
environment: environment:
DEPLOY_HOST: DEPLOY_HOSTNAME:
from_secret: deploy_host from_secret: deploy_hostname
SPT_HOSTNAME: SPT_ITEMS_HOSTNAME:
from_secret: spt_hostname from_secret: spt_items_hostname
DEPLOYMENT_USER: DEPLOYMENT_USER:
from_secret: deploy_username from_secret: deploy_username
when: when:

View File

@ -6,7 +6,7 @@ concurrency:
limit: 1 limit: 1
environment: environment:
SPT_ITEMS_PATH: /var/www/html/aki/spt-item-api SPT_ITEMS_PATH: /var/www/html/aki/spt-items-api
trigger: trigger:
event: event:
@ -17,25 +17,19 @@ trigger:
- development - development
steps: steps:
- name: fetch and update submodules to the latest commit
image: alpine/git
commands:
- git submodule init
- git submodule update --recursive --remote
- name: replace hosts and user variables - name: replace hosts and user variables
image: ubuntu:impish image: ubuntu:impish
environment: environment:
DEPLOY_HOST: DEPLOY_HOSTNAME:
from_secret: deploy_host from_secret: deploy_hostname
SPT_HOSTNAME: SPT_ITEMS_HOSTNAME:
from_secret: spt_hostname from_secret: spt_items_hostname
DEPLOYMENT_USER: DEPLOYMENT_USER:
from_secret: deploy_username from_secret: deploy_username
commands: commands:
- sed -i 's/{{ SPT_HOSTNAME }}/'"$SPT_HOSTNAME"'/g' ./items/frontend/.env.example - sed -i 's/{{ SPT_ITEMS_HOSTNAME }}/'"$SPT_ITEMS_HOSTNAME"'/g' ./items/frontend/.env.example
- mv ./items/frontend/.env.example ./items/frontend/.env - mv ./items/frontend/.env.example ./items/frontend/.env
- sed -i 's/{{ DEPLOY_HOST }}/'"$DEPLOY_HOST"'/g' ./.ansible-items/inventory - sed -i 's/{{ DEPLOY_HOSTNAME }}/'"$DEPLOY_HOSTNAME"'/g' ./.ansible-items/inventory
- sed -i 's/{{ DEPLOYMENT_USER }}/'"$DEPLOYMENT_USER"'/g' ./.ansible-items/inventory - sed -i 's/{{ DEPLOYMENT_USER }}/'"$DEPLOYMENT_USER"'/g' ./.ansible-items/inventory
when: when:
branch: branch:
@ -76,10 +70,10 @@ steps:
private_key: private_key:
from_secret: deploy_ssh_key from_secret: deploy_ssh_key
environment: environment:
DEPLOY_HOST: DEPLOY_HOSTNAME:
from_secret: deploy_host from_secret: deploy_hostname
SPT_HOSTNAME: SPT_ITEMS_HOSTNAME:
from_secret: spt_hostname from_secret: spt_items_hostname
DEPLOYMENT_USER: DEPLOYMENT_USER:
from_secret: deploy_username from_secret: deploy_username
when: when:

View File

@ -18,8 +18,8 @@
## Required secrets ## Required secrets
| secret name | description | example | | secret name | description | example |
| :-----------------| :---------- | :------- | | :-----------------| :---------- | :------- |
| spt_hostname | The remote server where spt-items-finder will be reachable <br> used for the frontend resolution | spt-items.my.server.com | | spt_items_hostname | The remote server where spt-items-finder will be reachable <br> used for the frontend resolution | spt-items.my.server.com |
| deploy_host | The remote server where to deploy <br> used by Ansible SSH | my.server.com | | deploy_hostname | The remote server where to deploy <br> used by Ansible SSH | my.server.com |
| deploy_username | The default username on the remote server <br> used by Ansible SSH <br> This user must have sudo rights | myuser | | deploy_username | The default username on the remote server <br> used by Ansible SSH <br> This user must have sudo rights | myuser |
| deploy_ssh_key | The **content** of the ssh private key used to connect to the remote server <br> The key needs to be in RSA in "RSA PRIVATE KEY" format <br> The ssh publick key needs to already be in the user used in the remote server ~/.ssh/authorized_keys | -----BEGIN RSA PRIVATE KEY----- <br> The key <br> -----END RSA PRIVATE KEY----- | | deploy_ssh_key | The **content** of the ssh private key used to connect to the remote server <br> The key needs to be in RSA in "RSA PRIVATE KEY" format <br> The ssh publick key needs to already be in the user used in the remote server ~/.ssh/authorized_keys | -----BEGIN RSA PRIVATE KEY----- <br> The key <br> -----END RSA PRIVATE KEY----- |

View File

@ -13,7 +13,7 @@
* [Check ansible syntax](#check-ansible-syntax) * [Check ansible syntax](#check-ansible-syntax)
* [Apply ansible playbook](#apply-ansible-playbook) * [Apply ansible playbook](#apply-ansible-playbook)
* [Playbook definition](#playbook-definition) * [Playbook definition](#playbook-definition)
* [Delete old spt-item-finder](#delete-old-spt-item-finder) * [Delete old spt-items-api](#delete-old-spt-items-api)
* [Copy the project](#copy-the-project) * [Copy the project](#copy-the-project)
* [Copy PHP env file](#copy-php-env-file) * [Copy PHP env file](#copy-php-env-file)
* [Get JavaScript chunks name](#get-javascript-chunks-name) * [Get JavaScript chunks name](#get-javascript-chunks-name)
@ -49,7 +49,7 @@ The pipeline is set to only one build at a time (every subsequent build with be
## Environment variables ## Environment variables
```yml ```yml
environment: environment:
SPT_ITEMS_PATH: /var/www/html/aki/spt-item-api SPT_ITEMS_PATH: /var/www/html/aki/spt-items-api
``` ```
Here are the environment variables. They are automatically injected in every step. Here are the environment variables. They are automatically injected in every step.
@ -79,21 +79,21 @@ Fetching and updating [submodules](https://git-scm.com/book/en/v2/Git-Tools-Subm
- name: replace hosts and user variables - name: replace hosts and user variables
image: ubuntu:impish image: ubuntu:impish
environment: environment:
DEPLOY_HOST: DEPLOY_HOSTNAME:
from_secret: deploy_host from_secret: deploy_hostname
SPT_HOSTNAME: SPT_ITEMS_HOSTNAME:
from_secret: spt_hostname from_secret: spt_items_hostname
DEPLOYMENT_USER: DEPLOYMENT_USER:
from_secret: deploy_username from_secret: deploy_username
commands: commands:
- sed -i 's/{{ SPT_HOSTNAME }}/'"$SPT_HOSTNAME"'/g' ./frontend/.env - sed -i 's/{{ SPT_ITEMS_HOSTNAME }}/'"$SPT_ITEMS_HOSTNAME"'/g' ./frontend/.env
- sed -i 's/{{ DEPLOY_HOST }}/'"$DEPLOY_HOST"'/g' ./.ansible/inventory - sed -i 's/{{ DEPLOY_HOSTNAME }}/'"$DEPLOY_HOSTNAME"'/g' ./.ansible/inventory
- sed -i 's/{{ DEPLOYMENT_USER }}/'"$DEPLOYMENT_USER"'/g' ./.ansible/inventory - sed -i 's/{{ DEPLOYMENT_USER }}/'"$DEPLOYMENT_USER"'/g' ./.ansible/inventory
``` ```
Executed on every push. \ Executed on every push. \
The following environment variables are injected using Drone secrets: The following environment variables are injected using Drone secrets:
* `SPT_HOSTNAME` is used by the frontend to call the backend. * `SPT_ITEMS_HOSTNAME` is used by the frontend to call the backend.
* `DEPLOY_HOST` is used by Ansible to connect to the remote server via SSH. * `DEPLOY_HOSTNAME` is used by Ansible to connect to the remote server via SSH.
* `DEPLOYMENT_USER` is used by Ansible to connect to the remote server via SSH. * `DEPLOYMENT_USER` is used by Ansible to connect to the remote server via SSH.
* all environment variables at the pipeline level (see [Environment variables](#environment-variables)) * all environment variables at the pipeline level (see [Environment variables](#environment-variables))
Using `sed` makes temporary changes in the container/pod instead of commiting secrets in the repo in plain text. \ Using `sed` makes temporary changes in the container/pod instead of commiting secrets in the repo in plain text. \
@ -144,10 +144,10 @@ Check the Ansible syntax in [playbook.yml](../.ansible/playbook.yml), [inventory
private_key: private_key:
from_secret: deploy_ssh_key from_secret: deploy_ssh_key
environment: environment:
DEPLOY_HOST: DEPLOY_HOSTNAME:
from_secret: deploy_host from_secret: deploy_hostname
SPT_HOSTNAME: SPT_ITEMS_HOSTNAME:
from_secret: spt_hostname from_secret: spt_items_hostname
DEPLOYMENT_USER: DEPLOYMENT_USER:
from_secret: deploy_username from_secret: deploy_username
when: when:
@ -160,8 +160,8 @@ Executed only on promotion to production. \
This step actually deploys to the server. \ This step actually deploys to the server. \
This step is [idempotent](https://en.wikipedia.org/wiki/Idempotence). \ This step is [idempotent](https://en.wikipedia.org/wiki/Idempotence). \
The following environment variables are injected using Drone secrets: The following environment variables are injected using Drone secrets:
* `SPT_HOSTNAME` is used by the PHP env file. * `SPT_ITEMS_HOSTNAME` is used by the PHP env file.
* `DEPLOY_HOST` is used to connect to the remote server via SSH. * `DEPLOY_HOSTNAME` is used to connect to the remote server via SSH.
* `DEPLOYMENT_USER` is used to connect to the remote server via SSH. * `DEPLOYMENT_USER` is used to connect to the remote server via SSH.
* all environment variables at the pipeline level (see [Environment variables](#environment-variables)) * all environment variables at the pipeline level (see [Environment variables](#environment-variables))
@ -174,9 +174,9 @@ become_method: sudo
``` ```
Uses the host defined in [inventory](../.ansible/inventory). Remember, the step [Replace hosts and user variables](#replace-hosts-and-user-variables) already replaced the variables at this point. The playbook will be executed as `root` user using `sudo`. Uses the host defined in [inventory](../.ansible/inventory). Remember, the step [Replace hosts and user variables](#replace-hosts-and-user-variables) already replaced the variables at this point. The playbook will be executed as `root` user using `sudo`.
#### Delete old spt-item-finder #### Delete old spt-items-api
```yml ```yml
- name: Delete spt-item-finder before adding everything again - name: Delete spt-items-api before adding everything again
file: file:
state: absent state: absent
path: "{{ lookup('env', 'SPT_ITEMS_PATH') }}" path: "{{ lookup('env', 'SPT_ITEMS_PATH') }}"
@ -202,7 +202,7 @@ Copies the whole project (frontend and backend) from the [api](../api) folder in
``` ```
Uses [Jinja2](https://jinja2docs.readthedocs.io/en/stable/) to resolve the [template for the PHP .env file](../.ansible/templates/.php_env.j2). \ Uses [Jinja2](https://jinja2docs.readthedocs.io/en/stable/) to resolve the [template for the PHP .env file](../.ansible/templates/.php_env.j2). \
`SPT_ITEMS_PATH` is injected thanks to the pipeline level environment variables (see [Environment variables](#environment-variables)). \ `SPT_ITEMS_PATH` is injected thanks to the pipeline level environment variables (see [Environment variables](#environment-variables)). \
`SPT_HOSTNAME` is injected in the environments properties (see [Apply ansible playbook](#apply-ansible-playbook)) `SPT_ITEMS_HOSTNAME` is injected in the environments properties (see [Apply ansible playbook](#apply-ansible-playbook))
#### Get JavaScript chunks name #### Get JavaScript chunks name
```yml ```yml

View File

@ -1,4 +1,4 @@
REACT_APP_BACKEND_URL=https://{{ SPT_HOSTNAME }} REACT_APP_BACKEND_URL=https://{{ SPT_ITEMS_HOSTNAME }}
REACT_APP_SPTARKOV_HOME=https://www.sp-tarkov.com/ REACT_APP_SPTARKOV_HOME=https://www.sp-tarkov.com/
REACT_APP_SPTARKOV_WORKSHOP=https://mods.sp-tarkov.com/ REACT_APP_SPTARKOV_WORKSHOP=https://mods.sp-tarkov.com/
REACT_APP_SPTARKOV_DOCUMENTATION=https://docs.sp-tarkov.com/ REACT_APP_SPTARKOV_DOCUMENTATION=https://docs.sp-tarkov.com/