#!/usr/bin/ksh
#####################################################################
# TITRE:	ISDHASqlStat
#--------------------------------------------------------------------
# CREE LE:	06/10/1998		Par: S. Gislain
#--------------------------------------------------------------------
# OBJET:	Commandes tcpctl et fin du fichier orasrv.log pour
#		SAP.
#			
#====================================================================
# Modifie le:	JJ/MM/AA		Par: 
#	Motif: motif ayant justifie la modification et points
#	modifies si besoin
#		18/12/96		V. Garreau (HP)
#		ajout option -O sur tcpctl start sinon le log
#		n'est pas au bon endroit
#		13/01/1999		S. GISLAIN
#	Verification presence du fichier de log.
#
#####################################################################
# REMARQUES: Les entetes des fonctions ont ete allegees pour plus
#            de lisibilite (fonction de petite taille et presque
#            identiques
#
#####################################################################
# CONVENTION DES CODES DE RETOUR (autre aue 0 (Ok) et 1 (erreur)
#
#====================================================================
# ACCES ET DROITS D'APPEL
#	Mode: 0777	Owner: 			Group:
#====================================================================
# PRE-REQUIS EN ENTREE
# Environnement materiel:
#	Machine: 			Constructeur: HP,SUN,IBM 
# Environnement logiciel:
#	OS: hp-ux			Version: 9.05
#	    Solaris				 5.3
#	    SunOs 				 4.1.3
#	    AIX					 xxxxx 	
# Initialisation des variables gloables (environnement, reseau...):
#	VARIABLE1	=	
#	VARIABLE2	=
#####################################################################

#####################################################################
# INVENTAIRE DES APPELS EXTERNES
# Script(s) appelant(s) ce script: 
#	Operation Center
#--------------------------------------------------------------------
# Script(s) appele(s) par ce script:
#	Non Applicable	
#--------------------------------------------------------------------
# Fonction(s) appelee(s) par ce script:
# - Systeme:
#	Non Applicable	
# - Internes:
#	Non Applicable
#====================================================================
# Environnement et variables globales
# importes non modifies:
#	Non Applicable
#--------------------------------------------------------------------
# Importes modifies:
#	Non Applicable
#--------------------------------------------------------------------
# Exportes:
#	NOM_VARIABLE= Non Applicable
#####################################################################
# Fonctions internes au script
#	DeterminationOS 
#	FonctionHPUX
#	FonctionSunOS
#	FonctionSolaris
#	FonctionAIX
#####################################################################

# Definition des variables globales locales script:
typeset NomInstance=$1                    # nom de l(instance oracle
typeset TypeMachine                       # Recuperation de l'OS  	
typeset VersionOS                         # Recuperation de la version de l'OS 
typeset ReferenceFonction		  # Commande differente suivant l'OS
typeset CompteOracle=ora${NomInstance}	  # Nom du compte oracle
					  # Nom de l'instance en majuscules
typeset NOMINSTANCE=$(print ${NomInstance} | tr "a-z" "A-Z")

# Definition des PATH :
PATH_LOG=/oracle/${NOMINSTANCE}/network/log

#####################################################################
# FONCTION: 	DeterminationOS	
# CREEE LE:	12/12/94		Par: Johann CURE HP
# OBJET:	Cette fonction permet de connaitre l'OS sur lequel
#		le script se deroule
#====================================================================
# Modifiee le:	12/12/96		Par:  Vincent Garreau HP
#	Motif: prise en compte de nouvelles plate-formes HP, AIX, SOLARIS, IRIX
#####################################################################
# Modifiee le:	JJ/MM/AA		Par: 
#	Motif: motif ayant justifie la modification et points
#	modifies si besoin
#####################################################################
# REMARQUES:
# 
#####################################################################
# CONVENTION DES CODES RETOUR (autres que 0 (Ok) et 2 (Erreur))
#
#====================================================================
# Fonctions DU SCRIPT appelees
#
#####################################################################
function DeterminationOS
{
	TypeMachine=$(uname -s)           # Recuperation de l'OS  	
	VersionOS=$(uname -rv)            # Recuperation de la version de l'OS 

	case ${TypeMachine} in
	HP-UX)
		if [[ "$(echo $VersionOS|cut -d. -f2)" = "10" || "$(echo $VersionOS|cut -d. -f2)" = "11" ]]
			then ReferenceFonction=FonctionHPUX10
			else ReferenceFonction=FonctionHPUX
		fi
		;;
	SunOS)
		if [ "$(echo $VersionOS|cut -c1,2)" = "5." ] ; then
				TypeMachine="Solaris"
				ReferenceFonction=FonctionSolaris
		else	
				ReferenceFonction=FonctionSunOS
		fi
		;;
	AIX)
		if [ "$(echo $VersionOS|cut -c 3,3)" = "4" ] 
			then ReferenceFonction=FonctionAIX42
			else ReferenceFonction=FonctionAIX
		fi
		;;
	IRIX)
		ReferenceFonction=FonctionIRIX
		;;

	*)	
		print "$TypeMachine non supporte par ce programme"
		exit 2
		;;
	esac
	return 0
}
#####################################################################
# FONCTION:     FonctionHP-UX
#		FonctionSunOS 
#		FonctionSolaris
#		FonctionAIX
# CREEE LE:     12/12/94                Par: Johann CURE HP
# OBJET:        Ces 4 fonctions execute les instructions propres a
#		chaque systeme pour obtenir les memes resultats 
#====================================================================
# Modifiee le:  JJ/MM/AA                Par:
#       Motif: motif ayant justifie la modification et points
#       modifies si besoin
#####################################################################
# REMARQUES: 	Connection en tant que administrateur Oracle.
#		Je redemarre le process orasrv et j'affiche les
#		status de ce dernier.
#		Puis j'affiche le 10 dernieres lignes du fichier
#		orasrv.log.
#
#####################################################################
# CONVENTION DES CODES RETOUR (autres que 0 (Ok) et 2 (Erreur))
#
#====================================================================
# Fonctions DU SCRIPT appelees
#
#####################################################################


function FonctionHPUX
	{
	FonctionSolaris
	return $?
	}

function FonctionHPUX10
	{
	FonctionHPUX
	return $?
	}

function FonctionSunOS
	{
	FonctionSolaris
	return $?
	}

function FonctionSolaris
	{
	print "\n\n----------------------------------------\n"

	print "Processus Oracle :\n"

	ps -fu ${CompteOracle}

	print "\n----------------------------------------\n"

	print "Statut du listener Oracle de ${CompteOracle} : lsnrctl status\n"

	su - ${CompteOracle} -c "lsnrctl status"

	print "\n----------------------------------------\n"

	if [ -f ${PATH_LOG}/listener.log ]
	then
		print "Fin du fichier ${PATH_LOG}/listener.log :\n"

   		tail ${PATH_LOG}/listener.log
	else
		print "Le fichier ${PATH_LOG}/listener.log n'existe pas !!!"
	fi

	print "\n\n----------------------------------------\n"

	return $?
	}

function FonctionAIX
	{
	FonctionSolaris
	return $?
	}

function FonctionAIX42
	{
	FonctionSolaris
	return $?
	}

function FonctionIRIX
	{
	FonctionSolaris
	return $?
	}

####################################################################
#			PROGRAMME PRINCIPAL
####################################################################

DeterminationOS

${ReferenceFonction}

if [ $? -ne 0 ]
	then
	echo "Probleme sur le programme $0." 1>&2
	exit 1
fi
	 
exit  0
