#!/bin/bash #------------------------------------------------------------------------------ # Copyright (c) Perforce Software, Inc., 2007-2015. All rights reserved # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are met: # # 1 Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # # 2. Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in the # documentation and/or other materials provided with the distribution. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS # FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL PERFORCE # SOFTWARE, INC. BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON # ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR # TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF # THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH # DAMAGE. #------------------------------------------------------------------------------ set -u # p4login generates a login ticket for the SDP super user. It is called # from cron scripts, and so does not normally generate output to stdout or # stderr. # # Normally output (stdout and stderr) is logged in $LOGS/p4login.log, # unless unless SDP_INSTANCE isn't defined, in which case it bails # immediately. # # An exit code of 0 indicates a valid login ticket exists, while a # non-zero exit code indicates a failure to login. export SDP_INSTANCE=${SDP_INSTANCE:-Undefined} declare DateFormat='%a %Y-%m-%d %H:%M:%S %Z' function bail () { echo -e "\nError: ${1:-Unknown Error}"; exit ${2:-1}; } [[ $SDP_INSTANCE == Undefined ]] && bail "Error: SDP_INSTANCE not defined." declare TicketExpiration=$($P4BIN -ztag -F %TicketExpiration% -p $P4PORT -u $P4USER login -s 2>/dev/null) declare Log=$LOGS/p4login.log echo "$(date +'%a %Y-%m-%d %H:%M:%S %Z'): Checking login status." > $Log if [[ $TicketExpiration =~ [0-9]+ ]]; then # A 'long-term' ticket is one that expires more than a month (31 days + 1 second) from now. if [[ $TicketExpiration -ge 2678401 ]]; then echo "$(date +'%a %Y-%m-%d %H:%M:%S %Z'): Verified: User $P4USER logged into $P4PORT with a long-term ticket. Login not required." >> $Log exit 0 else echo "$(date +'%a %Y-%m-%d %H:%M:%S %Z'): Warning: User $P4USER logged into $P4PORT with a short-term ticket. Attempting to extend." >> $Log echo Running: $P4BIN -p $P4PORT -u $P4USER -s login -a >> /p4/${SDP_INSTANCE}/logs/p4login.log 2>&1 $P4BIN -p $P4PORT -u $P4USER -s login -a < /p4/common/bin/adminpass >> /p4/${SDP_INSTANCE}/logs/p4login.log 2>&1 exit $? fi else echo "$(date +'%a %Y-%m-%d %H:%M:%S %Z'): Warning: User $P4USER is not logged into $P4PORT. Attempting to login." >> $Log echo Running: $P4BIN -p $P4PORT -u $P4USER -s login -a >> /p4/${SDP_INSTANCE}/logs/p4login.log 2>&1 $P4BIN -p $P4PORT -u $P4USER -s login -a < /p4/common/bin/adminpass >> /p4/${SDP_INSTANCE}/logs/p4login.log 2>&1 exit $? fi