funciones_helper.php 7.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240
  1. <?php
  2. defined('BASEPATH') or exit('No direct script access allowed');
  3. /**
  4. *
  5. * Helpers Funciones_helper
  6. *
  7. * This Helpers for ...
  8. *
  9. * @package CodeIgniter
  10. * @category Helpers
  11. * @author Setiawan Jodi <jodisetiawan@fisip-untirta.ac.id>
  12. * @link https://github.com/setdjod/myci-extension/
  13. *
  14. */
  15. // ------------------------------------------------------------------------
  16. if (!function_exists('guardar_log')) {
  17. function guardar_log($nombre_archivo = "", $texto = "", $echo = false, $tipo = 1)
  18. {
  19. $textoTipoLogico = "";
  20. if ($tipo == 1) {
  21. $textoTipoLogico = "INFO";
  22. } else if ($tipo == 2) {
  23. $textoTipoLogico = "ERROR";
  24. }
  25. //CREAMOS EL REGISTRO PARA EL LOG
  26. $registro = date('d-m-Y H:i:s') . ' - ' . $textoTipoLogico . " - " . $texto;
  27. //FICHERO DE LOG
  28. $file_name = APPPATH . 'logs/' . $nombre_archivo . '.txt';
  29. //GUARDAMOS EL REGISTRO EN EL FICHERO DE LOG
  30. $f = fopen($file_name, "a");
  31. fwrite($f, $registro . PHP_EOL);
  32. fclose($f);
  33. //SI ES NECESARIO SE MUESTRA POR PANTALLA
  34. if ($echo == true) {
  35. //echo $registro . '<br>';
  36. }
  37. return $texto . '<br>';
  38. }
  39. }
  40. if (!function_exists("insertBucle")) {
  41. function insertBucle($fila_archivo, $nombreTabla, $nombreLog): int
  42. {
  43. $contador = 1;
  44. $conjunto = array();
  45. $CI = &get_instance();
  46. foreach ($fila_archivo as $row) {
  47. $conjunto[] = $row;
  48. $contador++;
  49. if ($contador % 5000 == 0) {
  50. guardar_log($nombreLog, count($conjunto));
  51. $CI->db->insert_batch($nombreTabla, $conjunto);
  52. $conjunto = array();
  53. }
  54. }
  55. if (count($conjunto) > 0) {
  56. guardar_log($nombreLog, count($conjunto));
  57. $CI->db->insert_batch($nombreTabla, $conjunto);
  58. }
  59. gc_collect_cycles();
  60. /*$query = $this->db->query($sql);
  61. $result = $query->result();
  62. $query->free_result();*/
  63. return count($conjunto);
  64. }
  65. }
  66. if (!function_exists("insertBucleDuplicateOnKey")) {
  67. function insertBucleDuplicateOnKey($fila_archivo, $nombreTabla, $nombreLog)
  68. {
  69. $contador = 1;
  70. $conjunto = array();
  71. $CI = &get_instance();
  72. foreach ($fila_archivo as $row) {
  73. if ($nombreTabla == "bruto_datos_iniciales" || $nombreTabla == "maestro_datos_iniciales_licitacion") {
  74. if (is_array($row)) {
  75. guardar_log($nombreLog, "ID_licitacion-" . $row['id_licitacion']);
  76. } else {
  77. guardar_log($nombreLog, "ID_licitacion-" . $row->id_licitacion);
  78. }
  79. }
  80. $conjunto[] = $row;
  81. $contador++;
  82. if ($contador % 5000 == 0) {
  83. guardar_log($nombreLog, "Insertados - " . count($conjunto));
  84. //$CI->db->insert_batch($nombreTabla, $conjunto);
  85. $CI->db->insert_on_duplicate_update_batch($nombreTabla, $conjunto, $nombreLog);
  86. $conjunto = array();
  87. }
  88. }
  89. if (count($conjunto) > 0) {
  90. guardar_log($nombreLog, "Insertados - " . count($conjunto));
  91. //$CI->db->insert_batch($nombreTabla, $conjunto);
  92. $CI->db->insert_on_duplicate_update_batch($nombreTabla, $conjunto, $nombreLog);
  93. }
  94. unset($conjunto);
  95. gc_collect_cycles();
  96. return $CI->db->insert_id();
  97. }
  98. }
  99. if (!function_exists(("check_permisos_template"))) {
  100. function check_permisos_template($view_file_name, $data_array = array(), $vista_permiso = "home")
  101. {
  102. $CI = &get_instance();
  103. if ($CI->session->zonas != "") {
  104. $CI->load->model("Home_model");
  105. $vistas = $CI->Home_model->getPermisosVistaUsuario($CI->session->tipo_usuario);
  106. if ($CI->session->tipo_usuario == 1) {
  107. $CI->template_dashboard->load_template($view_file_name, $data_array);
  108. } else {
  109. if (in_array($vista_permiso, $vistas)) {
  110. $CI->template_dashboard->load_template($view_file_name, $data_array);
  111. } else {
  112. redirect("home");
  113. }
  114. }
  115. } else {
  116. redirect("login", "refresh");
  117. }
  118. }
  119. }
  120. if (!function_exists("pretty_dump")) {
  121. function pretty_dump($data)
  122. {
  123. echo '<pre>' . var_export($data, true) . '</pre>';
  124. }
  125. }
  126. if (!function_exists("enviarEmail")) {
  127. function enviarEmail($asunto, $body, $adjuntos = array(), $print_result = false)
  128. {
  129. $CI = &get_instance();
  130. $CI->load->model("Parser_model");
  131. $datosEmails = $CI->Parser_model->getDatosEmailEnvio();
  132. if ($datosEmails['num_rows'] > 0) {
  133. $userSmtp = $datosEmails['datos']->userSMTP;
  134. $passSMTP = $datosEmails['datos']->passSMTP;
  135. $emailToSend = $datosEmails['datos']->emailToSend;
  136. $hostname = $datosEmails['datos']->hostname;
  137. $port = $datosEmails['datos']->port;
  138. if (trim($userSmtp) && trim($passSMTP) && trim($emailToSend) && trim($hostname) && trim($port)) {
  139. try {
  140. $CI = &get_instance();
  141. $CI->load->library('email');
  142. $config['protocol'] = 'smtp';
  143. $config['smtp_host'] = $hostname;
  144. $config['smtp_user'] = $userSmtp;
  145. $config['smtp_pass'] = $passSMTP;
  146. $config['smtp_crypto'] = 'ssl';
  147. $config['smtp_port'] = $port;
  148. $config['mailtype'] = 'html';
  149. $config['wordwrap'] = 'TRUE';
  150. $config['newline'] = "\r\n";
  151. $config['priority'] = 5;
  152. $config['crlf'] = "\r\n";
  153. $CI->email->initialize($config);
  154. $CI->email->clear(true);
  155. $CI->email->from($userSmtp);
  156. $CI->email->to($emailToSend);
  157. $CI->email->subject($asunto);
  158. $CI->email->message($body);
  159. if ($adjuntos) {
  160. foreach ($adjuntos as $row) {
  161. $CI->email->attach($row);
  162. }
  163. }
  164. if ($print_result) {
  165. $CI->email->send(true);
  166. $CI->email->print_debugger();
  167. } else {
  168. $CI->email->send(true);
  169. }
  170. } catch (\Throwable $th) {
  171. guardar_log("ErrorEnvioEmail_" . date("d-m-Y"), "Se ha producido un error al enviar el email de inicio y/o el excel", false, 2);
  172. }
  173. }
  174. }
  175. }
  176. }
  177. if (!function_exists("eliminarArchivosProcesoCompleto")) {
  178. function eliminarArchivosProcesoCompleto($ruta)
  179. {
  180. $files = glob($ruta . "/format/*");
  181. foreach ($files as $file) { // iterate files
  182. if (is_file($file)) {
  183. unlink($file); // delete file
  184. }
  185. }
  186. rmdir($ruta . "/format");
  187. rmdir($ruta);
  188. }
  189. }
  190. // ------------------------------------------------------------------------
  191. /* End of file Funciones_helper.php */
  192. /* Location: ./application/helpers/Funciones_helper.php */