]> git.llucax.com Git - mecon/meconlib.git/blobdiff - lib/MECON/Agente.php
- Se cambia la interfase de MECON_Agente
[mecon/meconlib.git] / lib / MECON / Agente.php
index 691efd3e9c4d6ae519226701bfedc77607f3ff9f..b84fdc6bbe12cae8144bfba29b00355d1d4c86a6 100644 (file)
@@ -4,12 +4,12 @@
                                     meconlib
 -------------------------------------------------------------------------------
 This file is part of meconlib.
-
 meconlib is free software; you can redistribute it and/or modify it under
 the terms of the GNU General Public License as published by the Free
 Software Foundation; either version 2 of the License, or (at your option)
 any later version.
-
 meconlib is distributed in the hope that it will be useful, but WITHOUT
 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
@@ -24,203 +24,192 @@ Autor:  Gonzalo Merayo <gmeray@mecon.gov.ar>
 $Id$
 -----------------------------------------------------------------------------*/
 
-#require_once 'PEAR.php';
 require_once 'DB.php';
 require_once 'MECON/Tiempo/Hora.php';
 
-// +X2C Class 131 :Agente
 /**
- * @package
  * @access public
  */
-class Agente {
+class MECON_Agente {
+
     /**
-     * @var    int $agente
-     * @access public
+     * Documento del agente.
      */
     var $agente;
 
     /**
-     * @var    int $datos
-     * @access public
+     * Datos del agente
      */
-    var $datos;
-
-    // ~X2C
+    var $datos=array();
 
-    // +X2C Operation 133
     /**
      * @return string
-     * @access public
      */
-    function getDependencia() // ~X2C
-  {
-      return $this->datos['codep'];//TODO esta no es la columna correcta
-  }
-  // -X2C
+    function getDependencia()
+    {
+        if(in_array('codep',array_keys($this->datos)))
+            return $this->datos['codep'];//TODO esta no es la columna correcta
+        else
+            return false;
+    }
 
-    // +X2C Operation 134
     /**
      * @return void
      * @access public
      */
-    function getTipo() // ~X2C
-  {
-      if(is_null($this->datos['tipo_agente']))
-        return 'CON '.$this->datos['marco_legal'];
-      else
-        return $this->datos['tipo_agente'];
-      
-  }
-  // -X2C
+    function getTipo()
+    {
+        if(in_array('marco_legal',array_keys($this->datos)))
+            return 'CON '.$this->datos['marco_legal'];
+        elseif(in_array('tipo_agente',array_keys($this->datos)))
+            return $this->datos['tipo_agente'];
+        else
+            return false;
+    }
 
-    // +X2C Operation 135
     /**
+     * @param  dbh $db 
      * @param  int $agente 
      *
      * @return void
      * @access public
      */
-    function Agente($agente) // ~X2C
-  {
-      if(! is_null($agente))
-        $this->buscarAgente($agente);
-  }
-  // -X2C
+    function MECON_Agente(&$db,$agente)
+    {
+        $this->_db = $db;
+        //$this->_db = DB::connect('mysql://intranet:intranet@intranet-db.mecon.ar/novedades');
+        if(! is_null($agente)) {
+            $this->buscarAgente($agente);
+        }
+    }
 
-    // +X2C Operation 138
     /**
      * @return void
      * @access public
      */
-    function getNombre() // ~X2C
-  {
-      return $this->datos['nombre'];
-  }
-  // -X2C
+    function getNombre()
+    {
+        if(in_array('nombre',array_keys($this->datos)))
+            return $this->datos['nombre'];
+        else
+            return false;
+    }
 
-    // +X2C Operation 139
     /**
      * @return void
      * @access public
      */
-    function getHoraDesde() // ~X2C
-  {
-      if(is_null($this->datos['hentra']))
-          return new Hora($this->datos['hora_desde']);
-      else
-          return new Hora($this->datos['hentra']);
-  }
-  // -X2C
+    function getHoraDesde()
+    {
+        if(in_array('hora_desde',$this->datos))
+            return new MECON_Tiempo_Hora($this->datos['hora_desde']);
+        elseif(in_array('hentra',$this->datos))
+            return new MECON_Tiempo_Hora($this->datos['hentra']);
+        else
+            return false;
+    }
 
-    // +X2C Operation 140
     /**
      * @return void
      * @access public
      */
-    function getHoraHasta() // ~X2C
-  {
-      if(is_null($this->datos['hsale']))
-          return new Hora($this->datos['hora_hasta']);
-      else
-          return new Hora($this->datos['hsale']);
-  }
-  // -X2C
+    function getHoraHasta()
+    {
+        if(in_array('hora_hasta',$this->datos))
+            return new MECON_Tiempo_Hora($this->datos['hora_hasta']);
+        elseif(in_array('hsale',$this->datos))
+            return new MECON_Tiempo_Hora($this->datos['hsale']);
+        else
+            return false;
+    }
 
-    // +X2C Operation 149
     /**
      * @return void
      * @access public
      */
-    function getCuil() // ~X2C
+    function getCuil()
     {
-        $aux = $this->datos['cuil'];
-        $aux = preg_replace('/(\d{2})(\d*)(\d{1})/','$1-$2-$3',$aux);
-        return $aux;
+        if(in_array('cuil',$this->datos))
+        {
+            $aux = $this->datos['cuil'];
+            $aux = preg_replace('/(\d{2})(\d*)(\d{1})/','$1-$2-$3',$aux);
+            return $aux;
+        }else
+        {
+            return false;
+        }
     }
-    // -X2C
 
-    // +X2C Operation 151
     /**
      * @return void
      * @access public
      */
-    function getOtrosDatos() // ~X2C
+    function getOtrosDatos()
     {
         if(!is_null($this->datos['tipo_agente'])) {
-            $aux['tipo_doc'] = $this->datos['tipodoc']; 
-            $aux['fecha_nac'] = $this->datos['fecha_nac']; 
-            $aux['edad'] = $this->datos['edad']; 
-            $aux['estado_civil'] = $this->datos['estado_civil']; 
-            $aux['domicilio'] = $this->datos['domicilio']; 
-            $aux['puerta'] = $this->datos['num_puerta']; 
-            $aux['piso'] = $this->datos['piso']; 
-            $aux['depto'] = $this->datos['depto']; 
-            $aux['localidad'] = $this->datos['localidad']; 
-            $aux['provincia'] = $this->datos['provincia']; 
-            $aux['calle1'] = $this->datos['calle1']; 
-            $aux['calle2'] = $this->datos['calle2']; 
-            $aux['cp'] = $this->datos['cp']; 
-            $aux['telefono'] = $this->datos['telefono']; 
-            $aux['cargo'] = $this->datos['cargo']; 
-            $aux['nivel'] = $this->datos['nivel']; 
-            $aux['grado'] = $this->datos['grado']; 
-            $aux['func_ejec'] = $this->datos['func_ejec']; 
-            $aux['obra_social'] = $this->datos['obra_social']; 
-            $aux['afiliado'] = $this->datos['afiliado']; 
-            $aux['conyuge'] = $this->datos['conyuge']; 
-            $aux['fecha_nac_conyuge'] = $this->datos['fecha_nac_cony']; 
-            $aux['tipo_doc_conyuge'] = $this->datos['tipodoc_cony']; 
-            $aux['nro_doc_cony'] = $this->datos['nrodoc_cony']; 
+            $aux['tipo_doc'] = $this->datos['tipodoc'];
+            $aux['fecha_nac'] = $this->datos['fecha_nac'];
+            $aux['edad'] = $this->datos['edad'];
+            $aux['estado_civil'] = $this->datos['estado_civil'];
+            $aux['domicilio'] = $this->datos['domicilio'];
+            $aux['puerta'] = $this->datos['num_puerta'];
+            $aux['piso'] = $this->datos['piso'];
+            $aux['depto'] = $this->datos['depto'];
+            $aux['localidad'] = $this->datos['localidad'];
+            $aux['provincia'] = $this->datos['provincia'];
+            $aux['calle1'] = $this->datos['calle1'];
+            $aux['calle2'] = $this->datos['calle2'];
+            $aux['cp'] = $this->datos['cp'];
+            $aux['telefono'] = $this->datos['telefono'];
+            $aux['cargo'] = $this->datos['cargo'];
+            $aux['nivel'] = $this->datos['nivel'];
+            $aux['grado'] = $this->datos['grado'];
+            $aux['func_ejec'] = $this->datos['func_ejec'];
+            $aux['obra_social'] = $this->datos['obra_social'];
+            $aux['afiliado'] = $this->datos['afiliado'];
+            $aux['conyuge'] = $this->datos['conyuge'];
+            $aux['fecha_nac_conyuge'] = $this->datos['fecha_nac_cony'];
+            $aux['tipo_doc_conyuge'] = $this->datos['tipodoc_cony'];
+            $aux['nro_doc_cony'] = $this->datos['nrodoc_cony'];
+            return $aux;
+        } else {
+            return false;
         }
-        return $aux;
     }
-    // -X2C
 
-    // +X2C Operation 154
     /**
      * @param  int $agente 
      *
      * @return void
      * @access public
      */
-    function buscarAgente($agente) // ~X2C
+    function buscarAgente($agente)
     {
-      $this->agente = $agente;
-      $dsn = 'mysql://intranet:intranet@intranet-db/novedades';
-      $db = DB::connect($dsn);
-      if (DB::isError($db)) die ($db->getMessage("No pudo conectarse a la base"));
-      $sql = "SELECT * 
-              FROM web003
-             WHERE nrodoc = $agente";
-      $result = $db->query($sql);
-      if(DB::isError($result))
-        die($result->getMessage("query mal hecho"));
-      if($result->numRows() > 0)
-      {
-          $this->datos = $result->fetchRow(DB_FETCHMODE_ASSOC); 
-      }
-      else
-      {
-          $dsn = 'mysql://intranet:intranet@intranet-db/Contratados';
-          $db = DB::connect($dsn);
-          if (DB::isError($db)) die ($db->getMessage("No pudo conectarse a la base"));
-          $sql = "SELECT * 
-                  FROM Contratados
-                 WHERE nrodoc = $agente";
-          $result = $db->query($sql);
-          if(DB::isError($result))
-            die($result->getMessage("query mal hecho"));
-          if($result->numRows() > 0)
-          {
+        $this->agente = $agente;
+        $sql = "SELECT *
+               FROM novedades.web003
+               WHERE nrodoc = ".$agente;
+        $result = $this->_db->query($sql);
+        if(DB::isError($result))
+            trigger_error($result->getMessage("query mal hecho"), E_USER_ERROR);
+        if($result->numRows() > 0) {
             $this->datos = $result->fetchRow(DB_FETCHMODE_ASSOC);
-          }
-         else
-            return false;
-      }
-      return true;
+        } else {
+            $sql = "SELECT *
+                   FROM Contratados.Contratados
+                   WHERE nrodoc = ".$agente;
+            $result = $this->_db->query($sql);
+            if(DB::isError($result)) {
+                trigger_error($result->getMessage("query mal hecho"), E_USER_ERROR);
+            }
+            if($result->numRows() > 0) {
+                $this->datos = $result->fetchRow(DB_FETCHMODE_ASSOC);
+            } else {
+                return false;
+            }
+        }
+        return true;
     }
-    // -X2C
 
-} // -X2C Class :Agente
-?>
+}
+?>
\ No newline at end of file