/**
  * 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 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);
 }