require_once 'MECON/Agente.php';
require_once 'DB.php';
-// +X2C Class 145 :Dependencia
+// +X2C Class 145 :MECON_Dependencia
/**
* @access protected
*/
*/
var $nombre_breve;
+ /**
+ * Id de la dependencia en la base.
+ *
+ * @var int $dependencia_id
+ * @access public
+ */
+ 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($codep, $id = null) // ~X2C
{
- $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
- FROM Dependencias
- WHERE codigo_actual = '$this->codep' AND
- dependencia_esta_activa = 1";
- $result = $db->query($sql);
+ if(!is_null($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,codigo_actual
+ FROM Dependencias
+ WHERE codigo_actual = '$this->codep' AND
+ dependencia_esta_activa = 1";
+ $result = $db->query($sql);
+
+ }else {
+ $this->dependencia_id = $id;
+ $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, codigo_actual
+ FROM Dependencias
+ WHERE dependencia_id = $this->dependencia_id AND
+ dependencia_esta_activa = 1";
+ $result = $db->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
-} // -X2C Class :Dependencia
-?>
+ // +X2C Operation 167
+ /**
+ * Buscar dependencias por el codep.
+ *
+ * @param db &$dbh Base de Datos
+ * @param string $codep COdigo de dependencia, o parte del mismo seguido del comodIn (*)
+ *
+ * @return array
+ * @access public
+ * @static
+ */
+ function buscarPorCodigo(&$dbh, $codep) // ~X2C
+ {
+ //Reemplazar el comodIn
+ $codep = preg_replace ('/\*/', '%', $codep);
+
+ $sql = " SELECT codigo_actual, codigo_comdoc, nombre, dependencia_id
+ FROM CODEP.Dependencias
+ WHERE dependencia_esta_activa = 1
+ AND codigo_actual LIKE '$codep'
+ ORDER BY codigo_actual ";
+
+ $dbh->setFetchMode(DB_FETCHMODE_ASSOC);
+ $result = $dbh->query($sql);
+
+ return $result;
+ }
+ // -X2C
+
+ // +X2C Operation 168
+ /**
+ * @param db &$dbh Base de Datos
+ * @param string $clave Cadena de palabras clave del nombre de la dependencia.
+ *
+ * @return array
+ * @access public
+ * @static
+ */
+ function buscarPorNombre(&$dbh, $clave) // ~X2C
+ {
+ //ReducciOn de espacios en blanco
+ $clave = preg_replace ('/\s+/', ' ', $clave);
+
+ $sql = " SELECT codigo_actual, codigo_comdoc, nombre, dependencia_id
+ FROM CODEP.Dependencias
+ WHERE dependencia_esta_activa = 1 ";
+
+ //Separar la cadena de palabras clave
+ $items = split(' ', $clave);
+ foreach ($items as $i){
+ $sql.= " AND nombre like '%$i%' ";
+ }
+
+ $sql.= " ORDER BY codigo_actual";
+
+ $dbh->setFetchMode(DB_FETCHMODE_ASSOC);
+ $result = $dbh->query($sql);
+
+ return $result;
+ }
+ // -X2C
+
+} // -X2C Class :MECON_Dependencia
+?>
\ No newline at end of file