/**
  *
  *Edita la informacion de una clasificacion de proveedor
  *
  * @param id_clasificacion_proveedor int Id de la clasificacion del proveedor a editar
  * @param retenciones json Ids de las retenciones de la clasificacion de  proveedor
  * @param impuestos json Ids de los impuestos de la clasificacion del proveedor
  * @param descripcion string Descripcion de la clasificacion del proveedor
  * @param nombre string Nombre de la clasificacion del proveedor
  **/
 public static function EditarClasificacion($id_clasificacion_proveedor, $descripcion = null, $id_tarifa_compra = null, $id_tarifa_venta = null, $impuestos = null, $nombre = null, $retenciones = null)
 {
     Logger::log("Editando la clasificacion de proveedor " . $id_clasificacion_proveedor);
     //valida los parametros recibidos
     $validar = self::validarParametrosClasificacionProveedor($id_clasificacion_proveedor, $nombre, $descripcion, null, $id_tarifa_compra, $id_tarifa_venta);
     if (is_string($validar)) {
         Logger::error($validar);
         throw new Exception($validar);
     }
     //Los parametros que no sean nulos seran tomados como actualizacion
     $clasificacion_proveedor = ClasificacionProveedorDAO::getByPK($id_clasificacion_proveedor);
     if (!is_null($descripcion)) {
         $clasificacion_proveedor->setDescripcion($descripcion);
     }
     if (!is_null($nombre)) {
         $clasificacion_proveedor->setNombre($nombre);
     }
     $cambio_tarifa_compra = false;
     $cambio_tarifa_venta = false;
     if (!is_null($id_tarifa_compra)) {
         if ($id_tarifa_compra != $clasificacion_proveedor->getIdTarifaCompra()) {
             $cambio_tarifa_compra = true;
             $clasificacion_proveedor->setIdTarifaCompra($id_tarifa_compra);
         }
     }
     if (!is_null($id_tarifa_venta)) {
         if ($id_tarifa_venta != $clasificacion_proveedor->getIdTarifaVenta()) {
             $cambio_tarifa_venta = true;
             $clasificacion_proveedor->setIdTarifaVenta($id_tarifa_venta);
         }
     }
     //Se actualiza el registro. Si se reciben listas de impuestos y/o registros se guardan los
     //que estan en la lista, despues se recorren los registros de la base de datos y aquellos que no
     //se encuentren en la lista nueva seran eliminados.
     DAO::transBegin();
     try {
         ClasificacionProveedorDAO::save($clasificacion_proveedor);
         //Si se cambia la tarifa de compra o de venta, se actualizan aquellos proveedores
         //con etsa clasificacion de proveedor y cuya tarifa haya sido obtenida por el rol
         //o por la clasificacion de proveedor.
         if ($cambio_tarifa_compra || $cambio_tarifa_venta) {
             $proveedores = UsuarioDAO::search(new Usuario(array("id_clasificacion_proveedor" => $id_clasificacion_proveedor)));
             foreach ($proveedores as $proveedor) {
                 if ($cambio_tarifa_compra) {
                     if ($proveedor->getTarifaCompraObtenida() == "rol" || $proveedor->getTarifaCompraObtenida() == "proveedor") {
                         $proveedor->setIdTarifaCompra($id_tarifa_compra);
                         $proveedor->setTarifaCompraObtenida("proveedor");
                     }
                 }
                 if ($cambio_tarifa_venta) {
                     if ($proveedor->getTarifaVentaObtenida() == "rol" || $proveedor->getTarifaVentaObtenida() == "proveedor") {
                         $proveedor->setIdTarifaVenta($id_tarifa_venta);
                         $proveedor->setTarifaVentaObtenida("proveedor");
                     }
                 }
                 UsuarioDAO::save($proveedor);
             }
         }
         if (!is_null($impuestos)) {
             $impuestos = object_to_array($impuestos);
             if (!is_array($impuestos)) {
                 throw new Exception("Los impuestos son invalidos");
             }
             $impuesto_clasificacion_proveedor = new ImpuestoClasificacionProveedor(array("id_clasificacion_proveedor" => $clasificacion_proveedor->getIdClasificacionProveedor()));
             foreach ($impuestos as $impuesto) {
                 if (is_null(ImpuestoDAO::getByPK($impuesto))) {
                     throw new Exception("El impuesto " . $impuesto . " no existe", 901);
                 }
                 $impuesto_clasificacion_proveedor->setIdImpuesto($impuesto);
                 ImpuestoClasificacionProveedorDAO::save($impuesto_clasificacion_proveedor);
             }
             $impuestos_clasificacion_proveedor = ImpuestoClasificacionProveedorDAO::search(new ImpuestoClasificacionProveedor(array("id_clasificacion_proveedor" => $id_clasificacion_proveedor)));
             foreach ($impuestos_clasificacion_proveedor as $impuesto_clasificacion_proveedor) {
                 $encontrado = false;
                 foreach ($impuestos as $impuesto) {
                     if ($impuesto == $impuesto_clasificacion_proveedor->getIdImpuesto()) {
                         $encontrado = true;
                     }
                 }
                 if (!$encontrado) {
                     ImpuestoClasificacionProveedorDAO::delete($impuesto_clasificacion_proveedor);
                 }
             }
         }
         /* Fin if de impuestos */
         if (!is_null($retenciones)) {
             $retenciones = object_to_array($retenciones);
             if (!is_array($retenciones)) {
                 throw new Exception("Las retenciones son invalidas", 901);
             }
             $retencion_clasificacion_proveedor = new RetencionClasificacionProveedor(array("id_clasificacion_proveedor" => $clasificacion_proveedor->getIdClasificacionProveedor()));
             foreach ($retenciones as $retencion) {
                 if (is_null(RetencionDAO::getByPK($retencion))) {
                     throw new Exception("La retencion " . $retencion . " no existe", 901);
                 }
                 $retencion_clasificacion_proveedor->setIdRetencion($retencion);
                 RetencionClasificacionProveedorDAO::save($retencion_clasificacion_proveedor);
             }
             $retenciones_clasificacion_proveedor = RetencionClasificacionProveedorDAO::search(new RetencionClasificacionProveedor(array("id_clasificacion_proveedor" => $id_clasificacion_proveedor)));
             foreach ($retenciones_clasificacion_proveedor as $retencion_clasificacion_proveedor) {
                 $encontrado = false;
                 foreach ($retenciones as $retencion) {
                     if ($retencion == $retencion_clasificacion_proveedor->getIdRetencion()) {
                         $encontrado = true;
                     }
                 }
                 if (!$encontrado) {
                     RetencionClasificacionProveedorDAO::delete($retencion_clasificacion_proveedor);
                 }
             }
         }
         /* Fin if de retenciones */
     } catch (Exception $e) {
         DAO::transRollback();
         Logger::error("La clasificacion de proveedor no ha podido ser editada: " . $e);
         if ($e->getCode() == 901) {
             throw new Exception("La clasificacion de proveedor no ha podido ser editada: " . $e->getCode(), 901);
         }
         throw new Exception("La clasificacion de proveedor no ha podido ser editada", 901);
     }
     DAO::transEnd();
     Logger::log("La clasificacion de proveedor ha sido eeditada exitosamente ");
 }
 /**
  *
  *Crea una nueva retencion
  *
  * @param es_monto float Si es veradera, el campo monto_porcentaje sera tomado como un monto fijo, si es falso, sera tomado como un porcentaje
  * @param monto_porcentaje float Monto o procentaje que representa esta retencion
  * @param nombre string Nombre de la retencion
  * @param descripcion string Descripcion larga de la retencion
  * @return id_retencion int Id de la retencion creada
  **/
 public static function NuevaRetencion($es_monto, $monto_porcentaje, $nombre, $descripcion = null)
 {
     Logger::log("Creando una nueva retencion");
     //Se validan los parametros recibidos
     $e = self::validarEsMonto($es_monto);
     if (is_string($e)) {
         Logger::error($e);
         throw new Exception($e);
     }
     $e = self::validarMontoPorcentaje($monto_porcentaje);
     if (is_string($e)) {
         Logger::error($e);
         throw new Exception($e);
     }
     $e = self::validarNombre($nombre);
     if (is_string($e)) {
         Logger::error($e);
         throw new Exception($e);
     }
     if (!is_null($descripcion)) {
         $e = self::validarDescripcion($descripcion);
         if (is_string($e)) {
             Logger::error($e);
             throw new Exception($e);
         }
     }
     $retencion = new Retencion(array("es_monto" => $es_monto, "monto_porcentaje" => $monto_porcentaje, "nombre" => $nombre, "descripcion" => $descripcion));
     DAO::transBegin();
     try {
         RetencionDAO::save($retencion);
     } catch (Exception $e) {
         DAO::transRollback();
         Logger::error("No se ha podido crear la nueva retencion: " . $e);
         throw new Exception("No se ha podido crear la nueva retencion, consulte a su administrador de sistema");
     }
     DAO::transEnd();
     Logger::log("Retencion creada exitosamente");
     return array("id_retencion" => $retencion->getIdRetencion());
 }
