From edff34b548db49e94db2b6548adc95cc6001dcf5 Mon Sep 17 00:00:00 2001 From: yehudah Date: Sun, 15 Oct 2017 06:46:12 +0000 Subject: release git-svn-id: https://plugins.svn.wordpress.org/post-smtp/trunk@1746635 b8457f37-d9ea-0310-8a92-e5e31aec5664 --- .../Postman-Email-Log/PostmanEmailLogService.php | 279 +++++++++++++++++++++ 1 file changed, 279 insertions(+) create mode 100644 Postman/Postman-Email-Log/PostmanEmailLogService.php (limited to 'Postman/Postman-Email-Log/PostmanEmailLogService.php') diff --git a/Postman/Postman-Email-Log/PostmanEmailLogService.php b/Postman/Postman-Email-Log/PostmanEmailLogService.php new file mode 100644 index 0000000..b6dd98b --- /dev/null +++ b/Postman/Postman-Email-Log/PostmanEmailLogService.php @@ -0,0 +1,279 @@ +logger = new PostmanLogger ( get_class ( $this ) ); + } + + /** + * singleton instance + */ + public static function getInstance() { + static $inst = null; + if ($inst === null) { + $inst = new PostmanEmailLogService (); + } + return $inst; + } + + /** + * Logs successful email attempts + * + * @param PostmanMessage $message + * @param unknown $transcript + * @param PostmanModuleTransport $transport + */ + public function writeSuccessLog(PostmanEmailLog $log, PostmanMessage $message, $transcript, PostmanModuleTransport $transport) { + if (PostmanOptions::getInstance ()->isMailLoggingEnabled ()) { + $statusMessage = ''; + $status = true; + $subject = $message->getSubject (); + if (empty ( $subject )) { + $statusMessage = sprintf ( '%s: %s', __ ( 'Warning', Postman::TEXT_DOMAIN ), __ ( 'An empty subject line can result in delivery failure.', Postman::TEXT_DOMAIN ) ); + $status = 'WARN'; + } + $this->createLog ( $log, $message, $transcript, $statusMessage, $status, $transport ); + $this->writeToEmailLog ( $log ); + } + } + + /** + * Logs failed email attempts, requires more metadata so the email can be resent in the future + * + * @param PostmanMessage $message + * @param unknown $transcript + * @param PostmanModuleTransport $transport + * @param unknown $statusMessage + * @param unknown $originalTo + * @param unknown $originalSubject + * @param unknown $originalMessage + * @param unknown $originalHeaders + */ + public function writeFailureLog(PostmanEmailLog $log, PostmanMessage $message = null, $transcript, PostmanModuleTransport $transport, $statusMessage) { + if (PostmanOptions::getInstance ()->isMailLoggingEnabled ()) { + $this->createLog ( $log, $message, $transcript, $statusMessage, false, $transport ); + $this->writeToEmailLog ( $log ); + } + } + + /** + * Writes an email sending attempt to the Email Log + * + * From http://wordpress.stackexchange.com/questions/8569/wp-insert-post-php-function-and-custom-fields + */ + private function writeToEmailLog(PostmanEmailLog $log) { + // nothing here is sanitized as WordPress should take care of + // making database writes safe + $my_post = array ( + 'post_type' => PostmanEmailLogPostType::POSTMAN_CUSTOM_POST_TYPE_SLUG, + 'post_title' => $log->subject, + 'post_content' => $log->body, + 'post_excerpt' => $log->statusMessage, + 'post_status' => PostmanEmailLogService::POSTMAN_CUSTOM_POST_STATUS_PRIVATE + ); + + // Insert the post into the database (WordPress gives us the Post ID) + $post_id = wp_insert_post ( $my_post ); + $this->logger->debug ( sprintf ( 'Saved message #%s to the database', $post_id ) ); + $this->logger->trace ( $log ); + + // Write the meta data related to the email + update_post_meta ( $post_id, 'success', $log->success ); + update_post_meta ( $post_id, 'from_header', $log->sender ); + if (! empty ( $log->toRecipients )) { + update_post_meta ( $post_id, 'to_header', $log->toRecipients ); + } + if (! empty ( $log->ccRecipients )) { + update_post_meta ( $post_id, 'cc_header', $log->ccRecipients ); + } + if (! empty ( $log->bccRecipients )) { + update_post_meta ( $post_id, 'bcc_header', $log->bccRecipients ); + } + if (! empty ( $log->replyTo )) { + update_post_meta ( $post_id, 'reply_to_header', $log->replyTo ); + } + update_post_meta ( $post_id, 'transport_uri', $log->transportUri ); + + if (! $log->success || true) { + // alwas add the meta data so we can re-send it + update_post_meta ( $post_id, 'original_to', $log->originalTo ); + update_post_meta ( $post_id, 'original_subject', $log->originalSubject ); + update_post_meta ( $post_id, 'original_message', $log->originalMessage ); + update_post_meta ( $post_id, 'original_headers', $log->originalHeaders ); + } + + // we do not sanitize the session transcript - let the reader decide how to handle the data + update_post_meta ( $post_id, 'session_transcript', $log->sessionTranscript ); + + // truncate the log (remove older entries) + $purger = new PostmanEmailLogPurger (); + $purger->truncateLogItems ( PostmanOptions::getInstance ()->getMailLoggingMaxEntries () ); + } + + /** + * Creates a Log object for use by writeToEmailLog() + * + * @param PostmanMessage $message + * @param unknown $transcript + * @param unknown $statusMessage + * @param unknown $success + * @param PostmanModuleTransport $transport + * @return PostmanEmailLog + */ + private function createLog(PostmanEmailLog $log, PostmanMessage $message = null, $transcript, $statusMessage, $success, PostmanModuleTransport $transport) { + if ($message) { + $log->sender = $message->getFromAddress ()->format (); + $log->toRecipients = $this->flattenEmails ( $message->getToRecipients () ); + $log->ccRecipients = $this->flattenEmails ( $message->getCcRecipients () ); + $log->bccRecipients = $this->flattenEmails ( $message->getBccRecipients () ); + $log->subject = $message->getSubject (); + $log->body = $message->getBody (); + if (null !== $message->getReplyTo ()) { + $log->replyTo = $message->getReplyTo ()->format (); + } + } + $log->success = $success; + $log->statusMessage = $statusMessage; + $log->transportUri = PostmanTransportRegistry::getInstance ()->getPublicTransportUri ( $transport ); + $log->sessionTranscript = $log->transportUri . "\n\n" . $transcript; + return $log; + } + + /** + * Creates a readable "TO" entry based on the recipient header + * + * @param array $addresses + * @return string + */ + private static function flattenEmails(array $addresses) { + $flat = ''; + $count = 0; + foreach ( $addresses as $address ) { + if ($count >= 3) { + $flat .= sprintf ( __ ( '.. +%d more', Postman::TEXT_DOMAIN ), sizeof ( $addresses ) - $count ); + break; + } + if ($count > 0) { + $flat .= ', '; + } + $flat .= $address->format (); + $count ++; + } + return $flat; + } + } +} + +if (! class_exists ( 'PostmanEmailLogPurger' )) { + class PostmanEmailLogPurger { + private $posts; + private $logger; + + /** + * + * @return unknown + */ + function __construct() { + $this->logger = new PostmanLogger ( get_class ( $this ) ); + $args = array ( + 'posts_per_page' => 1000, + 'offset' => 0, + 'category' => '', + 'category_name' => '', + 'orderby' => 'date', + 'order' => 'DESC', + 'include' => '', + 'exclude' => '', + 'meta_key' => '', + 'meta_value' => '', + 'post_type' => PostmanEmailLogPostType::POSTMAN_CUSTOM_POST_TYPE_SLUG, + 'post_mime_type' => '', + 'post_parent' => '', + 'post_status' => 'private', + 'suppress_filters' => true + ); + $this->posts = get_posts ( $args ); + } + + /** + * + * @param array $posts + * @param unknown $postid + */ + function verifyLogItemExistsAndRemove($postid) { + $force_delete = true; + foreach ( $this->posts as $post ) { + if ($post->ID == $postid) { + $this->logger->debug ( 'deleting log item ' . intval($postid) ); + wp_delete_post ( $postid, $force_delete ); + return; + } + } + $this->logger->warn ( 'could not find Postman Log Item #' . $postid ); + } + function removeAll() { + $this->logger->debug ( sprintf ( 'deleting %d log items ', sizeof ( $this->posts ) ) ); + $force_delete = true; + foreach ( $this->posts as $post ) { + wp_delete_post ( $post->ID, $force_delete ); + } + } + + /** + * + * @param unknown $size + */ + function truncateLogItems($size) { + $index = count ( $this->posts ); + $force_delete = true; + while ( $index > $size ) { + $postid = $this->posts [-- $index]->ID; + $this->logger->debug ( 'deleting log item ' . $postid ); + wp_delete_post ( $postid, $force_delete ); + } + } + } +} -- cgit v1.2.3