# hms_load_and_verify.sh Version=1.0.11 #============================================================================== # Copyright and license info is available in the LICENSE file included with # the Server Deployment Package (SDP), and also available online: # https://swarm.workshop.perforce.com/projects/perforce_software-hms/view/main/LICENSE #------------------------------------------------------------------------------ #============================================================================== # HMS Library Functions. #------------------------------------------------------------------------------ # Function: load_helix_topology # # Input: # $1 - Helix Topology file path # $2 - Helix Topology file required format version. # # The following global arrays are updated: # # * InstanceUserPorts associative array # * InstanceMasterHost associative array # * InstanceServerPort associative array # * InstanceBrokerPort associative array # * InstanceManaged associative array # * InstanceDesc associative array # # Instance definition: # Form: INSTANCE|Name|UserPorts|MasterHost|ServerPort|BrokerPort|Managed|Desc # Example: # INSTANCE|fgs|perforce:1666|helix-01|1999|1666|Friendly Greeting Systems # # Return: # 0 - Instances loaded, syntax verified. # 1 - Errors detected. #------------------------------------------------------------------------------ function load_helix_topology { vvmsg "CALL: load_helix_topology($*)" declare cfgFile=$1 declare reqVersion=$2 declare cfgVersion= declare instance= declare instanceUserPorts= declare instanceMasterHost= declare instanceServerPort= declare instanceBrokerPort= declare instanceManaged= declare instanceDesc= declare instanceComponents= declare componentName= declare componentType= declare componentMasterHost= declare componentURL= declare componentBackupHost= declare componentManaged= declare componentDesc= declare failoverPathName= declare failoverFQName= declare failoverType= declare failoverMasterHost= declare failoverBackupHost= declare failoverInstanceList= declare failoverActive= declare line= declare -a errors declare -i errorCount=0 declare -i i declare -i lineCount=0 msg "Loading instances from [$cfgFile]." if [[ ! -r "$cfgFile" ]]; then errmsg "Cannot read Helix Topology file [$cfgFile]." return 1 fi # The first action is artifically hard-coded to START_IMPORT. while read line; do lineCount+=1 case $line in (\#*|NAME*) continue;; (GLOBAL_OPTIONS*) GlobalOptions=$(echo $line|cut -d '=' -f 2) ;; (VERSION*) cfgVersion=$(echo $line | cut -d '=' -f 2) if [[ "$cfgVersion" > "$reqVersion" ]]; then msg "Verified: Helix Topology file version [$cfgVersion] meets minimum requirement." else errors[$errorCount]="Helix Topology file version [$cfgVersion] is too old. Must be at least ${reqVersion}.0." errorCount+=1 fi ;; (INSTANCE*) # INSTANCE|Name|UserPorts|MasterHost|ServerPort|BrokerPort|Managed|Desc instance="$(echo $line | cut -d '|' -f 2)" instanceUserPorts="$(echo $line | cut -d '|' -f 3)" instanceMasterHost="$(echo $line | cut -d '|' -f 4)" instanceServerPort="$(echo $line | cut -d '|' -f 5)" instanceBrokerPort="$(echo $line | cut -d '|' -f 6)" instanceManaged="$(echo $line | cut -d '|' -f 7)" instanceDesc="$(echo $line | cut -d '|' -f 8)" vvmsg "DBG: Instance=$instance" InstanceUserPorts[$instance]=$instanceUserPorts InstanceMasterHost[$instance]=$instanceMasterHost InstanceServerPort[$instance]=$instanceServerPort InstanceBrokerPort[$instance]=$instanceBrokerPort InstanceManaged[$instance]=$instanceManaged InstanceDesc[$instance]=$instanceDesc vvmsg "DBG: InstanceName=$instance" vvmsg "DBG: InstanceUserPorts[$instance]=${InstanceUserPorts[$instance]}" vvmsg "DBG: InstanceMasterHost[$instance]=${InstanceMasterHost[$instance]}" vvmsg "DBG: InstanceServerPort[$instance]=${InstanceServerPort[$instance]}" vvmsg "DBG: InstanceBrokerPort[$instance]=${InstanceBrokerPort[$instance]}" vvmsg "DBG: InstanceManaged[$instance]=${InstanceManaged[$instance]}" vvmsg "DBG: InstanceDesc[$instance]=${InstanceDesc[$instance]}" ;; (COMPONENT*) # COMPONENT|Instance|Type|Name|MasterHost|BackupHost|Managed|URL|Desc instance="$(echo $line | cut -d '|' -f 2)" componentType="$(echo $line | cut -d '|' -f 3)" componentName="$(echo $line | cut -d '|' -f 4)" componentMasterHost="$(echo $line | cut -d '|' -f 5)" componentBackupHost="$(echo $line | cut -d '|' -f 6)" componentManaged="$(echo $line | cut -d '|' -f 7)" componentURL="$(echo $line | cut -d '|' -f 8)" componentDesc="$(echo $line | cut -d '|' -f 9)" componentFQName="$instance:$componentName" vvmsg "DBG: componentFQName=$componentFQName" vvmsg "DBG: componentType=$componentType" vvmsg "DBG: componentMasterHost=$componentMasterHost" vvmsg "DBG: componentBackupHost=$componentBackupHost" vvmsg "DBG: componentManaged=$componentManaged" vvmsg "DBG: componentURL=$componentURL" vvmsg "DBG: componentDesc=$componentDesc" # Maintain the InstanceComponents associative array (indexed by instance name) # as a space-separated list of components. componentList="${InstanceComponents[$instance]:-Unset}" if [[ $componentList == Unset ]]; then InstanceComponents[$instance]=$componentName else InstanceComponents[$instance]="$componentList $componentName" fi ComponentType[$componentFQName]=$componentType ComponentMasterHost[$componentFQName]=$componentMasterHost ComponentURL[$componentFQName]=$componentURL ComponentBackupHost[$componentFQName]=$componentBackupHost ComponentManaged[$componentFQName]=$componentManaged ComponentDesc[$componentFQName]=$componentDesc ;; (FAILOVER*) # FAILOVER|Name|Type|MasterHost|BackupHost|InstanceList|Active|Desc failoverPathName="$(echo $line | cut -d '|' -f 2)" failoverType="$(echo $line | cut -d '|' -f 3)" failoverMasterHost="$(echo $line | cut -d '|' -f 4)" failoverBackupHost="$(echo $line | cut -d '|' -f 5)" failoverInstanceList="$(echo $line | cut -d '|' -f 6)" failoverActive="$(echo $line | cut -d '|' -f 7)" failoverDesc="$(echo $line | cut -d '|' -f 8)" for instance in $(echo $failoverInstanceList|tr ',' ' '); do vvmsg "DBG: I=$instance" # Maintain the InstanceComponents associative array (indexed by instance name) # as a space-separated list of failover options. failoverOptionList="${InstanceFailoverOptions[$instance]:-Unset}" if [[ $failoverOptionList == Unset ]]; then InstanceFailoverOptions[$instance]=$failoverPathName else InstanceFailoverOptions[$instance]="$failoverOptionList $failoverPathName" fi failoverFQName="$instance:$failoverPathName" FailoverType[$failoverFQName]=$failoverType FailoverMasterHost[$failoverFQName]=$failoverMasterHost FailoverBackupHost[$failoverFQName]=$failoverBackupHost FailoverInstanceList[$failoverFQName]=$failoverInstanceList FailoverActive[$failoverFQName]=$failoverActive FailoverDesc[$failoverFQName]=$failoverDesc done ;; esac done < $cfgFile if [[ $errorCount -eq 0 ]]; then msg "\nVerified: All data passed sanity checks." else msg "\nThe following problems were identified:" i=0; while [[ $i -lt $errorCount ]]; do errmsg "${errors[$i]}" i+=1 done fi if [[ $errorCount -eq 0 ]]; then return 0 else return 1 fi } #------------------------------------------------------------------------------ function show_helix_topology { vvmsg "CALL: show_helix_topology($*)" declare -i i msg "${H}\nLoaded ${#InstanceManaged[*]} instances:\n" printf "%-3s %-16s %-40s %-4s %-5s %-2s %-40s %-s\n" "#" "Instance" "User Ports" "P4D" "P4B" "On" "User P4PORTs" "Description" printf "%-3s %-16s %-40s %-4s %-5s %-2s %-40s %-s\n" "---" "---------------" "---------------------------------------" "----" "-----" "--" "----------------------------------------" "------------------------------------------------" i=1; for instance in ${!InstanceManaged[*]}; do printf "%2d. %-16s %-40s %-4s %-5s %2d %-40s %-s\n" "$i" "$instance" "${InstanceUserPorts[$instance]}" "${InstanceServerPort[$instance]}" "${InstanceBrokerPort[$instance]}" "${InstanceManaged[$instance]}" "${InstanceUserPorts[$instance]}" "${InstanceDesc[$instance]}" i+=1 done for instance in ${!InstanceManaged[*]}; do msg "${H}\nFailover options for Instance $instance:\n" printf "%-3s %-9s %-5s %-16s %-16s %-36s %-2s %-s\n" "#" "Path Name" "Type" "Master Host" "Backup Host" "Instance List" "On" "Description" printf "%-3s %-9s %-5s %-16s %-16s %-36s %-2s %-s\n" "---" "---------" "-----" "----------------" "----------------" "------------------------------------" "--" "----------------------------------------" i=1; for f in ${!FailoverActive[*]}; do [[ $f == "$instance:"* ]] || continue vvmsg "DBG: F=$f" printf "%2d. %-9s %-5s %-16s %-16s %-36s %2d %-s\n" "$i" "${f#*:}" "${FailoverType[$f]}" "${FailoverMasterHost[$f]}" "${FailoverBackupHost[$f]}" "${FailoverInstanceList[$f]}" "${FailoverActive[$f]}" "${FailoverDesc[$f]}" i+=1 done done for instance in ${!InstanceManaged[*]}; do msg "${H}\nComponents for Instance $instance:\n" printf "%-3s %-19s %-9s %-24s %-24s %-2s %-36s %-s\n" "#" "Name" "Type" "Master Host" "Backup Host" "M" "Port/URL" "Description" printf "%-3s %-19s %-9s %-24s %-24s %-2s %-36s %-s\n" "---" "-------------------" "---------" "------------------------" "------------------------" "--" "------------------------------------" "------------------------------" i=1; for f in ${!ComponentManaged[*]}; do [[ $f == "$instance:"* ]] || continue vvmsg "DBG: F=$f" printf "%2d. %-19s %-9s %-24s %-24s %2d %-36s %-s\n" "$i" "${f#*:}" "${ComponentType[$f]}" "${ComponentMasterHost[$f]}" "${ComponentBackupHost[$f]}" "${ComponentManaged[$f]}" "${ComponentURL[$f]}" "${ComponentDesc[$f]}" i+=1 done done }
# | Change | User | Description | Committed | |
---|---|---|---|---|---|
#4 | 29182 | C. Thomas Tyler |
Moved HMS files from /p4/common/bin -> /p4/common/site/bin. Moved HMS files from /p4/common/lib -> /p4/common/site/lib. Removed dependency on SDP libs so that HMS can be deployed with a wider variety of SDP versions. |
||
#3 | 27694 | C. Thomas Tyler | Copyright Update; non-functional change. | ||
#2 | 25533 | C. Thomas Tyler |
Copied updated and new files from SDP into the new HMS "overlay" structure. A 'p4 copy' was done in all cases, so files in this change match what they did in the SDP. Corresponding files in the SDP are to be deleted. Some files will need modification to adapt to the new HMS structure, e.g. the 'setup' tree. |
||
#1 | 25531 | C. Thomas Tyler |
Refactored to receive merge from SDP. This structure emphasizes that HMS will be layered on the SDP. The tree is now structured to make it clear where files appear in an as-deployed configurtion, overlaid into the '/p4/common' structure of the SDP. The test suite is outside this structure, as it will not be deployed (due to dependencies on infratructure that won't likely appear in SDP production deployments). |
||
//guest/perforce_software/hms/dev/hms/lib/hms_load_and_verify.sh | |||||
#1 | 20312 | ttyler | Populate -o -b hms_sg_to_workshop. |