<?php

define("BYPASS_INSTANCE_CHECK", false);
require_once "../../../server/bootstrap.php";
$page = new GerenciaComponentPage();
//
// Parametros necesarios
//
$page->requireParam("rid", "GET", "La retencion no existe.");
$esta_retencion = RetencionDAO::getByPK($_GET["rid"]);
//
// Titulo de la pagina
//
$page->addComponent(new TitleComponent("Editar retencion " . $esta_retencion->getNombre(), 2));
$form = new DAOFormComponent($esta_retencion);
$form->hideField(array("id_retencion"));
$form->sendHidden("id_retencion");
$form->createComboBoxJoin("es_monto", "es_monto", array(array("id" => 1, "caption" => "Si"), array("id" => 0, "caption" => "No")), $esta_retencion->getEsMonto());
$form->addApiCall("api/impuestos_retenciones/retencion/editar", "GET");
$form->onApiCallSuccessRedirect("impuestos.lista.retencion.php");
$page->addComponent($form);
$page->render();
 private static function validarParametrosRetencionUsuario($id_retencion = null, $id_usuario = null)
 {
     //valida que la retencion exista en la base de datos
     if (!is_null($id_retencion)) {
         if (is_null(RetencionDAO::getByPK($id_retencion))) {
             return "La retencion con id: " . $id_retencion . " no existe";
         }
     }
     //valida que el usuario exista en la base de datos
     if (!is_null($id_usuario)) {
         if (is_null(UsuarioDAO::getByPK($id_usuario))) {
             return "El usuario con id: " . $id_usuario . " no existe";
         }
     }
     return true;
 }
 /**
  *
  *Edita un servicio
  *
  * @param id_servicio int Id del servicio a editar
  * @param sucursales json Sucursales en las cuales estara disponible este servicio
  * @param nombre_servicio string Nombre del servicio
  * @param garantia int Si este servicio tiene una garanta en meses.
  * @param impuestos json array de ids de impuestos que tiene este servico
  * @param metodo_costeo string Mtodo de costeo del servicio: 1 = Costo Promedio en Base a Entradas.2 = Costo Promedio en Base a Entradas Almacn.3 = ltimo costo.4 = UEPS.5 = PEPS.6 = Costo especfico.7 = Costo Estndar
  * @param empresas string Objeto que contiene los ids de las empresas a las que pertenece este servicio
  * @param codigo_servicio string Codigo de control del servicio manejado por la empresa, no se puede repetir
  * @param descripcion_servicio string Descripcion del servicio
  * @param compra_en_mostrador string Verdadero si este servicio se puede comprar en mostrador, para aquello de compra-venta. Para poder hacer esto, el sistema debe poder hacer compras en mostrador
  * @param activo bool Si el servicio esta activo o no
  * @param control_de_existencia int 00000001 = Unidades. 00000010 = Caractersticas. 00000100 = Series. 00001000 = Pedimentos. 00010000 = LoteCaractersticas. 00000100 = Series. 00001000 = Pedimentos. 00010000 = Lote
  * @param foto_servicio string Url de la foto del servicio
  * @param margen_de_utilidad string Un porcentage de 0 a 100 si queremos que este servicio marque utilidad en especifico
  * @param clasificaciones json Uno o varios id_clasificacion de este servicio, esta clasificacion esta dada por el usuario Array
  * @param retenciones json Ids de retenciones que afectan este servicio
  * @param costo_estandar float Valor del costo estandar del servicio
  **/
 public static function Editar($id_servicio, $clasificaciones = null, $codigo_servicio = null, $compra_en_mostrador = null, $control_de_existencia = null, $costo_estandar = null, $descripcion_servicio = null, $empresas = null, $extra_params = null, $foto_servicio = null, $garantia = null, $impuestos = null, $metodo_costeo = null, $nombre_servicio = null, $precio = null, $retenciones = null, $sucursales = null)
 {
     Logger::log("Editando servicio " . $id_servicio);
     //valida los parametros recibidos
     $validar = self::validarParametrosServicio($id_servicio, $nombre_servicio, $metodo_costeo, $codigo_servicio, $compra_en_mostrador, null, $descripcion_servicio, $costo_estandar, $garantia, $control_de_existencia, $foto_servicio, $precio);
     if (is_string($validar)) {
         Logger::error($validar);
         throw new Exception($validar);
     }
     //Los parametros que no sean nulos seran tomados como actualizacion
     $servicio = ServicioDAO::getByPK($id_servicio);
     if (!is_null($nombre_servicio)) {
         $servicio->setNombreServicio(trim($nombre_servicio));
     }
     if (!is_null($garantia)) {
         $servicio->setGarantia($garantia);
     }
     if (!is_null($codigo_servicio)) {
         $servicio->setCodigoServicio(trim($codigo_servicio));
     }
     if (!is_null($descripcion_servicio)) {
         $servicio->setDescripcionServicio($descripcion_servicio);
     }
     if (!is_null($compra_en_mostrador)) {
         $servicio->setCompraEnMostrador($compra_en_mostrador);
     }
     if (!is_null($control_de_existencia)) {
         $servicio->setControlExistencia($control_de_existencia);
     }
     if (!is_null($extra_params)) {
         $servicio->setExtraParams(json_encode($extra_params));
     }
     if (!is_null($foto_servicio)) {
         $servicio->setFotoServicio($foto_servicio);
     }
     if (!is_null($costo_estandar)) {
         if (!is_numeric($costo_estandar) || $costo_estandar < 0) {
             throw new Exception("Indique un valor de costo valido");
         }
         $servicio->setCostoEstandar($costo_estandar);
     }
     if (!is_null($precio)) {
         if (!is_numeric($precio) || $precio < 0) {
             throw new Exception("Indique un valor de precio valido");
         }
         $servicio->setPrecio($precio);
     }
     if (!is_null($metodo_costeo)) {
         if ($metodo_costeo == "costo" && is_null($costo_estandar)) {
             throw new Exception("Indique un valor de costo");
         }
         if ($metodo_costeo == "precio" && is_null($precio)) {
             throw new Exception("Indique un valor de precio");
         }
         $servicio->setMetodoCosteo($metodo_costeo);
     }
     //Se verifica que se cuente con el atributo que busca el metodo de costeo
     if ($servicio->getMetodoCosteo() == "precio" && is_null($servicio->getPrecio()) || $servicio->getMetodoCosteo() == "costo" && is_null($servicio->getCostoEstandar())) {
         Logger::error("No se cuenta con el parametro " . $metodo_costeo);
         throw new Exception("No se cuenta con el parametro " . $metodo_costeo);
     }
     //Se actualiza el registro de servicio. Si se reciben listas de empresas, sucursales, clasificaciones, impuestos
     //y/o retenciones, se recorre la lista y se guardan o actualizan los que se encuentren.
     //Despues se recorren los registros acutales y se buscan en las listas recibidas, si no son encontrados son eliminados
     //de la base de datos
     DAO::transBegin();
     try {
         ServicioDAO::save($servicio);
         if (!is_null($empresas)) {
             $empresas = object_to_array($empresas);
             if (!is_array($empresas)) {
                 throw new Exception("Las empresas son invalidas", 901);
             }
             $servicio_empresa = new ServicioEmpresa(array("id_servicio" => $servicio->getIdServicio()));
             foreach ($empresas as $empresa) {
                 $validar = self::validarParametrosServicioEmpresa($empresa);
                 if (is_string($validar)) {
                     throw new Exception($validar, 901);
                 }
                 $servicio_empresa->setIdEmpresa($empresa);
                 ServicioEmpresaDAO::save($servicio_empresa);
             }
             $servicios_empresa = ServicioEmpresaDAO::search(new ServicioEmpresa(array("id_servicio" => $id_servicio)));
             foreach ($servicios_empresa as $s_e) {
                 $encontrado = false;
                 foreach ($empresas as $empresa) {
                     if ($empresa == $s_e->getIdEmpresa()) {
                         $encontrado = true;
                     }
                 }
                 if (!$encontrado) {
                     ServicioEmpresaDAO::delete($s_e);
                 }
             }
         }
         /* Fin if de empresas */
         if (!is_null($sucursales)) {
             $sucursales = object_to_array($sucursales);
             if (!is_array($sucursales)) {
                 throw new Exception("Las sucursales no son validas", 901);
             }
             $servicio_sucursal = new ServicioSucursal(array("id_servicio" => $servicio->getIdServicio()));
             foreach ($sucursales as $sucursal) {
                 $validar = self::validarParametrosServicioSucursal($sucursal);
                 if (is_string($validar)) {
                     throw new Exception($validar, 901);
                 }
                 $servicio_sucursal->setIdSucursal($sucursal);
                 ServicioSucursalDAO::save($servicio_sucursal);
             }
             $servicios_sucursal = ServicioSucursalDAO::search(new ServicioSucursal(array("id_servicio" => $id_servicio)));
             foreach ($servicios_sucursal as $s_s) {
                 $encontrado = false;
                 foreach ($sucursales as $sucursal) {
                     if ($sucursal == $s_s->getIdSucursal()) {
                         $encontrado = true;
                     }
                 }
                 if (!$encontrado) {
                     ServicioSucursalDAO::delete($s_s);
                 }
             }
         }
         /* Fin if de sucursales */
         if (!is_null($clasificaciones)) {
             $clasificaciones = object_to_array($clasificaciones);
             if (!is_array($clasificaciones)) {
                 throw new Exception("Las clasificaciones son invalidas", 901);
             }
             $servicio_clasificacion = new ServicioClasificacion(array("id_servicio" => $servicio->getIdServicio()));
             foreach ($clasificaciones as $clasificacion) {
                 if (is_null(ClasificacionServicioDAO::getByPK($clasificacion))) {
                     throw new Exception("La clasificacion " . $clasificacion . " no existe", 901);
                 }
                 $servicio_clasificacion->setIdClasificacionServicio($clasificacion);
                 ServicioClasificacionDAO::save($servicio_clasificacion);
             }
             $servicios_clasificacion = ServicioClasificacionDAO::search(new ServicioClasificacion(array("id_servicio" => $id_servicio)));
             foreach ($servicios_clasificacion as $s_c) {
                 $encontrado = false;
                 foreach ($clasificaciones as $clasificacion) {
                     if ($clasificacion == $s_c->getIdClasificacionServicio()) {
                         $encontrado = true;
                     }
                 }
                 if (!$encontrado) {
                     ServicioClasificacionDAO::delete($s_c);
                 }
             }
         }
         /* Fin if de clasificaciones */
         if (!is_null($impuestos)) {
             $impuestos = object_to_array($impuestos);
             if (!is_array($impuestos)) {
                 throw new Exception("Los impuestos son invalidos", 901);
             }
             $impuesto_servicio = new ImpuestoServicio(array("id_servicio" => $servicio->getIdServicio()));
             foreach ($impuestos as $impuesto) {
                 if (is_null(ImpuestoDAO::getByPK($impuesto))) {
                     throw new Exception("El impuesto " . $impuesto . " no existe", 901);
                 }
                 $impuesto_servicio->setIdImpuesto($impuesto);
                 ImpuestoServicioDAO::save($impuesto_servicio);
             }
             $impuesto_servicio = ImpuestoServicioDAO::search(new ImpuestoServicio(array("id_servicio" => $id_servicio)));
             foreach ($impuesto_servicio as $i_s) {
                 $encontrado = false;
                 foreach ($impuestos as $impuesto) {
                     if ($impuesto == $i_s->getIdImpuesto()) {
                         $encontrado = true;
                     }
                 }
                 if (!$encontrado) {
                     ImpuestoServicioDAO::delete($i_s);
                 }
             }
         }
         /* Fin if de impuestos */
         if (!is_null($retenciones)) {
             $retenciones = object_to_array($retenciones);
             if (!is_array($retenciones)) {
                 throw new Exception("Las retenciones son invalidas", 901);
             }
             $retencion_servicio = new RetencionServicio(array("id_servicio" => $servicio->getIdServicio()));
             foreach ($retenciones as $retencion) {
                 if (is_null(RetencionDAO::getByPK($retencion))) {
                     throw new Exception("La retencion " . $retencion . " no existe", 901);
                 }
                 $retencion_servicio->setIdRetencion($retencion);
                 RetencionServicioDAO::save($retencion_servicio);
             }
             $retencion_servicio = RetencionServicioDAO::search(new RetencionServicio(array("id_servicio" => $id_servicio)));
             foreach ($retencion_servicio as $r_s) {
                 $encontrado = false;
                 foreach ($retenciones as $retencion) {
                     if ($retencion == $r_s->getIdRetencion()) {
                         $encontrado = true;
                     }
                 }
                 if (!$encontrado) {
                     RetencionServicioDAO::delete($r_s);
                 }
             }
         }
         /* Fin if de impuestos */
     } catch (Exception $e) {
         DAO::transRollback();
         Logger::error("No se pudo editar el servicio " . $id_servicio . " : " . $e);
         if ($e->getCode() == 901) {
             throw new Exception("No se pudo editar el servicio: " . $e->getMessage(), 901);
         }
         throw new Exception("No se pudo editar el servicio", 901);
     }
     DAO::transEnd();
     Logger::log("Servicio editado exitosamente");
 }