/** * * Un administrador puede editar una sucursal, incuso si hay puntos de venta con sesiones activas que pertenecen a esa empresa. * * @author Juan Manuel García Carmona <*****@*****.**> * @param id_empresa int Id de la empresa a modificar * @param cuentas_bancarias json Arreglo que contiene los id de las cuentas bancarias * @param direccion json { "tipo": "fiscal", "calle": "Francisco I Madero", "numero_exterior": "1009A", "numero_interior": 12, "colonia": "centro", "codigo_postal": "38000", "telefono1": "4611223312", "telefono2": "", "id_ciudad": 3, "referencia": "El local naranja"} * @param direccion_web string Direccion del sitio de la empresa * @param email string Correo electronico de la empresa * @param id_moneda string Id de la moneda base que manejaran las sucursales * @param impuestos_compra json Impuestos de compra por default que se heredan a las sucursales y estas a su vez a los productos * @param impuestos_venta json Impuestos de venta por default que se heredan a las sucursales y estas a su vez a los productos * @param mensaje_morosos string mensaje enviado a los clientes (email) cuando un pago es demorado * @param razon_social string El nombre de la nueva empresa. * @param representante_legal string El nombre del representante legal de la nueva empresa. * @param rfc string RFC de la empresa * @param uri_logo string url del logo de la empresa **/ public static function Editar($id_empresa, $cuentas_bancarias = null, $direccion = null, $direccion_web = null, $email = null, $id_moneda = "0", $impuestos_compra = null, $impuestos_venta = null, $mensaje_morosos = null, $razon_social = null, $representante_legal = null, $rfc = null, $uri_logo = null) { //se guarda el registro de la empresa y se verifica que este activa $empresa = EmpresaDAO::getByPK($id_empresa); if (!$empresa->getActivo()) { Logger::error("La empresa no esta activa, no se puede editar una empresa desactivada"); throw new Exception("La empresa no esta activa, no se puede editar una empresa desactivada", 901); } $empresa->setDireccionWeb($direccion_web); //TODO : Por que carajos no esta el campo email!! //$empresa->setEmail($email); //TODO : No se debe de editar //$empresa->setIdMoneda($id_moneda); $empresa->setMensajeMorosos($mensaje_morosos); $empresa->setRazonSocial($razon_social); $empresa->setRepresentanteLegal($representante_legal); $empresa->setRfc($rfc); //editamos el id del logo if (!empty($uri_logo)) { //varificamos si cambio el logo $_logo = LogoDAO::getByPK($empresa->getIdLogo()); if ($uri_logo !== $_logo->getImagen()) { $logo = new Logo(array("imagen" => $uri_logo, "tipo" => "-")); try { LogoDAO::save($logo); } catch (Exception $e) { DAO::transRollback(); Logger::error("No se pudo crear la empresa, error al crear el logo: " . $e->getMessage()); throw new Exception("No se pudo crear la empresa, consulte a su administrador de sistema", 901); } $id_logo = $logo->getIdLogo(); $empresa->setIdLogo($id_logo); } } //lógica para manejar la edicion o agregado de una direccion verificamos si se cambiaron las direcciones if (!is_null($direccion)) { if (!is_array($direccion)) { //Logger::error("Verifique el formato de los datos de las direcciones, se esperaba un array "); //throw new Exception("Verifique el formato de los datos de las empresas, se esperaba un array "); $direccion = object_to_array($direccion); } $_direccion = new Direccion($direccion); $d = DireccionDAO::getByPK($empresa->getIdDireccion()); //verificamos si se va a editar una direccion o se va a crear una nueva if (isset($d->id_direccion)) { //se edita la direccion if (!($_direccion = DireccionDAO::getByPK($d->id_direccion))) { DAO::transRollback(); Logger::error("No se tiene registro de la dirección con id : {$direccion->id_direccion}"); throw new InvalidDataException("No se tiene registro de la dirección con id : {$direccion->id_direccion}"); } $_direccion->setIdDireccion($d->id_direccion); //bandera que indica si cambia algun parametro de la direccion $cambio_direccion = false; //calle if (isset($d->calle)) { $cambio_direccion = true; $_direccion->setCalle($direccion['calle']); } //numero_exterior if (isset($d->numero_exterior)) { $cambio_direccion = true; $_direccion->setNumeroExterior($direccion['numero_exterior']); } //numero_interior if (isset($d->numero_interior)) { $cambio_direccion = true; $_direccion->setNumeroInterior($direccion['numero_interior']); } //referencia if (isset($d->referencia)) { $cambio_direccion = true; $_direccion->setReferencia($direccion['referencia']); } //colonia if (isset($d->colonia)) { $cambio_direccion = true; $_direccion->setColonia($direccion['colonia']); } //id_ciudad if (isset($d->id_ciudad)) { $cambio_direccion = true; $_direccion->setIdCiudad($direccion['id_ciudad']); } //codigo_postal if (isset($d->codigo_postal)) { $cambio_direccion = true; $_direccion->setCodigoPostal($direccion['codigo_postal']); } //telefono if (isset($d->telefono)) { $cambio_direccion = true; $_direccion->setTelefono($direccion['telefono1']); } //telefono2 if (isset($d->telefono2)) { $cambio_direccion = true; $_direccion->setTelefono2($direccion['telefono2']); } //Si cambio algun parametro de direccion, se actualiza el usuario que modifica y la fecha if ($cambio_direccion) { DireccionController::EditarDireccion($_direccion); } else { DireccionController::NuevaDireccion($calle = isset($d->calle) ? $d->calle : "", $numero_exterior = isset($d->numero_exterior) ? $d->numero_exterior : "", $colonia = isset($d->colonia) ? $d->colonia : "", $id_ciudad = isset($d->id_ciudad) ? $d->id_ciudad : "", $codigo_postal = isset($d->codigo_postal) ? $d->codigo_postal : "", $numero_interior = isset($d->numero_interior) ? $d->numero_interior : "", $referencia = isset($d->referencia) ? $d->referencia : "", $telefono = isset($d->telefono) ? $d->telefono : "", $telefono2 = isset($d->telefono2) ? $d->telefono2 : ""); } } } DAO::transBegin(); try { //Se guardan los cambios hechos en la empresa EmpresaDAO::save($empresa); } catch (Exception $e) { DAO::transRollback(); Logger::error("No se pudo modificar la empresa: " . $e); throw new Exception("No se pudo modificar la empresa"); } $impuestos_empresa = ImpuestoEmpresaDAO::search(new ImpuestoEmpresa(array("id_empresa" => $empresa->getIdEmpresa()))); //quitamos los impuestos que no estan actualmente foreach ($impuestos_empresa as $impuesto_empresa) { $exist_ic = false; foreach ($impuestos_compra as $impuesto_compra) { if ($impuesto_compra->getIdImpuesto() == $impuesto_empresa->getIdImpuesto()) { $exist_ic = true; } } if (!$exist_ic) { try { ImpuestoEmpresaDAO::delete($impuesto_empresa); } catch (Exception $e) { Logger::warn("Error al eliminar impuesto : " . $e->getMessage()); } } } $impuestos_empresa = ImpuestoEmpresaDAO::search(new ImpuestoEmpresa(array("id_empresa" => $empresa->getIdEmpresa()))); foreach ($impuestos_empresa as $impuesto_empresa) { $exist_iv = false; foreach ($impuestos_venta as $impuesto_venta) { if ($impuesto_venta->getIdImpuesto() == $impuesto_venta->getIdImpuesto()) { $exist_iv = true; } } if (!$exist_iv) { try { ImpuestoEmpresaDAO::delete($impuesto_empresa); } catch (Exception $e) { Logger::warn("Error al eliminar impuesto : " . $e->getMessage()); } } } //agregamos los impuestos de compra que no existen $impuestos_empresa = ImpuestoEmpresaDAO::search(new ImpuestoEmpresa(array("id_empresa" => $empresa->getIdEmpresa()))); if ($impuestos_compra != NULL) { foreach ($impuestos_compra as $impuesto_compra) { $exist_ic = false; foreach ($impuestos_empresa as $impuesto_empresa) { if ($impuesto_compra->getIdImpuesto() == $impuesto_empresa->getIdImpuesto()) { $exist_ic = true; } } if (!$exist_ic) { try { ImpuestoEmpresaDAO::save(new ImpuestoEmpresa(array("id_empresa" => $empresa->getIdEmpresa(), "id_impuesto" => $impuesto_compra->getIdImpuesto()))); } catch (Exception $e) { Logger::warn("Error al guardar un impuesto compra : " . $e->getMessage()); } } } } //agregamos los impuestos de venta que no existen $impuestos_empresa = ImpuestoEmpresaDAO::search(new ImpuestoEmpresa(array("id_empresa" => $empresa->getIdEmpresa()))); if ($impuestos_venta != NULL) { foreach ($impuestos_venta as $impuesto_venta) { $exist_iv = false; foreach ($impuestos_venta as $impuesto_venta) { if ($impuesto_venta->getIdImpuesto() == $impuesto_venta->getIdImpuesto()) { $exist_iv = true; } } if (!$exist_iv) { try { ImpuestoEmpresaDAO::save(new ImpuestoEmpresa(array("id_empresa" => $empresa->getIdEmpresa(), "id_impuesto" => $impuesto_venta->getIdImpuesto()))); } catch (Exception $e) { Logger::warn("Error al guardar un impuesto venta : " . $e->getMessage()); } } } } if ($cuentas_bancarias != NULL) { foreach ($cuentas_bancarias as $cuenta_bancarias) { //Pendiente hasta que se haga el SPEC de cuentas bancarias } } DAO::transEnd(); Logger::log("Empresa editada con exito"); }
public function testCatalogoCuentasEmpresa() { $dir = new Direccion(); $dir->setIdUsuarioUltimaModificacion(1); $dir->setUltimaModificacion(mktime()); $dir->setCalle("Calle: " . mktime()); DAO::transBegin(); try { DireccionDAO::save($dir); } catch (Exception $e) { DAO::transRollback(); Logger::error("No se ha podido guardar la direccion (Desde Unit Tests): " . $e); if ($e->getCode() == 901) { throw new Exception("No se ha podido guardar la nueva direccion (desde Unit Test)|: " . $e->getMessage(), 901); } throw new Exception("No se ha podido guardar la nueva direccion (Desde Unit Tests)", 901); } DAO::transEnd(); $empresa = new Empresa(); $empresa->setRazonSocial("Razon Social - " . time()); $empresa->setRfc(time()); $empresa->setIdDireccion($dir->getIdDireccion()); $empresa->setFechaAlta(mktime()); $empresa->setIdLogo(1); $empresa->setActivo(1); DAO::transBegin(); try { EmpresaDAO::save($empresa); } catch (Exception $e) { DAO::transRollback(); Logger::error("No se ha podido guardar la nueva empresa (Desde Unit Tests): " . $e); if ($e->getCode() == 901) { throw new Exception("No se ha podido guardar la nueva empresa (desde Unit Test)|: " . $e->getMessage(), 901); } throw new Exception("No se ha podido guardar la nueva empresa (Desde Unit Tests)", 901); } DAO::transEnd(); $res = ContabilidadController::NuevoCatalogoCuentasEmpresa($empresa->getIdEmpresa()); //return array("status"=>"ok","id_catalogo_cuentas"=>$nuevo_catalogo_cuentas->getIdCatalogo()); $this->assertSame('ok', $res["status"]); $this->assertInternalType('int', (int) $res["id_catalogo_cuentas"]); }
/** * Desactivar Almacen */ public function testDesactivarAlmacen() { POSController::DropBd(); $usuario = UsuarioDAO::getAll(); if (sizeof($usuario) == 0) { Logger::error("WHOOOT no hay usuarios en la BD"); return; } $id_usuario = $usuario[0]->getIdUsuario(); @DireccionDAO::save($direccion = new Direccion(array("calle" => "Una Calle", "numero_exterior" => "322", "id_ciudad" => "12", "codigo_postal" => "38000", "ultima_modificacion" => "2012-02-21 22:10:45", "id_usuario_ultima_modificacion" => "2"))); @EmpresaDAO::save($empresa = new Empresa(array("id_direccion" => $direccion->getIdDireccion(), "rfc" => "RFC_" . time(), "razon_social" => "Empresa_Razon_Social__" . time(), "fecha_alta" => "2012-02-21 22:10:45", "activo" => 1, "direccion_web" => "Dir_" . time()))); @SucursalDAO::save($sucursal = new Sucursal(array("id_direccion" => $direccion->getIdDireccion(), "razon_social" => "Sucursal_Razon_Social__" . time(), "saldo_a_favor" => 2000, "fecha_apertura" => "2012-02-21 22:10:45", "activa" => 1))); $tipo_almacen = AlmacenesController::NuevoTipo("Nuevo_Tipo_Almacen___" . time()); Logger::log("Nuevo almacen"); $almacen = AlmacenesController::Nuevo($id_empresa = $empresa->getIdEmpresa(), $id_sucursal = $sucursal->getIdSucursal(), $id_tipo_almacen = $tipo_almacen["id_tipo_almacen"], $nombre = "Almacen_Editar" . time(), $descripcion = "Almacen de prueba_ " . time()); // Desactivamos el Almacen Logger::log("A desactivar almacen recien creado"); $almacen_desactivado = AlmacenesController::Desactivar($id_almacen = $almacen["id_almacen"]); $_almacen = AlmacenDAO::getByPK($almacen["id_almacen"]); $this->assertEquals(0, $_almacen->getActivo()); }