/** * Método principal del comando * @author Esteban De La Fuente Rubio, DeLaF (esteban[at]sasco.cl) * @version 2015-09-30 */ public function main($ambiente = \sasco\LibreDTE\Sii::PRODUCCION) { // obtener conexión a la base de datos $db =& \sowerphp\core\Model_Datasource_Database::get(); // obtener firma electrónica try { $Firma = new \sasco\LibreDTE\FirmaElectronica(); } catch (\sowerphp\core\Exception $e) { $this->out('<error>No fue posible obtener la firma electrónica</error>'); return 1; } // obtener contribuyentes de ambiente de producción $contribuyentes = \sasco\LibreDTE\Sii::getContribuyentes($Firma, $ambiente); if (!$contribuyentes) { $this->out('<error>No fue posible obtener los contribuyentes desde el SII</error>'); return 2; } // procesar cada uno de los contribuyentes $registros = num(count($contribuyentes)); $procesados = 0; foreach ($contribuyentes as $c) { // contabilizar contribuyente procesado $procesados++; if ($this->verbose >= 1) { $this->out('Procesando ' . num($procesados) . '/' . $registros . ': contribuyente ' . $c[1]); } // agregar y/o actualizar datos del contribuyente si no tiene usuario administrador list($rut, $dv) = explode('-', $c[0]); $Contribuyente = new \website\Dte\Model_Contribuyente($rut); if (!$Contribuyente->usuario) { $Contribuyente->dv = $dv; $Contribuyente->razon_social = substr($c[1], 0, 100); if (isset($c[3][9])) { $aux = explode('-', $c[3]); if (isset($aux[2])) { list($d, $m, $Y) = $aux; $Contribuyente->resolucion_fecha = $Y . '-' . $m . '-' . $d; } } if (is_numeric($c[2])) { $Contribuyente->resolucion_numero = (int) $c[2]; } if (strpos($c[4], '@')) { $Contribuyente->intercambio_user = substr($c[4], 0, 50); } $Contribuyente->modificado = date('Y-m-d H:i:s'); try { $Contribuyente->save(); } catch (\sowerphp\core\Exception_Model_Datasource_Database $e) { if ($this->verbose >= 2) { $this->out('<error>Contribuyente ' . $c[1] . ' no pudo ser guardado en la base de datos</error>'); } } } } $this->showStats(); return 0; }
/** * Método que recupera la conexión a la base de datos después de * deserializar * @author Esteban De La Fuente Rubio, DeLaF (esteban[at]delaf.cl) * @version 2014-10-16 */ public function __wakeup() { $this->db = \sowerphp\core\Model_Datasource_Database::get($this->_database); }
/** * Método que corrige los datos de los contribuyentes existentes, cargando: * - razon social * - giro * - actividad económica * @author Esteban De La Fuente Rubio, DeLaF (esteban[at]sasco.cl) * @version 2015-12-31 */ private function corregir() { $db =& \sowerphp\core\Model_Datasource_Database::get(); $contribuyentes = $db->getCol(' SELECT rut FROM contribuyente WHERE usuario IS NULL AND ( giro IS NULL OR actividad_economica IS NULL OR REPLACE(razon_social, \'.\', \'\') = ' . $db->concat('rut', '-', 'dv') . ' ) '); $registros = num(count($contribuyentes)); $procesados = 0; $actualizados = 0; foreach ($contribuyentes as $rut) { $Contribuyente = new \website\Dte\Model_Contribuyente($rut); $response = \sowerphp\core\Network_Http_Socket::get('https://sasco.cl/api/servicios/enlinea/sii/actividad_economica/' . $Contribuyente->rut . '/' . $Contribuyente->dv); if ($response['status']['code'] == 200) { $info = json_decode($response['body'], true); $procesados++; if ($this->verbose) { $this->out('Procesando ' . num($procesados) . '/' . $registros . ': contribuyente ' . $Contribuyente->rut . '-' . $Contribuyente->dv); } $cambios = false; if ($Contribuyente->razon_social == \sowerphp\app\Utility_Rut::addDV($Contribuyente->rut) and !empty($info['razon_social'])) { $Contribuyente->razon_social = substr($info['razon_social'], 0, 100); $cambios = true; } if (!$Contribuyente->actividad_economica and !empty($info['actividades'][0]['codigo'])) { $Contribuyente->actividad_economica = $info['actividades'][0]['codigo']; $cambios = true; } if (!$Contribuyente->giro and !empty($info['actividades'][0]['glosa'])) { $Contribuyente->giro = substr($info['actividades'][0]['glosa'], 0, 80); $cambios = true; } if ($cambios) { try { if ($Contribuyente->save()) { $actualizados++; } } catch (\sowerphp\core\Exception_Model_Datasource_Database $e) { } } } } $this->out('Se actualizaron ' . num($actualizados) . ' contribuyentes de un total de ' . $registros); }