diff --git a/.gitignore b/.gitignore index a34ee8e..36e073a 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1,3 @@ -centos_django.step \ No newline at end of file +centos_django.step +.vscode +teste* \ No newline at end of file diff --git a/centos.conf b/centos.conf index ba1df70..8febf31 100755 --- a/centos.conf +++ b/centos.conf @@ -3,23 +3,23 @@ # Nome do usuário no sistema # Sistem's username -USERNAME="lucas" +USERNAME="centos" # Nome do App no repositório # App name on repo -APP="3m" +APP="app" # Nome do ambiente virtual python # Virtual environment name VENV=".venv" -# Nome de usuário do repositório -# Git username -GIT_USER="lucas" +# Nome de usuário do repositório ou grupo +# Git username or group +GIT_USER="username" # Endereço do projeto no repositório # Git project url -GITURL="https://git.lucasf.dev/$GIT_USER/$APP.git" +GITURL="https://repo.com/$GIT_USER/$APP.git" # IP público ou domínio # Public IP address or domain diff --git a/run.sh b/run.sh index 472f671..b1ceddb 100755 --- a/run.sh +++ b/run.sh @@ -25,13 +25,13 @@ APP="appname" # Virtual environment name VENV=".venv" -# Nome de usuário do repositório -# Git username +# Nome de usuário do repositório ou grupo +# Git username or group GIT_USER="username" # Endereço do projeto no repositório # Git project url -GITURL="https://repositório.com/$GIT_USER/$APP.git" +GITURL="https://repo.com/$GIT_USER/$APP.git" # IP público ou domínio # Public IP address or domain @@ -76,10 +76,14 @@ MSG_PT[entry]="Digite sim ou s para continuar (sim/não): " MSG_PT[error_root]="Você precisa executar o script como root" MSG_PT[error_requirements]="Não encontrei o arquivo requirements.txt" MSG_PT[error_env]="Não encontrei o arquivo .env" +MSG_PT[sugest_env]="Posso criar esse arquivo pra você? +Eu criarei com as variáveis [SECRET_KEY, ALLOWED_HOSTS, DEBUG]. +Sim! vou criar uma SECRET_KEY como Django +apenas para dar sequência e testar o servidor, claro que você pode alterar depois." MSG_PT[error_allwhost]="Não encontrei a variável ALLOWED_HOSTS, você lembrou de extrair do settings.py?" MSG_PT[error_debug]="Não encontrei a variável DEBUG, você lembrou de extrair do settings.py?" MSG_PT[repo]="Por favor verificar o repositório ou suas credenciais" -MSG_PT[done]="FEITO" +MSG_PT[done]="TUDO PRONTO! Só curtir!" MSG_PT[fail]="FALHOU" declare -A MSG_EN @@ -89,16 +93,32 @@ MSG_EN[entry]="Shall we proceed? (yes/no): " MSG_EN[error_root]="You must be root" MSG_EN[error_req]="Can't find requirements.txt file" MSG_EN[error_env]="Can't find .env file" +MSG_EN[sugest_env]="Can i create this file for you? +I'll create basic variables like [SECRET_KEY, ALLOWED_HOSTS, DEBUG]. +Yep! i'll create a SECRET_KEY like Django +just for continue and test server, although you can change it after." MSG_EN[error_allwhost]="Can't find ALLOWED_HOSTS variable did you extract it from settings.py?" MSG_EN[error_debug]="Can't find DEBUG variable did you extract it from settings.py?" MSG_EN[repo]="Please check your repo or credentials" -MSG_EN[done]="DONE" +MSG_EN[done]="ALL DONE! Enjoy it!" MSG_EN[fail]="FAIL" STEP=0 SCRIPT_PATH=$(dirname $0) SCRIPT_STEP_FILE="$SCRIPT_PATH/centos_django.step" +CHARS="abcdefghijklmnopqrstuvwxyz0123456789!@#$%^&*(-_=+)" +for ((i=0;i<${#CHARS};i++)); do ARRAY[$i]="${CHARS:i:1}"; done + +# Cria uma sequência de 50 caracteres aleatórios +# Create 50 random chars +key_gen() { + for ((c=1; c<=50; c++)); do + KEY="$KEY${ARRAY[$((RANDOM % 50))]}" + done + echo $KEY +} + # Lê o arquivo de configuração e atualiza os valores das variáveis # Read config file and set all variables if [[ -f "$SCRIPT_PATH/$ARQ_CONF" ]]; then @@ -126,16 +146,22 @@ fi # Verifica se o usuário ativo é o root # Verify if is a root user if [[ "$EUID" -ne 0 ]];then - HAS_ERROS="yes" ERRORS+=("${MSGS[error_root]}") + echo -e "\033[31m${MSGS[error_root]}\033[0m" + exit 1 fi # Verifica a existência do usuário no sistema # Check if user exists CNU=$(grep -c $USERNAME /etc/passwd) if [[ $CNU -lt 1 ]]; then - echo "precisa criar o usuário" - #useradd --create-home $USERNAME + useradd --create-home $USERNAME +fi + +# Sanitiza a variável SERVICE +# Sanitize SERVICE var +if [[ ! $SERVICE =~ ".service" ]]; then + SERVICE+=".service" fi # Obtém o IP @@ -184,28 +210,44 @@ clone_project() { fi } -# Verifica a existência dos arquivos requirements.txt e .env -# Check for existence of requirements.txt and .env files -validate_files() { +# Verifica a existência do arquivo requirements.txt +# Check for existence of requirements.txt file +validate_requirements() { if [[ ! -f "/home/$USERNAME/$APP/requirements.txt" ]]; then - HAS_ERROS="yes" - ERRORS+=("${MSGS[error_req]}") + echo -e "\033[31m${MSGS[errors]}" && + echo -e "\033[0m - \033[37m${MSGS[error_req]}\033[0m" && + update_step_error "$x" fi +} +# Verifica a existência do arquivo .env +# Check for existence of .env file +validate_env() { if [[ ! -f "/home/$USERNAME/$APP/.env" ]]; then - HAS_ERROS="yes" - ERRORS+=("${MSGS[error_env]}") - fi - - if [[ ${#ERRORS[@]} -ge 1 ]]; then echo -e "\033[31m${MSGS[errors]}" - for error in "${ERRORS[@]}"; do - echo -e "\033[0m - \033[37m$error\033[0m" - done - update_step_error "$x" + echo -e "\033[0m - \033[37m${MSGS[error_env]}\033[0m" && + echo -e "\n${MSGS[sugest_env]}\n" && + read -p "${MSGS[entry]}" resp_env && + if [[ -n resp_env ]]; then + if [[ ${resp_env,,} == "sim" ]] || [[ ${resp_env,,} == "s" ]] || [[ ${resp_env,,} == "yes" ]] || [[ ${resp_env,,} == "y" ]]; then + make_env_file + fi + else + update_step_error "$x" + fi fi } +# Cria um arquivo .env +# Create a .env file +make_env_file() { + ENV="SECRET_KEY='$(key_gen)'\n + ALLOWED_HOSTS=localhost, 127.0.0.1\n + DEBUG=False + " + $(echo -e $ENV | sed -e 's/^[ \t]*//' > /home/$USERNAME/$APP/.env) +} + # Incrementar IP em ALLOWED_HOSTS no arquivo .env caso não tenha incrementado # Increase ALLOWED_HOSTS IP on .env file if it doesn't exist increment_ip() { @@ -260,7 +302,6 @@ install_packages() { # Criar o ambiente Virtual # Create venv create_venv() { - # python3 -m venv /home/$USERNAME/$APP/$VENV && . /home/$USERNAME/$APP/$VENV/bin/activate python3 -m venv /home/$USERNAME/$APP/$VENV if [[ $? -ge 1 ]]; then update_step_error "$x" @@ -317,6 +358,44 @@ enable_ports() { fi } +# Corrigir a configuração inicial do nginx +# Manage default nginx config file +manage_default_nginx_file() { + mv /etc/nginx/nginx.conf /etc/nginx/nginx.conf~ && + cat > /etc/nginx/nginx.conf <