From 6c71afde83e187bc1a9d02ac0dbbd74079424467 Mon Sep 17 00:00:00 2001 From: Ryan Thorn <106628688+rthorn-nr@users.noreply.github.com> Date: Fri, 31 Mar 2023 09:04:59 -0700 Subject: [PATCH] PHP recipe application name --- recipes/newrelic/apm/php/debian.yml | 18 +++++++++++------- recipes/newrelic/apm/php/redhat.yml | 19 ++++++++++++------- 2 files changed, 23 insertions(+), 14 deletions(-) diff --git a/recipes/newrelic/apm/php/debian.yml b/recipes/newrelic/apm/php/debian.yml index a89e2b408..e6e1c3b4d 100644 --- a/recipes/newrelic/apm/php/debian.yml +++ b/recipes/newrelic/apm/php/debian.yml @@ -208,19 +208,22 @@ install: read -r APPLICATION_RESTART APPLICATION_RESTART=${APPLICATION_RESTART:-y} - echo "$APPLICATION_NAME $APPLICATION_RESTART" > "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + echo "$APPLICATION_NAME" > "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + echo "$APPLICATION_RESTART" >> "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" fi # Interactive install with NEW_RELIC_APPLICATION_NAME envar set, uses envar and also defaults to service restart if [[ "{{.NEW_RELIC_ASSUME_YES}}" != "true" && ! -z $NEW_RELIC_APPLICATION_NAME ]]; then - echo "$NEW_RELIC_APPLICATION_NAME y" > "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + echo "$NEW_RELIC_APPLICATION_NAME" > "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + echo "y" >> "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" fi verify_continue: cmds: - | if [[ "{{.NEW_RELIC_ASSUME_YES}}" != "true" ]]; then - read -r APPLICATION_NAME APPLICATION_RESTART < "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + read -r APPLICATION_NAME < "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + read -r APPLICATION_RESTART < <(tail -n 1 "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}") else APPLICATION_NAME="{{.NEW_RELIC_APPLICATION_NAME}}" APPLICATION_RESTART="{{.NEW_RELIC_APPLICATION_RESTART}}" @@ -230,7 +233,8 @@ install: if [ -f "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" ]; then rm -f "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" 2>/dev/null fi - echo "$APPLICATION_NAME $APPLICATION_RESTART" > "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + echo "$APPLICATION_NAME" > "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + echo "$APPLICATION_RESTART" >> "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" fi echo -e "{{.WHITE}}Confirmation: The following options were selected. If you wish to change an option, please select 'n' at the prompt and restart the installation." @@ -486,7 +490,7 @@ install: # files. # - APPLICATION_NAME=$(cat "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" | cut -d' ' -f1 | xargs echo -n) + read -r APPLICATION_NAME < "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" INI_DIRS=($WEB_INI_DIR $CLI_INI_DIR) for dirs in $INI_DIRS; do for ini in $dirs; do @@ -529,7 +533,7 @@ install: APPLICATION_NAME=${APPLICATION_NAME//\&/\&} # Replace every occurrence of '&' with "\&" fi - sed -i "s/newrelic.appname = \"PHP Application\"/newrelic.appname = \"${APPLICATION_NAME}\"/" $ini_full_name + sed -i "s/newrelic.appname = \"[^\"]*\"/newrelic.appname = \"${APPLICATION_NAME}\"/" $ini_full_name if [ "{{.NEW_RELIC_REGION}}" = "STAGING" ]; then sed -i 's/;newrelic.daemon.collector_host = ""/newrelic.daemon.collector_host = "staging-collector.newrelic.com"/' $ini_full_name sed -i 's/;newrelic.loglevel = "info"/newrelic.loglevel = "verbosedebug"/' $ini_full_name @@ -595,7 +599,7 @@ install: # Case: apache only or nginx only, they respective service needs to be restarted. # This means only restart the first process in processes_to_restart.txt. # - APPLICATION_RESTART=$(cat "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" | cut -d' ' -f2 | xargs echo -n) + read -r APPLICATION_RESTART < <(tail -n 1 "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}") if [ "$APPLICATION_RESTART" = "y" ] && [ -f "{{.TMP_INSTALL_DIR}}/processes_to_restart.txt" ]; then cd {{.TMP_INSTALL_DIR}} read -r process user_name < "{{.TMP_INSTALL_DIR}}/processes_to_restart.txt" diff --git a/recipes/newrelic/apm/php/redhat.yml b/recipes/newrelic/apm/php/redhat.yml index f98caa58d..83da08fa7 100644 --- a/recipes/newrelic/apm/php/redhat.yml +++ b/recipes/newrelic/apm/php/redhat.yml @@ -190,19 +190,22 @@ install: read -r APPLICATION_RESTART APPLICATION_RESTART=${APPLICATION_RESTART:-y} - echo "$APPLICATION_NAME $APPLICATION_RESTART" > "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + echo "$APPLICATION_NAME" > "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + echo "$APPLICATION_RESTART" >> "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" fi # Interactive install with NEW_RELIC_APPLICATION_NAME envar set, uses envar and also defaults to service restart if [[ "{{.NEW_RELIC_ASSUME_YES}}" != "true" && ! -z $NEW_RELIC_APPLICATION_NAME ]]; then - echo "$NEW_RELIC_APPLICATION_NAME y" > "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + echo "$NEW_RELIC_APPLICATION_NAME" > "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + echo "y" >> "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" fi verify_continue: cmds: - | if [[ "{{.NEW_RELIC_ASSUME_YES}}" != "true" ]]; then - read -r APPLICATION_NAME APPLICATION_RESTART < "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + read -r APPLICATION_NAME < "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + read -r APPLICATION_RESTART < <(tail -n 1 "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}") else APPLICATION_NAME="{{.NEW_RELIC_APPLICATION_NAME}}" APPLICATION_RESTART="{{.NEW_RELIC_APPLICATION_RESTART}}" @@ -212,7 +215,8 @@ install: if [ -f "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" ]; then rm -f "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" 2>/dev/null fi - echo "$APPLICATION_NAME $APPLICATION_RESTART" > "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + echo "$APPLICATION_NAME" > "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" + echo "$APPLICATION_RESTART" >> "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" fi echo -e "{{.WHITE}}Confirmation: The following options were selected. If you wish to change an option, please select 'n' at the prompt and restart the installation." @@ -444,7 +448,7 @@ install: # Loop through all the directories where the installation placed `newrelic.ini` # files. # - APPLICATION_NAME=$(cat "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" | cut -d' ' -f1 | xargs echo -n) + read -r APPLICATION_NAME < "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" for ini in $WEB_INI_DIR $CLI_INI_DIR; do ini_full_name="${ini}/newrelic.ini" if [ ! -f "$ini_full_name" ]; then @@ -461,7 +465,8 @@ install: APPLICATION_NAME=${APPLICATION_NAME//\&/\&} # Replace every occurrence of '&' with "\&" fi - sed -i "s/newrelic.appname = \"PHP Application\"/newrelic.appname = \"${APPLICATION_NAME}\"/" $ini_full_name + + sed -i "s/newrelic\.appname = \"[^\"]*\"/newrelic.appname = \"${APPLICATION_NAME}\"/" $ini_full_name if [ "{{.NEW_RELIC_REGION}}" = "STAGING" ]; then sed -i 's/;newrelic.daemon.collector_host = ""/newrelic.daemon.collector_host = "staging-collector.newrelic.com"/' $ini_full_name fi @@ -486,7 +491,7 @@ install: # Case: apache only or nginx only, they respective service needs to be restarted. # This means only restart the first process in processes_to_restart.txt. # - APPLICATION_RESTART=$(cat "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}" | cut -d' ' -f2 | xargs echo -n) + read -r APPLICATION_RESTART < <(tail -n 1 "{{.TMP_INSTALL_DIR}}/{{.USER_INPUT}}") if [ "$APPLICATION_RESTART" = "y" ] && [ -f "{{.TMP_INSTALL_DIR}}/processes_to_restart.txt" ]; then cd {{.TMP_INSTALL_DIR}} read -r process user_name < "{{.TMP_INSTALL_DIR}}/processes_to_restart.txt"