]> git.llucax.com Git - mecon/meconlib.git/blobdiff - lib/MECON/Dependencia.php
Se cambia el constructor de MECON_Dependencia para que tome por parámetro la conexión...
[mecon/meconlib.git] / lib / MECON / Dependencia.php
index 6cc0637127473621e8c7d3c494c754fcd5a332c6..f30c91766f116128097f5c93650833fbb113ea7b 100644 (file)
@@ -28,11 +28,16 @@ $Id$
 require_once 'MECON/Agente.php';
 require_once 'DB.php';
 
-// +X2C Class 145 :MECON_Dependencia
 /**
  * @access protected
  */
 class MECON_Dependencia {
+    /**
+     * @var    int $dbh
+     * @access private
+     */
+    var $_dbh;
+
     /**
      * @var    int $codep
      * @access public
@@ -59,44 +64,55 @@ class MECON_Dependencia {
      */
     var $dependencia_id = null;
 
-    // ~X2C
-
-    // +X2C Operation 147
     /**
-     * @param  int $codep 
+     * @param  string $codep 
+     * @param  int $id 
      *
      * @return void
      * @access public
      */
-    function MECON_Dependencia($codep) // ~X2C
+    function MECON_Dependencia(&$dbh, $codep, $id = null, $database = 'CODEP') 
     {
-        $this->codep = $codep;
-        $dsn = 'mysql://intranet:intranet@intranet-db.mecon.ar/CODEP';
-        $db = DB::connect($dsn);
-        if (DB::isError($db))
-            die ($db->getMessage("No pudo conectarse a la base"));
-        $sql = "SELECT nombre, nombre_breve, dependencia_id
-               FROM Dependencias
-               WHERE codigo_actual = '$this->codep' AND
-               dependencia_esta_activa = 1";
-        $result = $db->query($sql);
+        $this->_dbh = $dbh;
+
+        if(!is_null($codep)) {
+            $this->codep = $codep;
+
+            $sql = "SELECT  nombre, nombre_breve, dependencia_id, codigo_actual
+                    FROM    $database.Dependencias
+                    WHERE   codigo_actual = '$this->codep' AND
+                           dependencia_esta_activa = 1";
+
+            $result = $this->_dbh->query($sql);
+        }
+       else {
+            $this->dependencia_id = $id;
+
+            $sql = "SELECT  nombre, nombre_breve, dependencia_id, codigo_actual
+                    FROM    $database.Dependencias
+                    WHERE   dependencia_id = $this->dependencia_id AND
+                           dependencia_esta_activa = 1";
+            $result = $this->_dbh->query($sql);
+        }
+
         if(DB::isError($result))
             die($result->getMessage("query mal hecho"));
+
         if($result->numRows() > 0) {
             $row = $result->fetchRow(DB_FETCHMODE_ASSOC);
+            $this->codep = $row['codigo_actual'];
             $this->nombre = $row['nombre'];
             $this->nombre_breve = $row['nombre_breve'];
             $this->dependencia_id = $row['dependencia_id'];
         }
     }
-    // -X2C
+    
 
-    // +X2C Operation 148
     /**
      * @return void
      * @access public
      */
-    function getAgentes() // ~X2C
+    function getAgentes() 
     {
         //Planta y becarios
         $agentes = array();
@@ -127,15 +143,14 @@ class MECON_Dependencia {
             $agentes[] = new MECON_Agente($row[0]);
         return $agentes;
     }
-    // -X2C
 
-    // +X2C Operation 150
+
     /**
      * @return dependencia
      * @access public
      * @static
      */
-    function getDependencias() // ~X2C
+    function getDependencias() 
     {
         $dsn = 'mysql://intranet:intranet@intranet-db.mecon.ar/CODEP';
         $db = DB::connect($dsn);
@@ -152,31 +167,29 @@ class MECON_Dependencia {
             $dependencias[] = $row[0];
         return $dependencias;
     }
-    // -X2C
 
-    // +X2C Operation 165
+
     /**
      * @return void
      * @access public
      */
-    function getNombre() // ~X2C
+    function getNombre() 
     {
         return $this->nombre;
     }
-    // -X2C
 
-    // +X2C Operation 166
+
     /**
      * @return void
      * @access public
      */
-    function getNombreBreve() // ~X2C
+    function getNombreBreve() 
     {
         return $this->nombre_breve;
     }
-    // -X2C
 
-    // +X2C Operation 167
+
+
     /**
      * Buscar dependencias por el codep.
      *
@@ -187,12 +200,12 @@ class MECON_Dependencia {
      * @access public
      * @static
      */
-    function buscarPorCodigo(&$dbh, $codep) // ~X2C
+    function buscarPorCodigo(&$dbh, $codep)
     {
        //Reemplazar el comodIn
        $codep = preg_replace ('/\*/', '%', $codep);    
     
-       $sql = " SELECT codigo_actual, codigo_comdoc, nombre 
+       $sql = " SELECT codigo_actual, codigo_comdoc, nombre, dependencia_id 
                 FROM CODEP.Dependencias
                 WHERE dependencia_esta_activa = 1 
                        AND codigo_actual LIKE '$codep' 
@@ -203,9 +216,9 @@ class MECON_Dependencia {
        
        return $result;
     }
-    // -X2C
 
-    // +X2C Operation 168
+
+
     /**
      * @param  db &$dbh Base de Datos
      * @param  string $clave Cadena de palabras clave del nombre de la dependencia.
@@ -214,12 +227,12 @@ class MECON_Dependencia {
      * @access public
      * @static
      */
-    function buscarPorNombre(&$dbh, $clave) // ~X2C
+    function buscarPorNombre(&$dbh, $clave) 
     {
        //ReducciOn de espacios en blanco
        $clave = preg_replace ('/\s+/', ' ', $clave);   
     
-       $sql = " SELECT codigo_actual, codigo_comdoc, nombre 
+       $sql = " SELECT codigo_actual, codigo_comdoc, nombre, dependencia_id
                 FROM CODEP.Dependencias
                 WHERE  dependencia_esta_activa = 1 ";
 
@@ -236,7 +249,7 @@ class MECON_Dependencia {
        
        return $result;
     }
-    // -X2C
 
-} // -X2C Class :MECON_Dependencia
+
+} 
 ?>
\ No newline at end of file