-<?php
-// vim: set expandtab tabstop=4 softtabstop=4 shiftwidth=4:
-// +----------------------------------------------------------------------+
-// | PHP Version 4 |
-// +----------------------------------------------------------------------+
-// | Copyright (c) 1997-2003 The PHP Group |
-// +----------------------------------------------------------------------+
-// | This source file is subject to version 2.02 of the PHP license, |
-// | that is bundled with this package in the file LICENSE, and is |
-// | available at through the world-wide-web at |
-// | http://www.php.net/license/2_02.txt. |
-// | If you did not receive a copy of the PHP license and are unable to |
-// | obtain it through the world-wide-web, please send a note to |
-// | license@php.net so we can mail you a copy immediately. |
-// +----------------------------------------------------------------------+
-// | Created: Thu Jun 19 16:54:08 2003
-// | Author: Gonzalo Merayo <gmeray@mecon.gov.ar>
-// +----------------------------------------------------------------------+
-//
-// $Id$
-// $Author$
-// $URL$
-// $Date$
-// $Rev$
-//
+<?php /* vim: set binary expandtab tabstop=4 shiftwidth=4 textwidth=80:
+-------------------------------------------------------------------------------
+ Ministerio de EconomÃa
+ 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.
+
+You should have received a copy of the GNU General Public License; if not,
+write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
+Boston, MA 02111-1307 USA
+-------------------------------------------------------------------------------
+Creado: Thu Jun 19 16:54:08 2003
+Autor: Gonzalo Merayo <gmeray@mecon.gov.ar>
+-------------------------------------------------------------------------------
+$Id$
+-----------------------------------------------------------------------------*/
#require_once 'PEAR.php';
require_once 'MECON/Agente.php';
require_once 'DB.php';
-
-
-// +X2C Class 145 :dependencia
/**
* @access protected
*/
-class dependencia {
- /**
- * @var int $codep
- * @access public
- */
- var $codep;
-
- // ~X2C
-
- // +X2C Operation 147
- /**
- * @param int $codep
- *
- * @return void
- * @access public
- */
- function dependencia($codep) // ~X2C
- {
- $this->codep = $codep;
- }
- // -X2C
-
- // +X2C Operation 148
- /**
- * @return void
- * @access public
- */
- function getAgentes() // ~X2C
- {
-//Planta y becarios
- $agentes = array();
- $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 nrodoc
- FROM web003
- WHERE codep = $this->codep";
- $result = $db->query($sql);
- if(DB::isError($result))
- die($result->getMessage("query mal hecho"));
- while($row = $result->fetchRow())
- $agentes[] = new Agente($row[0]);
-//Contratados
- $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 codep = $this->codep";
- $result = $db->query($sql);
- if(DB::isError($result))
- die($result->getMessage("query mal hecho"));
- while($row = $result->fetchRow())
- $agentes[] = new Agente($row[0]);
- return $agentes;
- }
- // -X2C
-
-} // -X2C Class :dependencia
-?>
+class MECON_Dependencia {
+
+ /**
+ * @protected
+ */
+ var $_dbh;
+
+ /**
+ * @protected
+ */
+ var $_database;
+
+ /**
+ * @var int $codep
+ * @access public
+ */
+ var $codep;
+
+ /**
+ * @var int $nombre
+ * @access public
+ */
+ var $nombre;
+
+ /**
+ * @var int $nombre_breve
+ * @access public
+ */
+ var $nombre_breve;
+
+ /**
+ * Id de la dependencia en la base.
+ *
+ * @var int $dependencia_id
+ * @access public
+ */
+ var $dependencia_id = null;
+
+ /**
+ * @param string $codep
+ * @param int $id
+ *
+ * @return void
+ * @access public
+ */
+ function MECON_Dependencia(&$dbh, $codep, $id = null, $database = 'CODEP')
+ {
+ $this->_dbh = $dbh;
+ $this->_database = $database;
+
+ 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'];
+ }
+ }
+
+
+ /**
+ * @return void
+ * @access public
+ */
+ function getAgentes()
+ {
+ //Planta y becarios
+ $agentes = array();
+ $sql = "SELECT nrodoc
+ FROM {$this->_database}.web003
+ WHERE codep = '{$this->codep}'";
+ $result = $this->_db->query($sql);
+ if(DB::isError($result))
+ trigger_error($result->getMessage("query mal hecho"), E_USER_ERROR);
+ while($row = $result->fetchRow())
+ $agentes[] = new MECON_Agente($this->_db, $row[0]);
+ //Contratados
+ $sql = "SELECT nrodoc
+ FROM Contratados.Contratados
+ WHERE codep = '$this->codep'";
+ $result = $db->query($sql);
+ if(DB::isError($result))
+ trigger_error($result->getMessage("query mal hecho"), E_USER_ERROR);
+ while($row = $result->fetchRow())
+ $agentes[] = new MECON_Agente($this->_db, $row[0]);
+ return $agentes;
+ }
+
+
+ /**
+ * @return dependencia
+ * @access public
+ * @static
+ */
+ function getDependencias()
+ {
+ $sql = "SELECT codigo_actual
+ FROM {$this->_database}.Dependencias
+ WHERE dependencia_esta_activa = 1";
+ $result = $this->_db->query($sql);
+ if(DB::isError($result))
+ trigger_error($result->getMessage("query mal hecho"), E_USER_ERROR);
+ $dependencias = array();
+ while($row = $result->fetchRow())
+ $dependencias[] = $row[0];
+ return $dependencias;
+ }
+
+
+ /**
+ * @return void
+ * @access public
+ */
+ function getNombre()
+ {
+ return $this->nombre;
+ }
+
+
+ /**
+ * @return void
+ * @access public
+ */
+ function getNombreBreve()
+ {
+ return $this->nombre_breve;
+ }
+
+
+
+ /**
+ * 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, $database = 'CODEP')
+ {
+ //Reemplazar el comodIn
+ $codep = preg_replace ('/\*/', '%', $codep);
+
+ $sql = " SELECT codigo_actual, codigo_comdoc, nombre, dependencia_id
+ FROM $database.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;
+ }
+
+
+
+ /**
+ * @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, $database = 'CODEP')
+ {
+ //ReducciOn de espacios en blanco
+ $clave = preg_replace ('/\s+/', ' ', $clave);
+
+ $sql = " SELECT codigo_actual, codigo_comdoc, nombre, dependencia_id
+ FROM $database.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;
+ }
+
+
+}
+?>
\ No newline at end of file