#!/usr/bin/ksh
#####################################################################
# TITRE:	CFTRecepFic
#--------------------------------------------------------------------
# CREE LE:	12/11/94		Par: Johann CURE HP
#--------------------------------------------------------------------
# OBJET:  	Action automatique lorsqu'une reception ne se 
#		passe pas correctement	
#			
#====================================================================
# Modifie le:	JJ/MM/AA		Par: 
#	Motif: motif ayant justifie la modification et points
#	modifies si besoin
#
# 29/10/96	D.Stoll
# Pour gerer les serveurs sur lesquels plusieurs CFT sont installes
# ajout d'un parametre
#	$4 = nom du repertoire d'installation de CFT
#	(le compte CFT doit etre egal a 'adm$4')
# 
#====================================================================
# 19/12/96      V.Garreau
# nouveaux arguments pour un besoin de souplesse :
#       $1 : nom repertoire CFT
#       $2 : user admisnistration CFT
#       $3 : IDF
#       $4 : FNAME
#       $5 : PART
#####################################################################
# 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,SGI
# Environnement logiciel:
#	OS: hp-ux			Version: 9.05
#	    hp-ux				 10.20
#	    Solaris				 5.3
#	    Solaris				 5.5
#	    SunOs 				 4.1.3
#	    AIX					 3.x
#	    AIX					 4.2
#	    IRIX				 5.3
# Initialisation des variables globales (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
#	FonctionHPUX10
#	FonctionSunOS
#	FonctionSolaris
#	FonctionAIX
#	FonctionAIX42
#	FonctionIRIX
#####################################################################


# Definition des PATH :
export PATH_CFT=/logiciel/$1/filexe

# Recuperation des arguments et les exporter pour les commandes su
##################################################################
export User=$2
export IDF=$3
export FNAME=$4
export PART=$5

# Definition des variables globales locales script:
typeset TypeMachine                       # Recuperation de l'OS  	
typeset VersionOS                         # Recuperation de la version de l'OS 
typeset ReferenceFonction		  # Commande differente suivant l'OS

#####################################################################
# 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
#		FonctionHPUX10
#		FonctionSunOS 
#		FonctionSolaris
#		FonctionAIX
#		FonctionAIX42
#		FonctionIRIX
# CREEE LE:     12/12/94                Par: Johann CURE HP
# OBJET:        Ces 6 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:	Liste de toutes les transactions concernant le PART
#		et l'IDF donnes en parametre.
#
#####################################################################
# CONVENTION DES CODES RETOUR (autres que 0 (Ok) et 2 (Erreur))
#
#====================================================================
# Fonctions DU SCRIPT appelees
#
#####################################################################

function FonctionHPUX
	{
	su - ${User} -c "
		$PATH_CFT/CFTUTIL listcat type=all,part=$PART,idf=$IDF  "
	return 0 
	}

function FonctionHPUX10
	{
	FonctionHPUX
	return 0
	}

function FonctionSunOS
	{
	su - ${User} -c "
		$PATH_CFT/CFTUTIL listcat type=all,part=$PART,idf=$IDF  "
	return 0
	}

function FonctionSolaris
	{
	su - ${User} -c "
		$PATH_CFT/CFTUTIL listcat type=all,part=$PART,idf=$IDF  "
	return 0
	}

function FonctionAIX
	{
	su - ${User} -c "
		$PATH_CFT/CFTUTIL listcat type=all,part=$PART,idf=$IDF  "
	return 0
	}

function FonctionAIX42
	{
	FonctionAIX
	return 0
	}

function FonctionIRIX
	{
	su - ${User} -c "
		$PATH_CFT/CFTUTIL listcat type=all,part=$PART,idf=$IDF  "
	return 0
	}


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

# Test pour s'assurer de la presence du fichier LOCK
# Si ce dernier est absent pas besoin de continuer le programme
# CFT est arretee.
###############################################################
#[[ ! -f $PATH_CFT/LOCK ]] && echo toto && exit 0 

DeterminationOS

${ReferenceFonction}

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

exit  0
