2012-08-07 13:31:35 +00:00
< ? php
require_once 'WsScore/WsScore.php' ;
require_once realpath ( dirname ( __FILE__ )) . '/Types.php' ;
class Gestion extends WsScore
{
/**
* Récupère les informations du profil connecté
* @ param string $login
* @ param string $ipUtilisateur
* @ return InfosLoginReturn
*/
public function getInfosLogin ( $login , $ipUtilisateur = '' )
{
$this -> authenticate ();
//Initialisation
if ( empty ( $ipUtilisateur )) $ipUtilisateur = $_SERVER [ 'REMOTE_ADDR' ];
$error = new ErrorType ();
$result = new InfosLogin ();
//Filtre IP
$filtre = trim ( $this -> tabInfoUser [ 'filtre_ip' ]);
if ( ! empty ( $filtre ) && ! checkPlagesIp ( $filtre , $ipUtilisateur ) ){
debugLog ( 'I' , " getInfosLogin Adresse IP $ipUtilisateur non declaree pour le compte $login " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$this -> sendError ( '0904' );
}
debugLog ( 'I' , " getInfosLogin pour $login (IP= $ipUtilisateur ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
//L'utilisateur qui demande les informations est différent
if ( $this -> tabInfoUser [ 'login' ] <> $login
&& in_array ( $this -> tabInfoUser [ 'profil' ], array ( 'Administrateur' , 'SuperAdministrateur' ) )
) {
/** Un administrateur veut il des infos sur un login ? **/
$iDbCrm = new WDB ( 'sdv1' );
$rep = $iDbCrm -> select (
'utilisateurs u, clients c' ,
'u.login, u.id, u.email, u.password, u.idClient, u.typeCompte, u.actif, u.filtre_ip, u.civilite, u.nom, u.prenom, u.tel, u.fax, u.mobile, u.profil, u.raisonSociale, u.siret, u.adrNum, u.adrIndRep, u.adrTypeVoie, u.adrLibVoie, u.adrCp, u.adrVille, u.adrComp, u.tel, u.fax, u.mobile, u.pref, u.profil, u.dateInscription, u.dateValidation, u.nombreConnexions, u.dateDerniereConnexion, u.droits, u.referenceParDefaut, u.nbReponses, u.formatMail, u.dateDebutCompte, u.dateFinCompte, u.maxFicheId, c.droits AS droitsClients, c.test AS clientTest, c.timeout, c.typeScore AS typeScore' ,
" u.login=' $login ' AND u.idClient=c.id AND u.deleted=0 " ,
false , MYSQL_ASSOC
);
$tabRep = $rep [ 0 ];
if ( count ( $rep ) > 0 )
{
$timeOutSec = $tabRep [ 'timeout' ];
if ( $timeOutSec == 0 ) $timeOutSec = 1800 ;
$result -> login = $login ;
$result -> id = $tabRep [ 'id' ];
$result -> email = $tabRep [ 'email' ];
$result -> typeCompte = $tabRep [ 'typeCompte' ];
$result -> idClient = $tabRep [ 'idClient' ];
$result -> filtre_ip = $tabRep [ 'filtre_ip' ];
$result -> civilite = $tabRep [ 'civilite' ];
$result -> nom = $tabRep [ 'nom' ];
$result -> prenom = $tabRep [ 'prenom' ];
$result -> raisonSociale = $tabRep [ 'raisonSociale' ];
$result -> siret = $tabRep [ 'siret' ];
$result -> adrNum = $tabRep [ 'adrNum' ];
$result -> adrIndRep = $tabRep [ 'adrIndRep' ];
$result -> adrTypeVoie = $tabRep [ 'adrTypeVoie' ];
$result -> adrLibVoie = $tabRep [ 'adrLibVoie' ];
$result -> adrCp = $tabRep [ 'adrCp' ];
$result -> adrVille = $tabRep [ 'adrVille' ];
$result -> adrComp = $tabRep [ 'adrComp' ];
$result -> tel = $tabRep [ 'tel' ];
$result -> fax = $tabRep [ 'fax' ];
$result -> mobile = $tabRep [ 'mobile' ];
$result -> pref = $tabRep [ 'pref' ];
$result -> profil = $tabRep [ 'profil' ];
$result -> dateInscription = $tabRep [ 'dateInscription' ];
$result -> dateValidation = $tabRep [ 'dateValidation' ];
$result -> nombreConnexions = $tabRep [ 'nombreConnexions' ];
$result -> dateDerniereConnexion = $tabRep [ 'dateDerniereConnexion' ];
$result -> droits = $tabRep [ 'droits' ];
$result -> droitsClients = $tabRep [ 'droitsClients' ];
$result -> timeout = $timeOutSec ;
$result -> clientTest = $tabRep [ 'clientTest' ];
$result -> typeScore = $tabRep [ 'typeScore' ];
$result -> nbReponses = $tabRep [ 'nbReponses' ];
$result -> formatMail = $tabRep [ 'formatMail' ];
$result -> reference = $tabRep [ 'referenceParDefaut' ];
$result -> dateDebutCompte = $tabRep [ 'dateDebutCompte' ];
$result -> dateFinCompte = $tabRep [ 'dateFinCompte' ];
$result -> maxFicheId = $tabRep [ 'maxFicheId' ];
} else {
/** On log l'erreur d'authentification **/
$tabInsert = array (
'login' => $login ,
'page' => 'infosLogin' ,
'params' => 'Erreur Login/Password' ,
'ipClient' => $ipUtilisateur );
$iDbCrm -> insert ( 'logs' , $tabInsert );
}
}
//Authentification de l'utilisateur
else
{
$ref = 'OK' ;
//Identification utilisateur
$connected = true ;
$result -> connected = $connected ;
$result -> login = $this -> tabInfoUser [ 'login' ];
$result -> id = $this -> tabInfoUser [ 'id' ];
$result -> idClient = $this -> tabInfoUser [ 'idClient' ];
$result -> email = $this -> tabInfoUser [ 'email' ];
$result -> typeCompte = $this -> tabInfoUser [ 'typeCompte' ];
$result -> filtre_ip = $this -> tabInfoUser [ 'filtre_ip' ];
$result -> ipPasserelle = $this -> tabInfoUser [ 'ipConnexion' ];
$result -> ipConnexion = $ipUtilisateur ;
$result -> civilite = $this -> tabInfoUser [ 'civilite' ];
$result -> nom = $this -> tabInfoUser [ 'nom' ];
$result -> prenom = $this -> tabInfoUser [ 'prenom' ];
$result -> raisonSociale = $this -> tabInfoUser [ 'raisonSociale' ];
$result -> siret = $this -> tabInfoUser [ 'siret' ];
$result -> adrNum = $this -> tabInfoUser [ 'adrNum' ];
$result -> adrIndRep = $this -> tabInfoUser [ 'adrIndRep' ];
$result -> adrTypeVoie = $this -> tabInfoUser [ 'adrTypeVoie' ];
$result -> adrLibVoie = $this -> tabInfoUser [ 'adrLibVoie' ];
$result -> adrCp = $this -> tabInfoUser [ 'adrCp' ];
$result -> adrVille = $this -> tabInfoUser [ 'adrVille' ];
$result -> adrComp = $this -> tabInfoUser [ 'adrComp' ];
$result -> tel = $this -> tabInfoUser [ 'tel' ];
$result -> fax = $this -> tabInfoUser [ 'fax' ];
$result -> mobile = $this -> tabInfoUser [ 'mobile' ];
$result -> pref = $this -> tabInfoUser [ 'pref' ];
$result -> profil = $this -> tabInfoUser [ 'profil' ];
$result -> dateInscription = $this -> tabInfoUser [ 'dateInscription' ];
$result -> dateValidation = $this -> tabInfoUser [ 'dateValidation' ];
$result -> nombreConnexions = $this -> tabInfoUser [ 'nombreConnexions' ];
$result -> dateDerniereConnexion = $this -> tabInfoUser [ 'dateDerniereConnexion' ];
$result -> droits = $this -> tabInfoUser [ 'droits' ];
$result -> droitsClients = $this -> tabInfoUser [ 'droitsClients' ];
$result -> timeout = $this -> tabInfoUser [ 'timeout' ];
$result -> clientTest = $this -> tabInfoUser [ 'clientTest' ];
$result -> typeScore = $this -> tabInfoUser [ 'typeScore' ];
$result -> nbReponses = $this -> tabInfoUser [ 'nbReponses' ];
$result -> formatMail = $this -> tabInfoUser [ 'formatMail' ];
$result -> reference = $this -> tabInfoUser [ 'referenceParDefaut' ];
$result -> dateDebutCompte = $this -> tabInfoUser [ 'dateDebutCompte' ];
$result -> dateFinCompte = $this -> tabInfoUser [ 'dateFinCompte' ];
$result -> maxFicheId = $this -> tabInfoUser [ 'maxFicheId' ];
$result -> typeScore = $this -> tabInfoUser [ 'typeScore' ];
$result -> acceptationCGU = $this -> tabInfoUser [ 'acceptationCGU' ];
// On log l'accès à l'authentification
if ( $this -> tabInfoUser [ 'clientTest' ] == 'Oui' || $this -> tabInfoUser [ 'typeCompte' ] == 'TEST' ) {
$test = 1 ;
} else {
$test = 0 ;
}
$tabInsert = array (
'login' => $this -> tabInfoUser [ 'login' ],
'idClient' => $this -> tabInfoUser [ 'idClient' ],
'page' => 'infosLogin' ,
'params' => $ref ,
'test' => $test ,
'ipClient' => $ipUtilisateur
);
$iDbCrm = new WDB ( 'sdv1' );
$iDbCrm -> insert ( 'logs' , $tabInsert );
//Date de dernière connexion
$iDbCrm -> update ( 'utilisateurs' ,
array ( 'dateDerniereConnexion' => date ( 'Y-m-d H:i:s' )),
" idClient= " . $this -> tabInfoUser [ 'idClient' ] . " AND login=' " . $this -> tabInfoUser [ 'login' ] . " ' "
);
}
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
//Retour
$output = new InfosLoginReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* Mise à jour des informations du profil connecté
* @ param string $login
* @ param string $action ( delete | enable | disable | changepwd | new | update )
* @ param string $infos
* @ return boolean
*/
public function setInfosLogin ( $login , $action , $infos = null )
{
$this -> authenticate ();
//Initialisation
$result = false ;
$infos = json_decode ( $infos , true );
switch ( $action )
{
case 'delete' :
if ( $this -> tabInfoUser [ 'profil' ] == 'Administrateur'
|| $this -> tabInfoUser [ 'profil' ] == 'SuperAdministrateur' ) {
$tabUpdate = array ( 'deleted' => 1 , 'dateUpdate' => date ( 'Y-m-d H:i:s' ) );
$iDbCrm = new WDB ( 'sdv1' );
if ( $iDbCrm -> update ( 'utilisateurs' , $tabUpdate , " login=' $login ' " )){
$result = true ;
}
}
break ;
case 'enable' :
case 'disable' :
if ( $this -> tabInfoUser [ 'profil' ] == 'Administrateur'
|| $this -> tabInfoUser [ 'profil' ] == 'SuperAdministrateur' ) {
$actif = 1 ;
if ( $action == 'disable' ) {
$actif = 0 ;
}
$tabUpdate = array ( 'actif' => $actif , 'dateUpdate' => date ( 'YmdHis' ) );
$iDbCrm = new WDB ( 'sdv1' );
if ( $iDbCrm -> update ( 'utilisateurs' , $tabUpdate , " login=' $login ' " )){
$result = true ;
}
}
break ;
case 'changepwd' :
$tabUpdate = array (
'password' => stripslashes ( $infos [ 'password' ]),
'dateUpdate' => date ( 'Y-m-d H:i:s' )
);
$iDbCrm = new WDB ( 'sdv1' );
if ( $iDbCrm -> update ( 'utilisateurs' , $tabUpdate , " login=' $login ' " , true )){
$result = true ;
}
break ;
case 'new' :
if ( $this -> tabInfoUser [ 'profil' ] == 'Administrateur'
|| $this -> tabInfoUser [ 'profil' ] == 'SuperAdministrateur' )
{
$tabUpdate = array ();
$idClient = $this -> tabInfoUser [ 'idClient' ];
if ( $this -> tabInfoUser [ 'profil' ] == 'SuperAdministrateur' && $infos [ 'idClient' ] != '' ){
$idClient = $infos [ 'idClient' ];
}
$tabUpdate [ 'idClient' ] = $idClient ;
$tabUpdate [ 'login' ] = $login ;
$tabUpdate [ 'email' ] = strtolower ( stripslashes ( $infos [ 'email' ]));
$tabUpdate [ 'password' ] = stripslashes ( $infos [ 'password' ]);
$tabUpdate [ 'actif' ] = 0 ;
$tabUpdate [ 'deleted' ] = 0 ;
$typeCompte = 'PROD' ;
if ( $this -> tabInfoUser [ 'profil' ] == 'SuperAdministrateur' && $infos [ 'typeCompte' ] == 'TEST' ){
$typeCompte = 'TEST' ;
}
$tabUpdate [ 'typeCompte' ] = $typeCompte ;
//@todo : See issue #0001209
/*
if ( $this -> tabInfoUser [ 'profil' ] == 'SuperAdministrateur' && ! empty ( $infos [ 'filtre_ip' ])) {
$tabUpdate [ 'filtre_ip' ] = $infos [ 'filtre_ip' ];
} else {
$rep = $iDbCrm -> select ( 'clients' , 'filtre_ip' , " id=' $idClinet ' " , false , MYSQL_ASSOC );
$tabUpdate [ 'filtre_ip' ] = $rep [ 0 ][ 'filtre_ip' ];
}
*/
//$tabUpdate['civilite'] = 'M';
$tabUpdate [ 'nom' ] = stripslashes ( $infos [ 'nom' ]);
$tabUpdate [ 'prenom' ] = stripslashes ( $infos [ 'prenom' ]);
//$tabUpdate['raisonSociale'] = '';
//$tabUpdate['siret'] = 00000000;
//adrNum
//adrIndRep
//adrTypeVoie
//adrLibVoie
//adrCp
//adrVille
//adrComp
$tabUpdate [ 'tel' ] = stripslashes ( $infos [ 'tel_fix' ]);
$tabUpdate [ 'fax' ] = stripslashes ( $infos [ 'tel_fax' ]);
$tabUpdate [ 'mobile' ] = stripslashes ( $infos [ 'tel_mob' ]);
$tabUpdate [ 'pref' ] = implode ( ' ' , $infos [ 'pref' ]);
$tabUpdate [ 'profil' ] = ( isset ( $infos [ 'profil' ])
|| ! in_array ( $infos -> profil , array ( 'SuperAdministrateur' , 'Administrateur' , 'Utilisateur' )) ) ?
$infos [ 'profil' ] : 'Utilisateur' ;
//dateInscription
//dateValidation
//nombreConnexions 0
//dateDerniereConnexion
$tabUpdate [ 'droits' ] = implode ( ' ' , $infos [ 'droits' ]);
$tabUpdate [ 'referenceParDefaut' ] = stripslashes ( $infos [ 'reference' ]);
$tabUpdate [ 'nbReponses' ] = $infos [ 'nbReponses' ];
if ( $this -> tabInfoUser [ 'profil' ] == 'SuperAdministrateur' ) {
$tabUpdate [ 'formatMail' ] = $infos [ 'formatMail' ];
$tabUpdate [ 'lienExtranetMail' ] = $infos [ 'lienExtranetMail' ];
$tabUpdate [ 'listeEven' ] = $infos [ 'listeEven' ];
$tabUpdate [ 'dateDebutCompte' ] = $infos [ 'dateDebutCompte' ];
$tabUpdate [ 'dateFinCompte' ] = $infos [ 'dateFinCompte' ];
$tabUpdate [ 'accesWS' ] = $infos [ 'accesWS' ];
$tabUpdate [ 'rechRefType' ] = $infos [ 'rechRefType' ];
}
//lienSurvFic
//idSurvFic
//loginCptSurvFic
$tabUpdate [ 'dateInsert' ] = date ( 'YmdHis' );
//dateUpdate => MySql automatic update
$iDbCrm = new WDB ( 'sdv1' );
if ( $iDbCrm -> insert ( 'utilisateurs' , $tabUpdate )){
$result = true ;
}
}
break ;
case 'update' :
2013-01-10 08:51:55 +00:00
//Don't update password if nothing is send
2012-08-07 13:31:35 +00:00
if ( ! empty ( $infos [ 'password' ])){
$tabUpdate [ 'password' ] = stripslashes ( $infos [ 'password' ]);
}
//Only this data could be updated by the user himself
$tabUpdate [ 'email' ] = stripslashes ( $infos [ 'email' ]);
$tabUpdate [ 'tel' ] = stripslashes ( $infos [ 'tel_fix' ]);
$tabUpdate [ 'fax' ] = stripslashes ( $infos [ 'tel_fax' ]);
$tabUpdate [ 'mobile' ] = stripslashes ( $infos [ 'tel_mb' ]);
$tabUpdate [ 'nbReponses' ] = $infos [ 'nbReponses' ];
$tabUpdate [ 'pref' ] = implode ( ' ' , $infos [ 'pref' ]);
//User with Administrateur or SuperAdministrateur can update these data
if ( $this -> tabInfoUser [ 'profil' ] == 'Administrateur'
|| $this -> tabInfoUser [ 'profil' ] == 'SuperAdministrateur' )
{
$tabUpdate [ 'droits' ] = implode ( ' ' , $infos [ 'droits' ]);
$tabUpdate [ 'nom' ] = stripslashes ( $infos [ 'nom' ]);
$tabUpdate [ 'prenom' ] = stripslashes ( $infos [ 'prenom' ]);
$tabUpdate [ 'referenceParDefaut' ] = stripslashes ( $infos [ 'reference' ]);
$tabUpdate [ 'profil' ] = isset ( $infos [ 'profil' ]) ? $infos [ 'profil' ] : 'Utilisateur' ;
}
//Only update as SuperAdministrateur
if ( $this -> tabInfoUser [ 'profil' ] == 'SuperAdministrateur' )
{
$typeCompte = 'PROD' ;
if ( $this -> tabInfoUser [ 'profil' ] == 'SuperAdministrateur' && $infos [ 'typeCompte' ] == 'TEST' ){
$typeCompte = 'TEST' ;
}
$tabUpdate [ 'typeCompte' ] = $typeCompte ;
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
$formatMail = 'txt1' ;
if ( ! empty ( $infos [ 'formatMail' ]) ) {
$formatMail = $infos [ 'formatMail' ];
}
$tabUpdate [ 'formatMail' ] = $formatMail ;
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
if ( array_key_exists ( 'lienExtranetMail' , $infos ) && ! empty ( $infos [ 'lienExtranetMail' ])) {
$tabUpdate [ 'lienExtranetMail' ] = $infos [ 'lienExtranetMail' ];
}
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
if ( array_key_exists ( 'listeEven' , $infos ) && ! empty ( $infos [ 'listeEven' ])) {
$tabUpdate [ 'listeEven' ] = $infos [ 'listeEven' ];
}
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
if ( array_key_exists ( 'dateDebutCompte' , $infos ) && ! empty ( $infos [ 'dateDebutCompte' ])) {
$tabUpdate [ 'dateDebutCompte' ] = $infos [ 'dateDebutCompte' ];
}
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
if ( array_key_exists ( 'dateFinCompte' , $infos ) && ! empty ( $infos [ 'dateFinCompte' ])) {
$tabUpdate [ 'dateFinCompte' ] = $infos [ 'dateFinCompte' ];
}
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
if ( array_key_exists ( 'accesWS' , $infos ) && ! empty ( $infos [ 'accesWS' ])) {
$tabUpdate [ 'accesWS' ] = $infos [ 'accesWS' ];
}
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
$rechRefType = 'UTI' ;
if ( array_key_exists ( 'rechRefType' , $infos ) && ! empty ( $infos [ 'rechRefType' ])) {
$rechRefType = $infos [ 'rechRefType' ];
}
$tabUpdate [ 'rechRefType' ] = $rechRefType ;
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
}
$tabUpdate [ 'dateUpdate' ] = date ( 'YmdHis' );
$iDbCrm = new WDB ( 'sdv1' );
if ( $iDbCrm -> update ( 'utilisateurs' , $tabUpdate , " login=' $login ' " , true )){
$result = true ;
}
break ;
default : $result = false ; break ;
}
return $result ;
}
/**
* Obtention automatique d ' un nouveau login pour un client
* @ param int idClient
* @ return NextLoginReturn
*/
public function getNextLogin ( $idClient )
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
if ( $this -> tabInfoUser [ 'profil' ] == 'Administrateur'
|| $this -> tabInfoUser [ 'profil' ] == 'SuperAdministrateur' )
{
/** Un administrateur veut créer un nouveau login **/
$iDbCrm = new WDB ( 'sdv1' );
2012-08-16 11:38:23 +00:00
$rep = $iDbCrm -> select ( 'clients c' , 'c.racineLogin, c.droits' , " c.id=' $idClient ' " );
2012-08-07 13:31:35 +00:00
$racine = $rep [ 0 ][ 'racineLogin' ];
$droitsClients = $rep [ 0 ][ 'droits' ];
2012-08-16 11:38:23 +00:00
$rep = $iDbCrm -> select ( 'utilisateurs' , 'login' , " idClient=' $idClient ' " );
2012-08-07 13:31:35 +00:00
if ( count ( $rep ) == 0 ) {
$racine .= '1' ;
} else {
2012-08-16 11:38:23 +00:00
$last_i = count ( $rep );
2012-08-07 13:31:35 +00:00
$racine .= $last_i + 1 ;
}
$result = new NextLoginResult ();
$result -> racine = $racine ;
$result -> idClient = $idClient ;
$result -> droitsClients = $droitsClients ;
} else {
$error -> errnum = 0 ;
$error -> errmsg = 'Acces non authorisé!' ;
}
$output = new NextLoginReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* Récupère la liste des clients ou les informations d ' un client
* @ param integer | boolean $idClient
* @ param ClientFiltre $filtre
* @ return ListeClientsReturn
*/
public function getListeClients ( $idClient = false , $filtre = null )
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
if ( empty ( $idClient )) $idClient = false ;
$isAuthorized = false ;
if ( $this -> tabInfoUser [ 'profil' ] == 'Administrateur' &&
( $idClient == 'false' || $idClient == $this -> tabInfoUser [ 'idClient' ])){
$idClient = $this -> tabInfoUser [ 'idClient' ];
$isAuthorized = true ;
}
if ( $this -> tabInfoUser [ 'profil' ] <> 'SuperAdministrateur' ){
$error -> errnum = 1 ;
$error -> errmsg = 'Profil non administrateur' ;
} else {
$isAuthorized = true ;
}
if ( $isAuthorized )
{
$strClient = '' ;
if ( is_numeric ( $idClient )) $strClient .= " AND id=' $idClient ' " ;
$iDbCrm = new WDB ( 'sdv1' );
$rep = $iDbCrm -> select ( 'clients' ,
'id, nom, actif, test, racineLogin, siren, nic, tva, editerFacture, fact_detail, fac_dest, fac_adr1, fac_adr2, fac_adr3, fac_email, fac_tel, fact_rib, liv_dest, liv_adr1, liv_adr2, liv_adr3, liv_email, liv_tel, droits, filtres_ip, dateInsert, dateUpdate, respComSD, typeContrat, dateSignature, typeAcces, typeScore, timeout, accesPieces, accesKbis, accesInvestigations, accesInternationnal, accesEnquetes, miseSousSurveillance, forfaitExtranetPeriode, forfaitExtranetMontant, reconductionAuto, remarque, forfaitPiecesNb, forfaitPiecesMt, forfaitPiecesDep, forfaitInvestigNb, forfaitInvestigMt, forfaitInvestigDep, tarifIndiscore' ,
" 1 $strClient " ,
false ,
MYSQL_ASSOC );
$tabRet = array ();
foreach ( $rep as $uti )
{
$client = new Client ();
$client -> idClient = $uti [ 'id' ];
$client -> nom = $uti [ 'nom' ];
$client -> actif = $uti [ 'actif' ];
$client -> test = $uti [ 'test' ];
$client -> racineLogin = $uti [ 'racineLogin' ];
$client -> siren = $uti [ 'siren' ];
$client -> nic = $uti [ 'nic' ];
$client -> tva = $uti [ 'tva' ];
$client -> editerFacture = $uti [ 'editerFacture' ];
$client -> fact_detail = $uti [ 'fact_detail' ];
$client -> fac_dest = $uti [ 'fac_dest' ];
$client -> fac_adr1 = $uti [ 'fac_adr1' ];
$client -> fac_adr2 = $uti [ 'fac_adr2' ];
$client -> fac_adr3 = $uti [ 'fac_adr3' ];
$client -> fac_email = $uti [ 'fac_email' ];
$client -> fac_tel = $uti [ 'fac_tel' ];
$client -> fact_rib = $uti [ 'fact_rib' ];
$client -> liv_dest = $uti [ 'liv_dest' ];
$client -> liv_adr1 = $uti [ 'liv_adr1' ];
$client -> liv_adr2 = $uti [ 'liv_adr2' ];
$client -> liv_adr3 = $uti [ 'liv_adr3' ];
$client -> liv_email = $uti [ 'liv_email' ];
$client -> liv_tel = $uti [ 'liv_tel' ];
$client -> droits = strtolower ( $uti [ 'droits' ]);
$client -> timeout = $uti [ 'timeout' ];
$client -> filtres_ip = $uti [ 'filtres_ip' ];
$client -> dateInsert = $uti [ 'dateInsert' ];
$client -> dateUpdate = $uti [ 'dateUpdate' ];
$client -> respComSD = $uti [ 'respComSD' ];
$client -> typeContrat = $uti [ 'typeContrat' ];
$client -> dateSignature = $uti [ 'dateSignature' ];
$client -> typeAcces = $uti [ 'typeAcces' ];
$client -> typeScore = $uti [ 'typeScore' ];
$client -> accesPieces = $uti [ 'accesPieces' ];
$client -> accesKbis = $uti [ 'accesKbis' ];
$client -> accesInvestigations = $uti [ 'accesInvestigations' ];
$client -> accesInternationnal = $uti [ 'accesInternationnal' ];
$client -> accesEnquetes = $uti [ 'accesEnquetes' ];
$client -> miseSousSurveillance = $uti [ 'miseSousSurveillance' ];
$client -> forfaitExtranetPeriode = $uti [ 'forfaitExtranetPeriode' ];
$client -> forfaitExtranetMontant = $uti [ 'forfaitExtranetMontant' ];
$client -> reconductionAuto = $uti [ 'reconductionAuto' ];
$client -> remarque = $uti [ 'remarque' ];
$client -> forfaitPiecesNb = $uti [ 'forfaitPiecesNb' ];
$client -> forfaitPiecesMt = $uti [ 'forfaitPiecesMt' ];
$client -> forfaitPiecesDep = $uti [ 'forfaitPiecesDep' ];
$client -> forfaitInvestigNb = $uti [ 'forfaitInvestigNb' ];
$client -> forfaitInvestigMt = $uti [ 'forfaitInvestigMt' ];
$client -> forfaitInvestigDep = $uti [ 'forfaitInvestigDep' ];
$client -> tarifIndiscore = $uti [ 'tarifIndiscore' ];
$tabRet [] = $client ;
}
}
$output = new ListeClientsReturn ();
$output -> error = $error ;
$output -> result = $tabRet ;
return $output ;
}
/**
* Retourne la liste des droits
* @ return ListeDroitsReturn []
*/
public function getListeDroits ()
{
$tabRet = array ();
foreach ( $this -> listeDroits as $code => $desc ){
$droit = new ListeDroitsReturn ();
$droit -> code = $code ;
$droit -> desc = $desc ;
$tabRet [] = $droit ;
}
return $tabRet ;
}
2012-12-26 10:13:05 +00:00
2012-09-13 12:58:01 +00:00
/**
* Catégorie des accès
* @ param string $code
2012-09-20 07:50:38 +00:00
* @ return ListCategoryReturn []
2012-09-13 12:58:01 +00:00
*/
public function getCategory ( $code = null )
{
$tabRet = array ();
foreach ( $this -> listeCategory as $code => $desc ){
$c = new ListCategoryReturn ();
$c -> code = $code ;
$c -> desc = $desc [ 'label' ];
$c -> droits = $desc [ 'droits' ];
$tabRet [] = $c ;
}
return $tabRet ;
}
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
/**
* Retourne la liste des préférences
* @ return ListePrefsReturn []
*/
public function getListePrefs ()
{
$tabRet = array ();
foreach ( $this -> listePrefs as $code => $desc ){
$pref = new ListePrefsReturn ();
$pref -> code = $code ;
$pref -> desc = $desc ;
$tabRet [] = $pref ;
}
return $tabRet ;
}
2012-12-26 10:13:05 +00:00
2012-10-09 07:33:43 +00:00
/**
* Retourne la liste des logs
* @ return ListeLogsReturn []
*/
protected function getLogs ()
{
$tabRet = array ();
foreach ( $this -> logs as $code => $desc ){
$log = new ListeLogsReturn ();
$log -> code = $code ;
$log -> desc = $desc ;
$tabRet [] = $log ;
}
return $tabRet ;
}
2012-08-07 13:31:35 +00:00
/**
* Récupère les informations du profil connecté
* @ param string $login
* @ param int $idClient
* @ return ListeUtilisateursReturn
*/
public function getListeUtilisateurs ( $login , $idClient = null )
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
$tabRet = array ();
if ( $this -> tabInfoUser [ 'profil' ] <> 'Administrateur' &&
$this -> tabInfoUser [ 'profil' ] <> 'SuperAdministrateur' )
{
$error -> errnum = 1 ;
$error -> errmsg = 'Profil non administrateur' ;
} else {
$iDbCrm = new WDB ( 'sdv1' );
if ( ! isset ( $idClient )){
$rep = $iDbCrm -> select ( 'utilisateurs' , 'idClient' , " login=' $login ' " );
$idClient = $rep [ 0 ][ 0 ];
}
if ( $idClient ==- 1 ) {
$error -> errnum = 1 ;
$error -> errmsg = 'idClient=0' ;
} else {
$rep = $iDbCrm -> select (
'utilisateurs' ,
'id, idClient, login, email, actif, nom, prenom, referenceParDefaut' ,
" idClient=' $idClient ' AND deleted=0 ORDER BY login ASC " ,
false , MYSQL_ASSOC );
foreach ( $rep as $uti ){
$utilisateur = new Utilisateur ();
$utilisateur -> idUti = $uti [ 'id' ];
$utilisateur -> idClient = $uti [ 'idClient' ];
$utilisateur -> login = $uti [ 'login' ];
$utilisateur -> email = $uti [ 'email' ];
$utilisateur -> actif = $uti [ 'actif' ];
$utilisateur -> nom = $uti [ 'nom' ];
$utilisateur -> prenom = $uti [ 'prenom' ];
$utilisateur -> reference = $uti [ 'referenceParDefaut' ];
$tabRet [] = $utilisateur ;
}
}
}
$output = new ListeUtilisateursReturn ();
$output -> error = $error ;
$output -> result = $tabRet ;
return $output ;
}
/**
* getLogsClients
* @ param string $mois ( Format : AAAA - MM ou AAAA / MM )
* @ param int $detail
* @ param int $idClient
* @ param string $login
* @ param int $all
* @ return LogsClientsReturn
*/
public function getLogsClients ( $mois , $detail = 0 , $idClient = 0 , $login = '' , $all = 0 )
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
if ( empty ( $detail )) $detail = 0 ;
if ( empty ( $idClient )) $idClient = 0 ;
if ( empty ( $login )) $login = '' ;
if ( empty ( $all )) $all = 0 ;
$strDetail = $strClient = $strLogin = '' ;
// Vue détaillée ou uniquement les infos payantes
if ( $detail == 0 ) {
$detail = 'Non' ;
//$strDetail=" AND (page LIKE 'greffe_%' OR page LIKE 'inpi_%' OR page='kbis' OR page LIKE 'indiscore%' OR page='privileges' OR page='commandeAsso') AND (params<>'' OR page LIKE 'indiscore%' AND tarifIndiscore<>0) AND (params NOT LIKE '%erreur%' OR params LIKE '%erreur 17%') ";
$strDetail = ' AND ( ' ;
$pages = array ( 'greffe_actes' , 'greffe_bilans' , 'kbis' , 'indiscore' , 'indiscore2' , 'indiscore3' , 'rapport2' , 'rapport3' , 'privileges' , 'privcumul' );
$totalPages = count ( $pages );
$i = 0 ;
foreach ( $pages as $page ) {
switch ( $page )
{
case 'greffe_actes' :
case 'greffe_bilans' :
$strDetail .= " (l.page = ' " . $page . " ' AND l.params<>'' AND (l.params NOT LIKE '%erreur%' OR l.params LIKE '%erreur 17%')) " ;
break ;
case 'kbis' :
$strDetail .= " (l.page = ' " . $page . " ' AND l.params<>'' AND l.params<>'1/1/0//' AND l.params<>'0/1/0//') " ;
break ;
default :
$strDetail .= " (l.page = ' " . $page . " ') " ;
break ;
}
$i ++ ;
if ( $i < $totalPages ) {
$strDetail .= ' OR ' ;
}
}
$strDetail .= ' ) ' ;
} elseif ( $detail == 1 ) {
$detail = 'Oui' ;
}
// On veut uniquement le client précis
if ( $all && $this -> tabInfoUser [ 'profil' ] == 'SuperAdministrateur' ) {
$all = 'Oui' ;
} else {
$all = 'Non' ;
}
// Pas d'idClient mentionné ou tentative sur autre client et non SAD
if ( $idClient == 0 || ( $idClient != $this -> tabInfoUser [ 'idClient' ] && $this -> tabInfoUser [ 'profil' ] != 'SuperAdministrateur' ) ){
$idClient = $this -> tabInfoUser [ 'idClient' ];
}
$strClient = " AND u.idClient= $idClient " ;
// On veut uniquement le login précis
if ( $login != '' ) {
$strLogin = " AND l.login=' $login ' " ;
} else {
$login = 'Non' ;
}
// Dates de début et de fin
$mois = strtr ( $mois , array ( '-' => '' , '/' => '' ));
$annee = substr ( $mois , 0 , 4 );
$mois = substr ( $mois , 4 , 2 );
$dateDeb = date ( 'Y-m-d' , mktime ( 0 , 0 , 0 , $mois , 1 , $annee ));
$dateFin = date ( 'Y-m-t' , mktime ( 0 , 0 , 0 , $mois , 15 , $annee ));
2012-11-30 13:51:48 +00:00
$c = Zend_Registry :: get ( 'config' );
$fichierCsv = $c -> profil -> path -> files . " /logs- $annee - $mois - $detail - $idClient - $login - $all .csv " ;
2012-08-07 13:31:35 +00:00
2012-11-30 13:51:48 +00:00
if ( file_exists ( $fichierCsv )
&& date ( 'Ymd' , filemtime ( $fichierCsv )) == date ( 'Ymd' )
&& filesize ( $fichierCsv ) > 60 ) {
2012-08-07 13:31:35 +00:00
$size = filesize ( $fichierCsv );
$erreur = false ;
$tabNom = array ();
$cache = 1 ;
} else {
@ unlink ( $fichierCsv );
$sql = " SELECT LOWER(l.login) as loginUti, page, l.siren, l.nic, l.params, l.dateHeure, u.idClient, c.nom, u.referenceParDefaut AS refUti
FROM `logs` l , utilisateurs u , clients c
WHERE 1 $strDetail $strClient $strLogin AND dateHeure BETWEEN '$dateDeb 00:00:00' AND '$dateFin 23:59:59' AND l . login = u . login AND u . idClient = c . id
GROUP BY l . login , l . siren , l . page , date ( dateHeure ), l . params
ORDER BY l . login ASC , l . dateHeure ASC " ;
2012-11-30 13:51:48 +00:00
$fp = fopen ( $c -> profil -> path -> cache . " /logs- $annee - $mois - $detail - $idClient - $login - $all .sql " , 'w' );
2012-08-07 13:31:35 +00:00
fwrite ( $fp , $sql . EOL );
fclose ( $fp );
2012-11-30 13:51:48 +00:00
exec ( " php " . $c -> profil -> path -> batch . " /sql2csv.php sdv1 " . $c -> profil -> path -> cache . " /logs- $annee - $mois - $detail - $idClient - $login - $all .sql $fichierCsv > /dev/null & " );
2012-08-07 13:31:35 +00:00
$size = $cache = 0 ;
}
$hostname = 'http://' . $_SERVER [ 'SERVER_NAME' ];
if ( $_SERVER [ 'SERVER_PORT' ] != '80' ){
$hostname .= ':' . $_SERVER [ 'SERVER_PORT' ];
}
$result = new LogsClients ();
2012-11-30 13:51:48 +00:00
$result -> Url = $hostname . " /fichier/logs/logs- $annee - $mois - $detail - $idClient - $login - $all .csv " ;
2012-08-07 13:31:35 +00:00
$result -> Taille = $size ;
$result -> Cache = $cache ;
$output = new LogsClientsReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* Création / Modification d ' un client
* @ param string $infos
* @ return ClientReturn
*/
public function setClient ( $infos )
{
$this -> authenticate ();
$result = false ;
//Pas SuperAdministrateur
if ( $this -> tabInfoUser [ 'profil' ] != 'SuperAdministrateur' ) {
throw new SoapFault ( 1 , 'Profil insuffisant pour cette méthode' );
} else {
$infos = json_decode ( $infos );
/**
* - Protéger les chaines de caractères
* - Gérer les champs select
*/
$idClient = null ;
$tabInfos = array ();
foreach ( $infos as $nom => $value )
{
switch ( $nom )
{
case 'idClient' :
$idClient = $value ;
break ;
case 'nom' :
$tabInfos [ 'nom' ] = $value ;
break ;
case 'actif' :
$tabInfos [ 'actif' ] = ( $value == 'Oui' ) ? 'Oui' : 'Non' ;
break ;
case 'test' :
$tabInfos [ 'test' ] = ( $value == 'Oui' ) ? 'Oui' : 'Non' ;
break ;
case 'racineLogin' :
$tabInfos [ 'racineLogin' ] = $infos -> racineLogin ;
break ;
case 'siren' :
$tabInfos [ 'siren' ] = ( int ) $value ;
break ;
case 'nic' :
$tabInfos [ 'nic' ] = ( int ) $value ;
break ;
case 'tva' :
$tabInfos [ 'tva' ] = $value ;
break ;
case 'idClientFacture' :
$tabInfos [ 'idClientFacture' ] = $value ;
break ;
case 'editerFacture' :
$tabInfos [ 'editerFacture' ] = ( $value == 'Non' ) ? 'Non' : 'Oui' ;
break ;
case 'fact_detail' :
$tabInfos [ 'fact_detail' ] = ( $value == 'Oui' ) ? 'Oui' : 'Non' ;
break ;
case 'fac_dest' :
$tabInfos [ 'fac_dest' ] = $value ;
break ;
case 'fac_adr1' :
$tabInfos [ 'fac_adr1' ] = $value ;
break ;
case 'fac_adr2' :
$tabInfos [ 'fac_adr2' ] = $value ;
break ;
case 'fac_adr3' :
$tabInfos [ 'fac_adr3' ] = $value ;
break ;
case 'fac_email' :
$tabInfos [ 'fac_email' ] = $value ;
break ;
case 'fac_tel' :
$tabInfos [ 'fac_tel' ] = $value ;
break ;
case 'fact_rib' :
if ( in_array ( $value , array ( 'BPOSTALE' , 'CCOOP' , 'CDNORD' ))){
$tabInfos [ 'fact_rib' ] = $value ;
}
break ;
case 'liv_dest' :
$tabInfos [ 'liv_dest' ] = $value ;
break ;
case 'liv_adr1' :
$tabInfos [ 'liv_adr1' ] = $value ;
break ;
case 'liv_adr2' :
$tabInfos [ 'liv_adr2' ] = $value ;
break ;
case 'liv_adr3' :
$tabInfos [ 'liv_adr3' ] = $value ;
break ;
case 'liv_email' :
$tabInfos [ 'liv_email' ] = $value ;
break ;
case 'liv_tel' :
$tabInfos [ 'liv_tel' ] = $value ;
break ;
case 'droits' :
if ( count ( $value ) > 0 ){
$tabInfos [ 'droits' ] = strtolower ( implode ( ' ' , $value ));
} else {
$tabInfos [ 'droits' ] = array ();
}
break ;
case 'filtres_ip' :
$tabInfos [ 'filtres_ip' ] = $value ;
break ;
case 'typeContrat' :
if ( in_array ( $value , array ( 'Contrat' , 'Marché' ))){
$tabInfos [ 'typeContrat' ] = $value ;
}
break ;
case 'typeAcces' :
if ( in_array ( $value , array ( 'userPassword' , 'userPasswordIP' , 'IP' ))){
$tabInfos [ 'typeAcces' ] = $value ;
}
break ;
case 'typeScore' :
if ( in_array ( $value , array ( '20' , '100' ))){
$tabInfos [ 'typeScore' ] = $value ;
}
break ;
case 'timeout' :
if ( ! empty ( $value )){
$tabInfos [ 'timeout' ] = $value ;
}
break ;
case 'accesPieces' :
$tabInfos [ 'accesPieces' ] = ( $value == 'Oui' ) ? 'Oui' : 'Non' ;
break ;
case 'accesKbis' :
$tabInfos [ 'accesKbis' ] = ( $value == 'Oui' ) ? 'Oui' : 'Non' ;
break ;
case 'accesInvestigations' :
$tabInfos [ 'value' ] = ( $value == 'Oui' ) ? 'Oui' : 'Non' ;
break ;
case 'accesInternationnal' :
$tabInfos [ 'accesInternationnal' ] = ( $value == 'Oui' ) ? 'Oui' : 'Non' ;
break ;
case 'accesEnquetes' :
$tabInfos [ 'accesEnquetes' ] = ( $value == 'Oui' ) ? 'Oui' : 'Non' ;
break ;
case 'miseSousSurveillance' :
$tabInfos [ 'miseSousSurveillance' ] = ( $value == 'Oui' ) ? 'Oui' : 'Non' ;
break ;
case 'forfaitExtranetPeriode' :
if ( in_array ( $value , array ( 'Mensuel' , 'Trimestriel' , 'Semestriel' , 'Annuel' ))){
$tabInfos [ 'forfaitExtranetPeriode' ] = $value ;
}
break ;
case 'forfaitExtranetMontant' :
$tabInfos [ 'forfaitExtranetMontant' ] = $value ;
break ;
case 'reconductionAuto' :
if ( $value == 'Non' ) {
$tabInfos [ 'reconductionAuto' ] = 'Non' ;
}
break ;
case 'remarque' :
$tabInfos [ 'remarque' ] = $value ;
break ;
case 'forfaitPiecesNb' :
$tabInfos [ 'forfaitPiecesNb' ] = $value ;
break ;
case 'forfaitPiecesMt' :
$tabInfos [ 'forfaitPiecesMt' ] = $value ;
break ;
case 'forfaitPiecesDep' :
$tabInfos [ 'forfaitPiecesDep' ] = $value ;
break ;
case 'forfaitInvestigNb' :
$tabInfos [ 'forfaitInvestigNb' ] = $value ;
break ;
case 'forfaitInvestigMt' :
$tabInfos [ 'forfaitInvestigMt' ] = $value ;
break ;
case 'forfaitInvestigDep' :
$tabInfos [ 'forfaitInvestigDep' ] = $value ;
break ;
case 'tarifIndiscore' :
$tabInfos [ 'tarifIndiscore' ] = $value ;
break ;
case 'InterSudLogin' :
$tabInfos [ 'InterSudLogin' ] = $value ;
break ;
case 'InterSudPass' :
$tabInfos [ 'InterSudPass' ] = $value ;
break ;
}
}
$iDbCrm = new WDB ( 'sdv1' );
if ( empty ( $idClient )){
//Ajout
$tabInfos [ 'dateInsert' ] = date ( 'Y-m-d H:i:s' );
$result = $iDbCrm -> insert ( 'clients' , $tabInfos , true );
} else {
//Droits client actuel avant modification
if ( isset ( $tabInfos [ 'droits' ])){
$rep = $iDbCrm -> select ( 'clients' , 'droits' , " id=' $idClient ' " , false , MYSQL_ASSOC );
$droitsPre = explode ( ' ' , $rep [ 0 ][ 'droits' ]);
$droitsSui = explode ( ' ' , $tabInfos [ 'droits' ]);
//Détection suppression d'un droit client
if ( count ( $droitsSui ) < count ( $droitsPre )){
$droitsDiff = array_diff ( $droitsPre , $droitsSui );
//Modification sur les droits utilisateurs
$update = array ();
if ( count ( $droitsDiff ) > 0 ){
foreach ( $droitsDiff as $droit ){
$query = " UPDATE utilisateurs set droits=TRIM(REPLACE(droits, ' $droit ', '')) WHERE idClient=' $idClient ' " ;
$iDbCrm -> query ( $query , true );
}
}
}
}
//Modification
$tabInfos [ 'dateUpdate' ] = date ( 'Y-m-d H:i:s' );
if ( $iDbCrm -> update ( 'clients' , $tabInfos , " id=' $idClient ' " , true )){
$result = true ;
}
}
}
$output = new ClientReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
2012-12-26 10:13:05 +00:00
protected function setClientService ( $idClient , $code = null , $label = null )
{
}
2012-08-07 13:31:35 +00:00
/**
* Création d ' un modele pour le préremplisage des données utilisateurs
* @ param integer $idClient
* @ param string $nom
* @ param ModeleUtilisateur $infos
* @ return ModeleUtilisateurReturn
*/
protected function setUserModel ( $idClient , $nom , $infos )
{
$this -> authenticate ();
}
/**
* Get all user params ( only for admin )
* @ param string $login
* @ return string
*/
public function getUser ( $login )
{
$this -> authenticate ();
if ( $this -> tabInfoUser [ 'profil' ] != 'SuperAdministrateur' ) {
$this -> sendError ( '0901' );
}
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> db -> sdv1 );
$userM = new Application_Model_Utilisateurs ( $db );
$sql = $userM -> select () -> where ( 'login = ?' , $login );
$rowset = $userM -> fetchRow ( $sql );
if ( $rowset ) {
$user = $rowset -> toArray ();
return json_encode ( $user );
} else {
throw new SoapFault ( '1' , 'Erreur' );
}
} catch ( Zend_Db_Exception $e ) {
throw new SoapFault ( 'Database' , $e -> getMessage ());
}
}
/**
* Création / Modification d ' utilisateurs
* @ param integer $idClient
* @ param SetUtilisateurs [] $users
* @ return UtilisateursReturn
*/
protected function setUsers ( $idClient , $users )
{
$this -> authenticate ();
$error = new ErrorType ();
$result = false ;
//idClient existe
$iDbCrm = new WDB ( 'sdv1' );
$rep = $iDbCrm -> select ( 'clients' , 'id, nom, actif, test, racineLogin, siren, nic, droits, filtres_ip, typeAcces, typeScore, accesPieces, accesKbis, accesInvestigations, accesInternationnal, accesEnquetes, miseSousSurveillance' , " 1 AND id=' $idClient ' " , false , MYSQL_ASSOC );
if ( count ( $rep ) > 0 ){
$client = $rep [ 0 ];
$idClient = $client [ 'id' ];
if ( count ( $users ) > 0 ){
foreach ( $users as $user ){
$tabInfos = array ();
$tabInfos [ 'idClient' ] = $idClient ;
$tabInfos [ 'login' ] = $user -> login ;
$tabInfos [ 'email' ] = '' ;
$tabInfos [ 'password' ] = $user -> password ;
$tabInfos [ 'actif' ] = '' ;
//$tabInfos['deleted'] = '';
if ( in_array ( $user -> typeCompte , array ( 'TEST' , 'PROD' ))){
$tabInfos [ 'typeCompte' ] = $user -> typeCompte ;
} else {
$tabInfos [ 'typeCompte' ] = 'PROD' ;
}
//$tabInfos['filtre_ip'] = '';
//SetInfosLogin
$tabInfos [ 'civilite' ] = '' ;
$tabInfos [ 'nom' ] = '' ;
$tabInfos [ 'prenom' ] = '' ;
//Identique au client
$tabInfos [ 'raisonSociale' ] = '' ;
$tabInfos [ 'siret' ] = '' ;
$tabInfos [ 'adrNum' ] = '' ;
$tabInfos [ 'adrInRep' ] = '' ;
$tabInfos [ 'adrTypeVoie' ] = '' ;
$tabInfos [ 'adrLibVoie' ] = '' ;
$tabInfos [ 'adrCp' ] = '' ;
$tabInfos [ 'adrVille' ] = '' ;
$tabInfos [ 'adrComp' ] = '' ;
$tabInfos [ 'tel' ] = '' ;
$tabInfos [ 'fax' ] = '' ;
$tabInfos [ 'mobile' ] = '' ;
$tabInfos [ 'pref' ] = '' ;
if ( in_array ( $user -> typeCompte , array ( 'Administrateur' , 'Utilisateur' ))){
$tabInfos [ 'profil' ] = $user -> profil ;
} else {
$tabInfos [ 'profil' ] = 'Utilisateur' ;
}
/*
$tabInfos [ 'dateInscription' ] = '' ;
$tabInfos [ 'dateValidation' ] = '' ;
*/
if ( empty ( $user -> droits )){
$tabInfos [ 'droits' ] = $client -> droits ;
} else {
$tabInfos [ 'droits' ] = $user -> droits ;
}
$tabInfos [ 'referenceParDefaut' ] = '' ;
$tabInfos [ 'nbReponses' ] = '' ;
$tabInfos [ 'listeEven' ] = '' ;
$tabInfos [ 'maxFicheId' ] = $user -> maxFicheId ;
//$tabInfos['dateInsert'] = '';
if ( empty ( $user -> id )){
$iDbCrm -> insert ( 'utilisateurs' , $tabInfos );
} else {
$iDbCrm -> update ( 'utilisateurs' , $tabInfos , " id=' $user->id ' " );
}
}
} else {
$error -> errnum = 1 ;
$error -> errmsg = 'Aucun utilisateur' ;
}
} else {
$error -> errnum = 1 ;
$error -> errmsg = 'Identifiant client inconnu!' ;
}
$output = new UtilisateursReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* Affecter aux utilisateurs les paramètres du client
* @ param integer $idClient
* @ param string $element
* @ param string [] $utilisateurs
* @ return boolean
*/
public function setClientsParamsOnUtilisateurs ( $idClient , $element = null , $utilisateurs = null )
{
$this -> authenticate ();
if ( $this -> tabInfoUser [ 'profil' ] != 'SuperAdministrateur' ) {
$this -> sendError ( '0901' );
}
if ( empty ( $element )){
throw new SoapFault ( 'Error' , 'Erreur dans les paramètres' );
}
switch ( strtolower ( $element )){
//Mettre à jour les ips des utilisateurs en fonction de celles du client
case 'ip' :
$iDbCrm = new WDB ( 'sdv1' );
$rep = $iDbCrm -> select ( 'clients' , 'filtre_ip' , " id=' $idClient ' " , false , MYSQL_ASSOC );
if ( count ( $rep ) == 0 ){
throw new SoapFault ( 'Error' , 'Client inexistant' );
}
$data = array (
'filtre_ip' => $rep [ 0 ][ 'filtre_ip' ],
'dateUpdate' => date ( 'Y-m-d H:i:s' ),
);
$where = ' WHERE idClient=' . $idClient ;
if ( ! empty ( $utilisateurs ) && is_array ( $utilisateurs -> item )){
$where .= ' AND login IN (' . join ( ',' , $utilisateurs -> item ) . ')' ;
}
if ( $iDbCrm -> update ( 'utilisateurs' , $data , $where )){
return true ;
}
return false ;
break ;
}
}
/**
* Enregistre l ' acceptation des CGU pour une application
* @ param string $application Nom de l ' outil utilisé
* @ return boolean
*/
public function setCGU ( $application = null )
{
$this -> authenticate ();
$idUser = $this -> tabInfoUser [ 'id' ];
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> db -> sdv1 );
$userM = new Application_Model_Utilisateurs ( $db );
$data = array ( 'acceptationCGU' => date ( 'YmdHis' ));
$result = $userM -> update ( $data , 'id=' . $idUser );
} catch ( Zend_Db_Exception $e ) {
throw new SoapFault ( 'Erreur' , $e -> getMessage ());
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'Erreur' , $e -> getMessage ());
}
if ( 1 == $result ) {
return true ;
}
return false ;
}
/**
* Definir la méthode de tarification
2012-10-17 06:20:39 +00:00
* @ param int $idClient Nom de l ' élément à facturer
* @ param ClientTarif $tarif Informations de facturation
* @ param int $id Identifiant pour l ' update
* @ return int
2012-08-07 13:31:35 +00:00
*/
2012-10-17 06:20:39 +00:00
public function setClientTarif ( $idClient , $tarif , $id = null )
2012-08-07 13:31:35 +00:00
{
/**
* Une tarification est toujours affecté à un élément $log .
* Celle ci est définie sur un compte client ( tous les utilisateurs ) ou un service ,
* Pour un type de facturation
* - Unitaire : Chaque élement est à facturer
* - Forfait limité : Si tarif unitaire > 0 alors on applique le prix unitaire pour chaque
* dépassement , sinon on coupe
* - Forfait illimité :
*/
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
$this -> authenticate ();
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
if ( $this -> tabInfoUser [ 'profil' ] != 'SuperAdministrateur' ) {
$this -> sendError ( '0902' );
2012-10-17 06:20:39 +00:00
}
2012-08-07 13:31:35 +00:00
2012-10-17 06:20:39 +00:00
if ( ! in_array ( $tarif -> log , array_keys ( $this -> logs ))) {
2012-08-07 13:31:35 +00:00
throw new SoapFault ( 'ClientTarif' , 'log inexistant' );
}
2012-12-26 10:13:05 +00:00
2012-10-17 06:20:39 +00:00
if ( ! in_array ( $tarif -> type , array ( 'Unitaire' , 'ForfaitLimit' , 'ForfaitNoLimit' ))) {
2012-08-07 13:31:35 +00:00
throw new SoapFault ( 'ClientTarif' , 'Erreur type' );
}
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
if ( ! in_array ( $tarif -> doublon , array ( 'jour' , 'mois' , 'period' ))) {
throw new SoapFault ( 'ClientTarif' , 'Erreur doublon' );
}
2012-12-26 10:13:05 +00:00
2012-10-17 06:20:39 +00:00
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> db -> sdv1 );
$db -> getConnection ();
} catch ( Zend_Db_Adapter_Exception $e ) {
if ( $this -> tabInfoUser [ 'idClient' ] != 1 ) {
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
$time = mktime ( 0 , 0 , 0 , substr ( $tarif -> date , 4 , 2 ), substr ( $tarif -> date , 6 , 2 ), substr ( $tarif -> date , 0 , 4 ));
2012-12-26 10:13:05 +00:00
2012-08-07 13:31:35 +00:00
$data = array (
2012-10-17 06:20:39 +00:00
'idClient' => $idClient ,
2012-08-07 13:31:35 +00:00
'service' => $tarif -> service ,
'log' => $tarif -> log ,
'type' => $tarif -> type ,
'priceUnit' => $tarif -> priceUnit ,
'limit' => $tarif -> limit ,
'dateDebut' => date ( 'YmdHis' , $time ),
'duree' => $tarif -> duree ,
'doublon' => $tarif -> doublon ,
);
2012-12-26 10:13:05 +00:00
2012-10-17 06:20:39 +00:00
try {
$tarifM = new Application_Model_Sdv1ClientsTarifs ( $db );
if ( empty ( $id )) {
$result = $tarifM -> update ( $data , 'id=' . $id );
} else {
$result = $tarifM -> insert ( $data );
}
} catch ( Zend_Db_Adapter_Exception $e ) {
if ( $this -> tabInfoUser [ 'idClient' ] != 1 ) {
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
2012-08-07 13:31:35 +00:00
}
2012-12-26 10:13:05 +00:00
2012-10-17 06:20:39 +00:00
return $result ;
}
/**
* Get list of tarif
* @ param int $idClient
* @ param string $service
* @ throws SoapFault
* @ return ClientTarif
*/
public function getClientTarifs ( $idClient , $service = null )
{
$this -> authenticate ();
2012-12-26 10:13:05 +00:00
2012-10-17 06:20:39 +00:00
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> db -> sdv1 );
$db -> getConnection ();
} catch ( Zend_Db_Adapter_Exception $e ) {
2013-01-10 08:51:55 +00:00
if ( $this -> tabInfoUser [ 'idClient' ] == 1 ) {
2012-10-17 06:20:39 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
2013-01-10 08:51:55 +00:00
} else {
throw new SoapFault ( 'ERR' , " Application error " );
2012-10-17 06:20:39 +00:00
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-12-26 10:13:05 +00:00
2012-10-17 06:20:39 +00:00
try {
$tarifM = new Application_Model_Sdv1ClientsTarifs ( $db );
$sql = $tarifM -> select ()
-> where ( 'idClient=?' , $idClient );
if ( ! empty ( $service )) {
$sql -> where ( 'service=?' , $service );
}
$sql -> order ( 'dateDebut DESC' );
$rows = $tarifM -> fetchAll ( $sql );
} catch ( Zend_Db_Adapter_Exception $e ) {
2013-01-10 08:51:55 +00:00
if ( $this -> tabInfoUser [ 'idClient' ] == 1 ) {
2012-10-17 06:20:39 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
2013-01-10 08:51:55 +00:00
} else {
throw new SoapFault ( 'ERR' , " Application error " );
2012-10-17 06:20:39 +00:00
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-12-26 10:13:05 +00:00
2012-10-17 06:20:39 +00:00
return $rows ;
2012-08-07 13:31:35 +00:00
}
/**
2012-10-17 06:20:39 +00:00
* Get a tarif and his details by date
* @ param string $log
* @ param int $idClient
* @ param string $service
* @ param string $date
* @ throws SoapFault
* @ return ClientTarif
2012-08-07 13:31:35 +00:00
*/
2012-10-17 06:20:39 +00:00
public function getClientTarif ( $log , $idClient , $service = 'default' , $date = null )
2012-08-07 13:31:35 +00:00
{
$this -> authenticate ();
2012-12-26 10:13:05 +00:00
2012-10-17 06:20:39 +00:00
if ( empty ( $service ) ) {
$service = 'default' ;
}
2012-12-26 10:13:05 +00:00
2012-10-17 06:20:39 +00:00
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> db -> sdv1 );
$db -> getConnection ();
} catch ( Zend_Db_Adapter_Exception $e ) {
2013-01-10 08:51:55 +00:00
if ( $this -> tabInfoUser [ 'idClient' ] == 1 ) {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
} else {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-10-17 06:20:39 +00:00
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-12-26 10:13:05 +00:00
2012-10-17 06:20:39 +00:00
try {
$tarifM = new Application_Model_Sdv1ClientsTarifs ( $db );
$sql = $tarifM -> select ()
-> from ( $tarifM , array (
'id' , 'idClient' , 'service' , 'log' , 'type' , 'priceUnit' , 'limit' , 'dateDebut' ,
'duree' , 'doublon' , 'DATE_ADD(dateDebut, INTERVAL duree DAY) AS dateFin'
))
-> where ( 'log=?' , $log )
-> where ( 'idClient=?' , $idClient )
-> where ( 'service=?' , $service );
//->where('dateDebut<=?', $date);
//->where('dateFin>?',$date);
//@todo : get date between
2012-12-26 10:13:05 +00:00
2012-10-17 06:20:39 +00:00
$row = $tarifM -> fetchRow ( $sql );
} catch ( Zend_Db_Adapter_Exception $e ) {
2013-01-10 08:51:55 +00:00
if ( $this -> tabInfoUser [ 'idClient' ] == 1 ) {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
} else {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-10-17 06:20:39 +00:00
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-12-26 10:13:05 +00:00
2012-10-17 06:20:39 +00:00
return $row ;
2012-08-07 13:31:35 +00:00
}
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
/**
* Liste des prestations pour un client
* @ param int $idClient
* @ return ClientPrestation []
* @ throws SoapFault
*/
public function getPrestations ( $idClient )
{
$this -> authenticate ();
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
//Connect to the database
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> db -> sdv1 );
$db -> getConnection ();
} catch ( Zend_Db_Adapter_Exception $e ) {
if ( $this -> tabInfoUser [ 'idClient' ] != 1 ) {
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
//Read prestations
try {
2012-10-17 06:20:39 +00:00
$prestationsM = new Application_Model_Sdv1Prestations ( $db );
2012-09-25 10:02:22 +00:00
$sql = $prestationsM -> select ()
-> from ( $prestationsM , array ( 'id' , 'typeprestation' , 'datemiseenplace' ,
'datefinprestation' , 'identifiantPrestation' , 'prestationactive' ))
-> where ( 'idClient=?' , $idClient );
$result = $prestationsM -> fetchAll ( $sql );
} catch ( Zend_Db_Exception $e ) {
if ( $this -> tabInfoUser [ 'idClient' ] != 1 ) {
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
$output = array ();
if ( $result -> count () > 0 ) {
foreach ( $result as $item ) {
$clientprestation = new ClientPrestation ();
$clientprestation -> id = $item -> id ;
$clientprestation -> type = $item -> typeprestation ;
$clientprestation -> identifiant = $item -> identifiantPrestation ;
$clientprestation -> active = $item -> prestationactive ;
$clientprestation -> dateDebut = $item -> datemiseenplace ;
$clientprestation -> dateFin = $item -> datefinprestation ;
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
$output [] = $clientprestation ;
}
}
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
return $output ;
}
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
/**
* Liste des paramètres d ' une prestation
* @ param int $id
* @ return string
* @ throws SoapFault
*/
public function getPrestation ( $id )
{
$this -> authenticate ();
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
//Connect to the database
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> db -> sdv1 );
$db -> getConnection ();
} catch ( Zend_Db_Adapter_Exception $e ) {
if ( $this -> tabInfoUser [ 'idClient' ] != 1 ) {
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
//Read prestations
try {
2012-10-17 06:20:39 +00:00
$prestationsM = new Application_Model_Sdv1Prestations ( $db );
2012-09-25 10:02:22 +00:00
$sql = $prestationsM -> select () -> where ( 'id=?' , $id );
$result = $prestationsM -> fetchRow ( $sql );
if ( $result !== null ) {
return json_encode ( $result -> toArray ());
} else {
return '' ;
}
} catch ( Zend_Db_Exception $e ) {
if ( $this -> tabInfoUser [ 'idClient' ] != 1 ) {
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
}
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
/**
* Enregistre les paramètres des la prestation
* @ param int $idClient
* @ param string $prestation
* @ return int
* @ throws SoapFault
*/
public function setPrestation ( $idClient , $prestation )
{
$this -> authenticate ();
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
if ( $this -> tabInfoUser [ 'profil' ] != 'SuperAdministrateur' ) {
$this -> sendError ( '0902' );
}
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
$prestationParameters = json_decode ( $prestation , true );
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
//Connect to the database
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> db -> sdv1 );
$db -> getConnection ();
} catch ( Zend_Db_Adapter_Exception $e ) {
if ( $this -> tabInfoUser [ 'idClient' ] != 1 ) {
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
//Insert or update a prestation
try {
2012-10-17 06:20:39 +00:00
$prestationsM = new Application_Model_Sdv1Prestations ( $db );
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
//Update
if ( ! empty ( $prestationParameters [ 'id' ])) {
$id = $prestationParameters [ 'id' ];
unset ( $prestationParameters [ 'id' ]);
$result = $prestationsM -> update ( $prestationParameters , 'id=' . $id );
}
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
//Insert
else {
//@todo : Some control before save
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
$result = $prestationsM -> insert ( $prestationParameters );
}
} catch ( Zend_Db_Exception $e ) {
if ( $this -> tabInfoUser [ 'idClient' ] != 1 ) {
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
2012-12-26 10:13:05 +00:00
2012-09-25 10:02:22 +00:00
return $result ;
}
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
/**
* Define a Service in Client
* @ param int $idClient
2013-01-10 08:51:55 +00:00
* @ param string $infos
2012-10-16 12:57:18 +00:00
* @ throws SoapFault
* @ return int
*/
2013-01-10 08:51:55 +00:00
public function setService ( $idClient , $infos = null )
2012-10-16 12:57:18 +00:00
{
$this -> authenticate ();
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
if ( $this -> tabInfoUser [ 'profil' ] != 'SuperAdministrateur' ) {
$this -> sendError ( '0902' );
}
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
//Connect to the database
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> db -> sdv1 );
$db -> getConnection ();
} catch ( Zend_Db_Adapter_Exception $e ) {
if ( $this -> tabInfoUser [ 'idClient' ] != 1 ) {
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
try {
2012-10-17 06:20:39 +00:00
$serviceM = new Application_Model_Sdv1ClientsServices ( $db );
2012-08-07 13:31:35 +00:00
2013-01-10 08:51:55 +00:00
$dataIn = json_decode ( $infos , true );
$code = $dataIn [ 'code' ];
$label = $dataIn [ 'label' ];
$droits = $dataIn [ 'droits' ];
2012-10-16 12:57:18 +00:00
//Check if code exist in idClient
$sql = $serviceM -> select ()
-> where ( 'idClient=?' , $idClient )
-> where ( 'code=?' , $code );
$row = $serviceM -> fetchAll ( $sql );
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
if ( $row -> count () > 0 ) {
$data = array (
'label' => $label ,
2013-01-10 08:51:55 +00:00
'droits' => $droits
2012-10-16 12:57:18 +00:00
);
2012-10-16 13:37:40 +00:00
$result = $serviceM -> update ( $data , array ( 'idClient=' . $idClient , 'code=' . $code ));
2012-10-16 12:57:18 +00:00
} else {
$data = array (
'code' => $code ,
'label' => $label ,
2013-01-10 08:51:55 +00:00
'droits' => $droits ,
2012-10-16 12:57:18 +00:00
'idClient' => $idClient
);
$result = $serviceM -> insert ( $data );
}
} catch ( Zend_Db_Exception $e ) {
2013-01-10 08:51:55 +00:00
if ( $this -> tabInfoUser [ 'idClient' ] == 1 ) {
2012-10-16 12:57:18 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
2013-01-10 08:51:55 +00:00
} else {
throw new SoapFault ( 'ERR' , " Application error " );
2012-10-16 12:57:18 +00:00
}
}
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
return $result ;
}
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
/**
* Set a User in a Service
* @ param string $login
* @ param string $code
* @ throws SoapFault
* @ return int
*/
2012-12-26 10:13:05 +00:00
public function setUserService ( $login , $code )
2012-10-16 12:57:18 +00:00
{
$this -> authenticate ();
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
if ( $this -> tabInfoUser [ 'profil' ] != 'SuperAdministrateur' ) {
$this -> sendError ( '0902' );
}
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
//Connect to the database
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> db -> sdv1 );
$db -> getConnection ();
} catch ( Zend_Db_Adapter_Exception $e ) {
2013-01-10 08:51:55 +00:00
if ( $this -> tabInfoUser [ 'idClient' ] == 1 ) {
2012-10-16 12:57:18 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
2013-01-10 08:51:55 +00:00
} else {
throw new SoapFault ( 'ERR' , " Application error " );
2012-10-16 12:57:18 +00:00
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
try {
2012-10-17 06:20:39 +00:00
$serviceM = new Application_Model_Sdv1UtilisateursService ( $db );
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
//Check if code exist in idClient
$sql = $serviceM -> select () -> where ( 'login=?' , $login );
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
$row = $serviceM -> fetchAll ( $sql );
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
if ( $row -> count () > 0 ) {
$data = array (
'serviceCode' => $label ,
);
2012-10-16 13:37:40 +00:00
$result = $serviceM -> update ( $data , 'login=' . $login );
2012-10-16 12:57:18 +00:00
} else {
$data = array (
'login' => $login ,
'serviceCode' => $code ,
);
$result = $serviceM -> insert ( $data );
}
} catch ( Zend_Db_Exception $e ) {
2013-01-10 08:51:55 +00:00
if ( $this -> tabInfoUser [ 'idClient' ] == 1 ) {
2012-10-16 12:57:18 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
2013-01-10 08:51:55 +00:00
} else {
throw new SoapFault ( 'ERR' , " Application error " );
2012-10-16 12:57:18 +00:00
}
}
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
return $result ;
}
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
/**
* List Services
* @ param int $idClient
* @ throws SoapFault
* @ return Service
*/
public function getServices ( $idClient )
{
$this -> authenticate ();
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
if ( $this -> tabInfoUser [ 'profil' ] != 'SuperAdministrateur' ) {
$this -> sendError ( '0902' );
}
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
//Connect to the database
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> db -> sdv1 );
$db -> getConnection ();
} catch ( Zend_Db_Adapter_Exception $e ) {
if ( $this -> tabInfoUser [ 'idClient' ] != 1 ) {
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
try {
2012-10-17 06:20:39 +00:00
$serviceM = new Application_Model_Sdv1ClientsServices ( $db );
2012-10-16 12:57:18 +00:00
$sql = $serviceM -> select () -> where ( 'idClient=?' , $idClient );
$rows = $serviceM -> fetchAll ( $sql );
} catch ( Zend_Db_Adapter_Exception $e ) {
if ( $this -> tabInfoUser [ 'idClient' ] != 1 ) {
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
$output = array ();
if ( $rows -> count () > 0 ) {
foreach ( $rows as $item ) {
$service = new Service ();
$service -> code = $item -> code ;
$service -> label = $item -> label ;
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
//Get logins
2012-10-17 06:20:39 +00:00
$userserviceM = new Application_Model_Sdv1UtilisateursService ( $db );
2012-10-16 12:57:18 +00:00
$sql = $userserviceM -> select () -> where ( 'code=?' , $item -> code );
$logins = $userserviceM -> fetchAll ( $sql );
2012-12-26 10:13:05 +00:00
2012-10-16 12:57:18 +00:00
if ( $logins -> count () > 0 ) {
foreach ( $logins as $login ) {
$service -> login [] = $login ;
}
}
$output [] = $service ;
}
}
return $output ;
}
2013-01-10 08:51:55 +00:00
protected function getService ( $idClient , $code )
{
$this -> authenticate ();
if ( $this -> tabInfoUser [ 'profil' ] != 'SuperAdministrateur' ) {
$this -> sendError ( '0902' );
}
//Connect to the database
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> db -> sdv1 );
$db -> getConnection ();
} catch ( Zend_Db_Adapter_Exception $e ) {
if ( $this -> tabInfoUser [ 'idClient' ] == 1 ) {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
} else {
throw new SoapFault ( 'ERR' , " Application error " );
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
try {
$serviceM = new Application_Model_Sdv1ClientsServices ( $db );
$sql = $serviceM -> select ()
-> where ( 'idClient=?' , $idClient )
-> where ( 'serviceCode=?' , $code );
$row = $serviceM -> fetchRow ( $sql );
} catch ( Zend_Db_Adapter_Exception $e ) {
if ( $this -> tabInfoUser [ 'idClient' ] == 1 ) {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
} else {
throw new SoapFault ( 'ERR' , " Application error " );
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
if ( null !== $row ) {
return json_encode ( $row -> toArray ());
}
return false ;
}
2012-08-07 13:31:35 +00:00
}