summaryrefslogtreecommitdiff
path: root/Postman/Postman-Mail/PostmanEmailAddress.php
diff options
context:
space:
mode:
authoryehudah <yehudah@b8457f37-d9ea-0310-8a92-e5e31aec5664>2017-10-15 06:46:12 +0000
committeryehudah <yehudah@b8457f37-d9ea-0310-8a92-e5e31aec5664>2017-10-15 06:46:12 +0000
commitedff34b548db49e94db2b6548adc95cc6001dcf5 (patch)
tree40ff112761d82af1d8c1c89d30ede8206502e17b /Postman/Postman-Mail/PostmanEmailAddress.php
parent2065680a6ff5379064031c260433bf9a9cd314b9 (diff)
downloadPost-SMTP-edff34b548db49e94db2b6548adc95cc6001dcf5.zip
release
git-svn-id: https://plugins.svn.wordpress.org/post-smtp/trunk@1746635 b8457f37-d9ea-0310-8a92-e5e31aec5664
Diffstat (limited to 'Postman/Postman-Mail/PostmanEmailAddress.php')
-rw-r--r--Postman/Postman-Mail/PostmanEmailAddress.php91
1 files changed, 91 insertions, 0 deletions
diff --git a/Postman/Postman-Mail/PostmanEmailAddress.php b/Postman/Postman-Mail/PostmanEmailAddress.php
new file mode 100644
index 0000000..67c4662
--- /dev/null
+++ b/Postman/Postman-Mail/PostmanEmailAddress.php
@@ -0,0 +1,91 @@
+<?php
+if (! class_exists ( 'PostmanEmailAddress' )) {
+ class PostmanEmailAddress {
+ private $name;
+ private $email;
+ public function __construct($email, $name = null) {
+ // Break $recipient into name and address parts if in the format "Foo <bar@baz.com>"
+ if (preg_match ( '/(.*)<(.+)>/', $email, $matches )) {
+ if (count ( $matches ) == 3) {
+ $name = $matches [1];
+ $email = $matches [2];
+ }
+ }
+ $this->setEmail ( trim ( $email ) );
+ $this->setName ( trim ( $name ) );
+ }
+ public static function copy(PostmanEmailAddress $orig) {
+ return new PostmanEmailAddress ( $orig->getEmail (), $orig->getName () );
+ }
+ public function getName() {
+ return $this->name;
+ }
+ public function getEmail() {
+ return $this->email;
+ }
+ public function format() {
+ $name = $this->getName ();
+ if (! empty ( $name )) {
+ return sprintf ( '%s <%s>', $this->getName (), $this->getEmail () );
+ } else {
+ return sprintf ( '%s', $this->getEmail () );
+ }
+ }
+ public function setName($name) {
+ $this->name = $name;
+ }
+ public function setEmail($email) {
+ $this->email = $email;
+ }
+
+ /**
+ * Validate the email address
+ *
+ * @throws Exception
+ */
+ public function validate($desc = '') {
+ if (! PostmanUtils::validateEmail ( $this->email )) {
+ if (empty ( $desc )) {
+ /* Translators: Where %s is the email address */
+ $message = sprintf ( 'Invalid e-mail address "%s"', $this->email );
+ } else {
+ /* Translators: Where (1) is the header name (eg. To) and (2) is the email address */
+ $message = sprintf ( 'Invalid "%1$s" e-mail address "%2$s"', $desc, $this->email );
+ }
+ $logger = new PostmanLogger ( get_class ( $this ) );
+ $logger->warn ( $message );
+ throw new Exception ( $message );
+ }
+ }
+
+ /**
+ * Accept a String of addresses or an array and return an array
+ *
+ * @param unknown $recipientList
+ * @param unknown $recipients
+ */
+ public static function convertToArray($emails) {
+ assert ( ! empty ( $emails ) );
+ if (! is_array ( $emails )) {
+ // http://tiku.io/questions/955963/splitting-comma-separated-email-addresses-in-a-string-with-commas-in-quotes-in-p
+ $t = str_getcsv ( $emails );
+ $emails = array ();
+ foreach ( $t as $k => $v ) {
+ if (strpos ( $v, ',' ) !== false) {
+ $t [$k] = '"' . str_replace ( ' <', '" <', $v );
+ }
+ $tokenizedEmail = trim ( $t [$k] );
+ array_push ( $emails, $tokenizedEmail );
+ }
+ }
+ return $emails;
+ }
+ public function log(PostmanLogger $log, $desc) {
+ $message = $desc . ' email=' . $this->getEmail ();
+ if (! empty ( $this->name )) {
+ $message .= ' name=' . $this->getName ();
+ }
+ $log->debug ( $message );
+ }
+ }
+} \ No newline at end of file