#!/bin/bash
#------------------------------------------------------------------------------
# Copyright (c) Perforce Software, Inc., 2007-2014. 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.
#------------------------------------------------------------------------------

. /p4/common/bin/backup_functions.sh

LOGFILE=$LOGS/p4verify.log
STATUS="OK: All scanned depots verified OK."
declare -i EXIT_CODE=0
 
P4="$P4BIN -p $P4PORT -u $P4USER"
 
/p4/common/bin/p4login
 
echo If there are errors in this log, contact support@perforce.com > $LOGFILE
 
# Verify all depots of all types except 'remote' and 'archive'.
for d in `$P4 -s depots|grep "^info: Depot " |\
   grep -v --perl-regexp "^info: Depot \S+ \d{4}\/\d{2}\/\d{2} (remote|archive|unload) " |\
   cut -d ' ' -f 3`; do
   echo === Started verify of //$d/... at $(date). >> $LOGFILE
   if [[ "${P4REPLICA}" == "FALSE" ]]; then
      echo $P4 -s verify -qz //$d/... >> $LOGFILE
      $P4 -s verify -qz //$d/... >> $LOGFILE 2>&1
   else
      echo $P4 -s verify -qz -t //$d/... >> $LOGFILE
      $P4 -s verify -qz -t //$d/... >> $LOGFILE 2>&1
      $P4 changes -s shelved //$d/... | cut -d " " -f 2 | while read cl;do
         $P4 print //$d/...@=$cl > /dev/null
      done
   fi

   if [[ $? -ne 0 ]]; then
      STATUS="Error: Verify attempt failed.  Review the log [$LOGFILE]."
      EXIT_CODE=1
   fi

done

for d in `$P4 -s depots| grep "^info: Depot " | grep --perl-regexp "^info: Depot \S+ \d{4}\/\d{2}\/\d{2} unload" | cut -d " " -f 3 `; do
   echo === Started verify of //$d/... at $(date). >> $LOGFILE
   if [[ "${P4REPLICA}" == "FALSE" ]]; then
      echo $P4 -s verify -U -q //$d/... >> $LOGFILE
      $P4 -s verify -U -q //$d/... >> $LOGFILE 2>&1
   else
      echo $P4 -s verify -U -q -t //$d/... >> $LOGFILE
      $P4 -s verify -U -q -t //$d/... >> $LOGFILE 2>&1
   fi

   if [[ $? -ne 0 ]]; then
      STATUS="Error: Verify attempt failed.  Review the log [$LOGFILE]."
      EXIT_CODE=1
   fi

done



if [[ $EXIT_CODE -eq 0 ]]; then
   if [[ -n "$(grep BAD! $LOGFILE)" || -n "$(grep MISSING! $LOGFILE)" || -n "$(grep p4\ help\ max $LOGFILE)" ]]; then
       STATUS="Warning: Verify errors detected.  Review the log [$LOGFILE]."
       EXIT_CODE=1
   fi
fi
 
echo Completed verifications at $(date). >> $LOGFILE

mail_log_file "$HOSTNAME $P4SERVER P4Verify Log ($STATUS)"
 
exit $EXIT_CODE
