subject = $request->subject; $message->from = $request->from; $message->to = $request->to; if ($request->has('html')) { $message->body = $request->html; } else { $message->body = $request->text; } $message->save(); if ($request->has('content-ids')) { $message->attachments = $request->get('attachment-info'); $message->save(); $directory = './attachments/' . $message->id; is_dir($directory) || mkdir($directory, 0777, true); $attachment_ids = json_decode($request->get('attachment-info')); foreach ($attachment_ids as $attachment_id => $attachment_info) { $allowed = explode(',', 'csv,doc,docx,xls,xlsx,ppt,pptx,xps,pdf,dxf,ai,psd,eps,ps,svg,ttf,zip,rar,tar,gzip,mp3,mpeg,wav,ogg,jpeg,jpg,png,gif,bmp,tif,webm,mpeg4,3gpp,mov,avi,mpegs,wmv,flx,txt'); $file = explode('.', $attachment_info->filename); if (in_array($file[count($file) - 1], $allowed)) { Storage::disk('tmp')->putFileAs($directory, $request->file($attachment_id), $attachment_info->filename); } } } } public static function getMessages($email): array { $limit = json_decode(config('app.settings.configuration_settings'))->fetch_messages_limit ?? 15; $messages = Message::where('to', $email)->orWhere('to', 'like', '%<' . $email . '>%')->limit($limit)->get(); $response = [ 'data' => [], 'notifications' => [] ]; foreach ($messages as $message) { $content = str_replace('body); if (json_decode(config('app.settings.configuration_settings'))->enable_masking_external_link) { $content = str_replace('href="', 'href="https://href.li/?', $content); } $obj = []; $obj['subject'] = $message->subject; $sender = explode('<', $message->from); $obj['sender_name'] = $sender[0]; if (isset($sender[1])) { $obj['sender_email'] = str_replace('>', '', $sender[1]); } else { $obj['sender_email'] = $obj['sender_name']; } $obj['timestamp'] = $message->created_at; $obj['date'] = $message->created_at->format(json_decode(config('app.settings.configuration_settings'))->date_format ?? 'd M Y h:i A'); $obj['datediff'] = $message->created_at->diffForHumans(); $obj['id'] = $message->id; $obj['content'] = $content; $obj['attachments'] = []; $domain = explode('@', $obj['sender_email'])[1]; $blocked = in_array($domain, json_decode(config('app.settings.configuration_settings'))->blocked_domains); if ($blocked) { $obj['subject'] = __('Blocked'); $obj['content'] = __('Emails from') . ' ' . $domain . ' ' . __('are blocked by Admin'); } if ($message->attachments && !$blocked) { $attachments = json_decode($message->attachments); foreach ($attachments as $id => $attachment) { $url = config('app.settings.app_base_url') . '/tmp/attachments/' . $message->id . '/' . $attachment->filename; if (str_contains($obj['content'], $id)) { $obj['content'] = str_replace('cid:' . $id, $url, $obj['content']); } else { if (Storage::disk('tmp')->exists('attachments/' . $message->id . '/' . $attachment->filename)) { $obj['attachments'][] = [ 'file' => $attachment->filename, 'url' => $url ]; } } } } $response['data'][] = $obj; if (!$message->is_seen) { $response['notifications'][] = [ 'subject' => $obj['subject'], 'sender_name' => $obj['sender_name'], 'sender_email' => $obj['sender_email'] ]; if (config('app.zemail_log')) { file_put_contents(storage_path('logs/zemail.csv'), request()->ip() . "," . date("Y-m-d h:i:s a") . "," . $obj['sender_email'] . "," . $email . PHP_EOL, FILE_APPEND); } $message->is_seen = true; $message->save(); } } return $response; } public static function fetchMessages($email, $type = 'to', $deleted = []): array { $allowed = explode(',', 'doc,docx,xls,xlsx,ppt,pptx,xps,pdf,dxf,ai,psd,eps,ps,svg,ttf,zip,rar,tar,gzip,mp3,mpeg,wav,ogg,jpeg,jpg,png,gif,bmp,tif,webm,mpeg4,3gpp,mov,avi,mpegs,wmv,flx,txt'); $connection = ZEmail::connectMailBox(); $mailbox = $connection->getMailbox('INBOX'); $search = new SearchExpression(); if ($type == 'cc') { $search->addCondition(new Cc($email)); } else { $search->addCondition(new To($email)); } $search->addCondition(new Since((new \DateTime('-1 day')))); $messages = $mailbox->getMessages($search, \SORTDATE, true); $limit = json_decode(config('app.settings.configuration_settings'))->fetch_messages_limit ?? 15; $count = 1; $response = [ 'data' => [], 'notifications' => [] ]; foreach ($messages as $message) { if (in_array($message->getNumber(), $deleted)) { $message->delete(); continue; } $blocked = false; $sender = $message->getFrom(); $date = $message->getDate(); if (!$date) { $date = new \DateTime(); if ($message->getHeaders()->get('udate')) { $date->setTimestamp($message->getHeaders()->get('udate')); } } $datediff = new Carbon($date); $content = ''; $html = $message->getBodyHtml(); if ($html) { $content = str_replace('getBodyText(); $content = str_replace('', $text)); } if (json_decode(config('app.settings.configuration_settings'))->enable_masking_external_link) { $content = str_replace('href="', 'href="http://href.li/?', $content); } $obj = []; $obj['subject'] = $message->getSubject(); $obj['sender_name'] = $sender->getName(); $obj['sender_email'] = $sender->getAddress(); $obj['timestamp'] = $message->getDate(); $obj['date'] = $date->format(json_decode(config('app.settings.configuration_settings'))->date_format ?? 'd M Y h:i A'); $obj['datediff'] = $datediff->diffForHumans(); $obj['id'] = $message->getNumber(); $obj['content'] = $content; $obj['attachments'] = []; //Checking if Sender is Blocked $domain = explode('@', $obj['sender_email'])[1]; $blocked = in_array($domain, json_decode(config('app.settings.configuration_settings'))->blocked_domains); if ($blocked) { $obj['subject'] = __('Blocked'); $obj['content'] = __('Emails from') . ' ' . $domain . ' ' . __('are blocked by Admin'); } if ($message->hasAttachments() && !$blocked) { $attachments = $message->getAttachments(); $directory = './tmp/attachments/' . $obj['id'] . '/'; is_dir($directory) || mkdir($directory, 0777, true); foreach ($attachments as $attachment) { $filenameArray = explode('.', $attachment->getFilename()); $extension = $filenameArray[count($filenameArray) - 1]; if (in_array($extension, $allowed)) { if (!file_exists($directory . $attachment->getFilename())) { file_put_contents( $directory . $attachment->getFilename(), $attachment->getDecodedContent() ); } if ($attachment->getFilename() !== 'undefined') { $url = config('app.settings.app_base_url') . str_replace('./', '/', $directory . $attachment->getFilename()); $structure = $attachment->getStructure(); if (isset($structure->id) && str_contains($obj['content'], trim($structure->id, '<>'))) { $obj['content'] = str_replace('cid:' . trim($structure->id, '<>'), $url, $obj['content']); } $obj['attachments'][] = [ 'file' => $attachment->getFilename(), 'url' => $url ]; } } } } $response['data'][] = $obj; if (!$message->isSeen()) { $response['notifications'][] = [ 'subject' => $obj['subject'], 'sender_name' => $obj['sender_name'], 'sender_email' => $obj['sender_email'] ]; if (config('app.zemail_log')) { file_put_contents(storage_path('logs/zemail.csv'), request()->ip() . "," . date("Y-m-d h:i:s a") . "," . $obj['sender_email'] . "," . $email . PHP_EOL, FILE_APPEND); } } $message->markAsSeen(); if (++$count > $limit) { break; } } $response['data'] = array_reverse($response['data']); $connection->expunge(); return $response; } // public static function fetchMessages($email, $type = 'to', $deleted = []): array // { // $startTime = microtime(true); // $allowed = explode(',', 'doc,docx,xls,xlsx,ppt,pptx,xps,pdf,dxf,ai,psd,eps,ps,svg,ttf,zip,rar,tar,gzip,mp3,mpeg,wav,ogg,jpeg,jpg,png,gif,bmp,tif,webm,mpeg4,3gpp,mov,avi,mpegs,wmv,flx,txt'); // $connection = ZEmail::connectMailBox(); // // $mailbox = $connection->getMailbox('INBOX'); // $search = new SearchExpression(); // if ($type == 'cc') { // $search->addCondition(new Cc($email)); // } else { // $search->addCondition(new To($email)); // } // $search->addCondition(new Since((new \DateTime('-1 day')))); // $stepStart = microtime(true); // $messages = $mailbox->getMessages($search, \SORTDATE, true); // \Log::info("1111 messages took: " . (microtime(true) - $stepStart)); // // $limit = json_decode(config('app.settings.configuration_settings'))->fetch_messages_limit ?? 15; // $count = 1; // $response = [ // 'data' => [], // 'notifications' => [] // ]; // // foreach ($messages as $message) { // if (in_array($message->getNumber(), $deleted)) { // $message->delete(); // continue; // } // $blocked = false; // $sender = $message->getFrom(); // $date = $message->getDate(); // if (!$date) { // $date = new \DateTime(); // if ($message->getHeaders()->get('udate')) { // $date->setTimestamp($message->getHeaders()->get('udate')); // } // } // $datediff = new Carbon($date); // $content = ''; // $html = $message->getBodyHtml(); // if ($html) { // $content = str_replace('getBodyText(); // $content = str_replace('', $text)); // } // if (json_decode(config('app.settings.configuration_settings'))->enable_masking_external_link) { // $content = str_replace('href="', 'href="http://href.li/?', $content); // } // $obj = []; // $obj['subject'] = $message->getSubject(); // $obj['sender_name'] = $sender->getName(); // $obj['sender_email'] = $sender->getAddress(); // $obj['timestamp'] = $message->getDate(); // $obj['date'] = $date->format(json_decode(config('app.settings.configuration_settings'))->date_format ?? 'd M Y h:i A'); // $obj['datediff'] = $datediff->diffForHumans(); // $obj['id'] = $message->getNumber(); // $obj['content'] = $content; // $obj['attachments'] = []; // //Checking if Sender is Blocked // $domain = explode('@', $obj['sender_email'])[1]; // $blocked = in_array($domain, json_decode(config('app.settings.configuration_settings'))->blocked_domains); // if ($blocked) { // $obj['subject'] = __('Blocked'); // $obj['content'] = __('Emails from') . ' ' . $domain . ' ' . __('are blocked by Admin'); // } // if ($message->hasAttachments() && !$blocked) { // $attachments = $message->getAttachments(); // $directory = './tmp/attachments/' . $obj['id'] . '/'; // is_dir($directory) || mkdir($directory, 0777, true); // foreach ($attachments as $attachment) { // $filenameArray = explode('.', $attachment->getFilename()); // $extension = $filenameArray[count($filenameArray) - 1]; // if (in_array($extension, $allowed)) { // if (!file_exists($directory . $attachment->getFilename())) { // file_put_contents( // $directory . $attachment->getFilename(), // $attachment->getDecodedContent() // ); // } // if ($attachment->getFilename() !== 'undefined') { // $url = config('app.settings.app_base_url') . str_replace('./', '/', $directory . $attachment->getFilename()); // $structure = $attachment->getStructure(); // if (isset($structure->id) && str_contains($obj['content'], trim($structure->id, '<>'))) { // $obj['content'] = str_replace('cid:' . trim($structure->id, '<>'), $url, $obj['content']); // } // $obj['attachments'][] = [ // 'file' => $attachment->getFilename(), // 'url' => $url // ]; // } // } // } // } // $response['data'][] = $obj; // if (!$message->isSeen()) { // $response['notifications'][] = [ // 'subject' => $obj['subject'], // 'sender_name' => $obj['sender_name'], // 'sender_email' => $obj['sender_email'] // ]; // if (config('app.zemail_log')) { // file_put_contents(storage_path('logs/zemail.csv'), request()->ip() . "," . date("Y-m-d h:i:s a") . "," . $obj['sender_email'] . "," . $email . PHP_EOL, FILE_APPEND); // } // } // $message->markAsSeen(); // if (++$count > $limit) { // break; // } // } // // $response['data'] = array_reverse($response['data']); // $connection->expunge(); // $endTime = microtime(true); // $executionTime = $endTime - $startTime; // \Log::info("getMessages execution time: {$executionTime} seconds"); // return $response; // } }