import.php 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. <?php
  2. header('Access-Control-Allow-Origin: *');
  3. header('Cache-Control: no-cache, must-revalidate');
  4. header('Content-type: application/json');
  5. $dbh = new PDO("mysql:host=localhost;dbname=tasks", "root", "gc01mysql");
  6. $dbh->setAttribute(PDO::ATTR_CASE, PDO::CASE_LOWER);
  7. $server = "{imap.1und1.de:993/imap/ssl}INBOX";
  8. $user = "status@global-cube.de";
  9. $passwd = "gc01smtp";
  10. function fehlerberichtAufbereiten ($fehlerbericht, &$fehlerAnzahl, $whitelist) {
  11. $fehlerbericht = str_replace("\r\`", "`", str_replace("\r\"", "\"", str_replace("\r\n", "", $fehlerbericht)));
  12. $fehlerbericht = json_decode($fehlerbericht, true);
  13. if ($whitelist) {
  14. if (!isset($whitelist['Layer'])) $whitelist['Layer'] = array();
  15. if (!isset($whitelist['Report'])) $whitelist['Report'] = array();
  16. if (!isset($whitelist['User'])) $whitelist['User'] = array();
  17. }
  18. foreach ($fehlerbericht as $i => $log) {
  19. if (preg_match("/\.bat$/", $log['Name'])) {
  20. $fehlerbericht[$i]['Errors'][0] = preg_replace("/!! Bitte E-Mailadresse fuer Statusbericht angeben !!/im", "! Bitte E-Mailadresse fuer Statusbericht angeben !", $fehlerbericht[$i]['Errors'][0]);
  21. $fehlerbericht[$i]['Errors'][0] = preg_replace("/!! SMTP-Konfiguration bitte anpassen !!/im", "! SMTP-Konfiguration bitte anpassen !", $fehlerbericht[$i]['Errors'][0]);
  22. $count = 0;
  23. $fehlerbericht[$i]['Errors'][0] = preg_replace("/(!![^\n]*!!)/im", "<b>$1</b>",$fehlerbericht[$i]['Errors'][0], -1, $count);
  24. $count2 = 0;
  25. $fehlerbericht[$i]['Errors'][0] = preg_replace("/(\(\w{2}\d{4}\) [^\r]*)/im", "<b>$1</b>", $fehlerbericht[$i]['Errors'][0], -1, $count2);
  26. //die(print($log['Errors'][0]));
  27. if ($count > 0 || $count2 > 0) {
  28. $fehlerbericht[$i]['ErrorLevel'] = 2;
  29. for ($j = 1; $j < $count; $j++) {
  30. $fehlerbericht[$i]['Errors'][] = "";
  31. }
  32. $fehlerAnzahl += 1;
  33. }
  34. } else if ($whitelist && count($fehlerbericht[$i]['Errors']) > 0 && ($fehlerbericht[$i]['Type'] == 'Versand' || $fehlerbericht[$i]['Type'] == 'Portal')) {
  35. $fehlerbericht[$i]['Errors2'] = array();
  36. foreach($fehlerbericht[$i]['Errors'] as $j => $e) {
  37. if (in_array($e['Layer'], $whitelist['Layer']) || in_array($e['Report'], $whitelist['Report']) || in_array($e['User'], $whitelist['User'])) {
  38. $fehlerbericht[$i]['Errors2'][] = $fehlerbericht[$i]['Errors'][$j];
  39. unset($fehlerbericht[$i]['Errors'][$j]);
  40. }
  41. }
  42. if (count($fehlerbericht[$i]['Errors']) == 0) {
  43. $fehlerbericht[$i]['ErrorLevel'] = 3;
  44. $fehlerAnzahl -= 1;
  45. }
  46. }
  47. }
  48. return addslashes(json_encode($fehlerbericht));
  49. }
  50. $q = $dbh->query("SELECT kunde, whitelist, version FROM kunden");
  51. $cust = $q->fetchAll(PDO::FETCH_ASSOC);
  52. $customers = array();
  53. $version = array();
  54. foreach ($cust as $c) {
  55. $customers[$c['kunde']] = json_decode(stripslashes($c['whitelist']), true);
  56. $version[$c['kunde']] = $c['version'];
  57. }
  58. $mbox = imap_open($server, $user, $passwd) or die("Could not open Mailbox - try again later!");
  59. $message_count = imap_num_msg($mbox);
  60. $result = array();
  61. for ($m = 1; $m <= $message_count; $m++) {
  62. $fehlerAnzahl = 0;
  63. $header = imap_headerinfo($mbox, $m);
  64. $rec = explode(";", $header->Subject);
  65. if (count($rec) < 3) continue;
  66. $date = date("Y-m-d", strtotime($header->MailDate));
  67. $result[] = $date . " " . $rec[2] . " - " . $rec[0];
  68. $structure = imap_fetchstructure($mbox, $m);
  69. $attachments = array();
  70. if (isset($structure->parts) && count($structure->parts)) {
  71. for ($i = 0; $i < count($structure->parts); $i++) {
  72. $attachments[$i] = array(
  73. 'is_attachment' => false,
  74. 'filename' => '',
  75. 'name' => '',
  76. 'attachment' => ''
  77. );
  78. if ($structure->parts[$i]->ifdparameters) {
  79. foreach ($structure->parts[$i]->dparameters as $object) {
  80. if (strtolower($object->attribute) == 'filename') {
  81. $attachments[$i]['is_attachment'] = true;
  82. $attachments[$i]['filename'] = $object->value;
  83. }
  84. }
  85. }
  86. if ($structure->parts[$i]->ifparameters) {
  87. foreach ($structure->parts[$i]->parameters as $object) {
  88. if (strtolower($object->attribute) == 'name') {
  89. $attachments[$i]['is_attachment'] = true;
  90. $attachments[$i]['name'] = $object->value;
  91. }
  92. }
  93. }
  94. if ($attachments[$i]['is_attachment']) {
  95. $attachments[$i]['attachment'] = imap_fetchbody($mbox, $m, $i + 1);
  96. if ($structure->parts[$i]->encoding == 3) { // 3 = BASE64
  97. $attachments[$i]['attachment'] = base64_decode($attachments[$i]['attachment']);
  98. } elseif ($structure->parts[$i]->encoding == 4) { // 4 = QUOTED-PRINTABLE
  99. $attachments[$i]['attachment'] = quoted_printable_decode($attachments[$i]['attachment']);
  100. }
  101. }
  102. }
  103. }
  104. $fehlerbericht = addslashes(trim(imap_fetchbody($mbox, $m, '1')));
  105. $info = 0;
  106. $starter = 0;
  107. foreach ($attachments as $key => $attachment) {
  108. if ($attachment['is_attachment']) {
  109. if ($attachment['filename'] == "info.json") {
  110. $info = addslashes($attachment['attachment']);
  111. }
  112. if ($attachment['filename'] == "gcstarter.json") {
  113. $starter = addslashes($attachment['attachment']);
  114. }
  115. if ($attachment['filename'] == "fehlerbericht.json") {
  116. $fehlerbericht = fehlerberichtAufbereiten($attachment['attachment'], $fehlerAnzahl, @$customers[$rec[0]]);
  117. }
  118. }
  119. }
  120. $rec[] = $fehlerbericht;
  121. $rec[4] += $fehlerAnzahl;
  122. $insertQuery = "INSERT INTO status_meldung (kunde, start, ende, datum, anzahl, fehlerbericht) VALUES ('" . implode("','", $rec) . "')";
  123. $c = $dbh->query($insertQuery);
  124. if ($c) {
  125. imap_delete($mbox, $m);
  126. } else {
  127. $result[] = $insertQuery;
  128. $result[] = $dbh->errorInfo();
  129. }
  130. if (!isset($customers[$rec[0]])) {
  131. $dbh->query("INSERT INTO kunden (kunde, start_soll, ende_soll, erster_status, system) VALUES ('{$rec[0]}', '{$rec[1]}', '{$rec[2]}', '{$rec[3]}', '?')");
  132. $customers[$rec[0]] = array();
  133. }
  134. $ver = "";
  135. if (preg_match("/Version:\s*(\d{4}-\d{2}-\d{2})_?(\w*)?/", $fehlerbericht, $ver) && (!isset($version[$rec[0]]) || $version[$rec[0]] != $ver[1])) {
  136. $beta = (count($ver) > 2) ? '1' : '0';
  137. $q = $dbh->query("UPDATE kunden SET version = '{$ver[1]}', beta_version = '{$beta}' WHERE kunde = '{$rec[0]}'");
  138. }
  139. if ($info) {
  140. $q = $dbh->query("SELECT * FROM kunden_config WHERE kunde = '{$rec[0]}' ORDER BY datum DESC LIMIT 1");
  141. $last = ($q && $q->rowCount() == 1) ? $q->fetch(PDO::FETCH_ASSOC) : false;
  142. if (!$last || addslashes($last['info']) != $info) {
  143. $dbh->query("INSERT INTO kunden_config (kunde, datum, info) VALUES ('{$rec[0]}', '{$rec[3]}', '{$info}')");
  144. }
  145. }
  146. if ($starter) {
  147. $dbh->query("INSERT INTO kunden_gcstarter (kunde, datum, gcstarter) VALUES ('{$rec[0]}', '{$rec[3]}', '{$starter}')");
  148. }
  149. }
  150. imap_expunge($mbox);
  151. imap_close($mbox);
  152. echo json_encode($result);