Commit b8cea73a92e923bf5182e87e76a747745d6f06f5
1 parent
54724069
added multiple email address support
git-svn-id: https://kt-dms.svn.sourceforge.net/svnroot/kt-dms/trunk@1245 c91229c3-7414-0410-bfa2-8a42b809f60b
Showing
3 changed files
with
36 additions
and
16 deletions
lib/email/Email.inc
| @@ -27,9 +27,9 @@ class Email { | @@ -27,9 +27,9 @@ class Email { | ||
| 27 | // create a new phpmailer object. | 27 | // create a new phpmailer object. |
| 28 | $this->oMailer = new phpmailer(); | 28 | $this->oMailer = new phpmailer(); |
| 29 | $this->oMailer->isSMTP(); | 29 | $this->oMailer->isSMTP(); |
| 30 | - $this->oMailer->Host = $default->system->get("emailServer"); | ||
| 31 | - $this->oMailer->From = (strlen($sFromEmail) == 0) ? $default->system->get("emailFrom") : $sFromEmail; | ||
| 32 | - $this->oMailer->FromName = (strlen($sFromName) == 0) ? $default->system->get("emailFromName") : $sFromName; | 30 | + $this->oMailer->Host = $default->emailServer; |
| 31 | + $this->oMailer->From = (strlen($sFromEmail) == 0) ? $default->emailFrom : $sFromEmail; | ||
| 32 | + $this->oMailer->FromName = (strlen($sFromName) == 0) ? $default->emailFromName : $sFromName; | ||
| 33 | $this->oMailer->WordWrap = 100; | 33 | $this->oMailer->WordWrap = 100; |
| 34 | $this->oMailer->IsHTML(true); | 34 | $this->oMailer->IsHTML(true); |
| 35 | } | 35 | } |
| @@ -37,11 +37,11 @@ class Email { | @@ -37,11 +37,11 @@ class Email { | ||
| 37 | /** | 37 | /** |
| 38 | * Sends an email to a specified recipient. | 38 | * Sends an email to a specified recipient. |
| 39 | * | 39 | * |
| 40 | - * @param string the sender's email address (optional) | ||
| 41 | - * @param string the sender's name (optional) | ||
| 42 | * @param string the recipients email address | 40 | * @param string the recipients email address |
| 43 | * @param string the subject of the email | 41 | * @param string the subject of the email |
| 44 | * @param string the body of the email | 42 | * @param string the body of the email |
| 43 | + * @param string the sender's email address (optional) | ||
| 44 | + * @param string the sender's name (optional) | ||
| 45 | * @return boolean true on email successfully sent, false otherwise and set $_SESSION["errorMessage"] | 45 | * @return boolean true on email successfully sent, false otherwise and set $_SESSION["errorMessage"] |
| 46 | */ | 46 | */ |
| 47 | function send($sToEmail, $sSubject, $sBody, $sFromEmail = "", $sFromName = "") { | 47 | function send($sToEmail, $sSubject, $sBody, $sFromEmail = "", $sFromName = "") { |
| @@ -58,7 +58,19 @@ class Email { | @@ -58,7 +58,19 @@ class Email { | ||
| 58 | if ((strlen($sFromName) > 0) && ($sFromName != "")) { | 58 | if ((strlen($sFromName) > 0) && ($sFromName != "")) { |
| 59 | $this->oMailer->FromName = $sFromName; | 59 | $this->oMailer->FromName = $sFromName; |
| 60 | } | 60 | } |
| 61 | - $this->oMailer->AddAddress($sToEmail); | 61 | + |
| 62 | + // if there are multiple addresses (; separated) | ||
| 63 | + $aEmailAddresses = array(); | ||
| 64 | + if (strpos($sToEmail, ";") > 0) { | ||
| 65 | + // explode them | ||
| 66 | + $aEmailAddresses = explode(";", $sToEmail); | ||
| 67 | + for ($i=0; $i<count($aEmailAddresses); $i++) { | ||
| 68 | + $this->oMailer->AddAddress($aEmailAddresses[$i]); | ||
| 69 | + $default->log->info("Email.inc adding " . $aEmailAddresses[$i]); | ||
| 70 | + } | ||
| 71 | + } else { | ||
| 72 | + $this->oMailer->AddAddress($sToEmail); | ||
| 73 | + } | ||
| 62 | $this->oMailer->Subject = stripslashes($sSubject); | 74 | $this->oMailer->Subject = stripslashes($sSubject); |
| 63 | $this->oMailer->Body = stripslashes($sBody); | 75 | $this->oMailer->Body = stripslashes($sBody); |
| 64 | 76 |
presentation/lookAndFeel/knowledgeTree/documentmanagement/emailBL.php
| @@ -39,11 +39,13 @@ if (checkSession()) { | @@ -39,11 +39,13 @@ if (checkSession()) { | ||
| 39 | } else { | 39 | } else { |
| 40 | $sMessage = "Your colleague, " . $oUser->getName() . ", wishes you to view the document entitled '" . $oDocument->getName() . "'.\n Click on the hyperlink below to view it"; | 40 | $sMessage = "Your colleague, " . $oUser->getName() . ", wishes you to view the document entitled '" . $oDocument->getName() . "'.\n Click on the hyperlink below to view it"; |
| 41 | } | 41 | } |
| 42 | - $sHyperLink = generateLink("/presentation/lookAndFeel/knowledgeTree/documentmanagement/viewBL.php", "fDocumentID=$fDocumentID", $oDocument->getName()); | 42 | + // add the link to the document to the mail |
| 43 | + $sMessage .= ' ' . generateLink("/presentation/lookAndFeel/knowledgeTree/documentmanagement/viewBL.php", "fDocumentID=$fDocumentID", $oDocument->getName()); | ||
| 43 | 44 | ||
| 44 | //email the hyperlink | 45 | //email the hyperlink |
| 45 | - $oEmail = new Email(); | ||
| 46 | - $oEmail->sendHyperlink($default->owl_email_from, "MRC DMS", $fToEmail, "Document link", $sMessage, $sHyperLink); | 46 | + $oEmail = new Email(); |
| 47 | + $oEmail->send($fToEmail, "Document link", $sMessage); | ||
| 48 | + | ||
| 47 | //go back to the document view page | 49 | //go back to the document view page |
| 48 | redirect("$default->rootUrl/control.php?action=viewDocument&fDocumentID=$fDocumentID"); | 50 | redirect("$default->rootUrl/control.php?action=viewDocument&fDocumentID=$fDocumentID"); |
| 49 | } else { | 51 | } else { |
| @@ -68,7 +70,7 @@ if (checkSession()) { | @@ -68,7 +70,7 @@ if (checkSession()) { | ||
| 68 | 70 | ||
| 69 | $oPatternCustom = & new PatternCustom(); | 71 | $oPatternCustom = & new PatternCustom(); |
| 70 | $oPatternCustom->setHtml(getDocumentEmailPage($oDocument)); | 72 | $oPatternCustom->setHtml(getDocumentEmailPage($oDocument)); |
| 71 | - //$main->setErrorMessage("Please enter an email address of the form someone@somewhere.some postfix"); | 73 | + $main->setErrorMessage("Please enter an email address of the form someone@somewhere.some postfix"); |
| 72 | $main->setCentralPayload($oPatternCustom); | 74 | $main->setCentralPayload($oPatternCustom); |
| 73 | $main->setFormAction($_SERVER["PHP_SELF"] . "?fDocumentID=$fDocumentID&fSendEmail=1"); | 75 | $main->setFormAction($_SERVER["PHP_SELF"] . "?fDocumentID=$fDocumentID&fSendEmail=1"); |
| 74 | $main->render(); | 76 | $main->render(); |
| @@ -88,12 +90,18 @@ if (checkSession()) { | @@ -88,12 +90,18 @@ if (checkSession()) { | ||
| 88 | 90 | ||
| 89 | /** use regex to validate the format of the email address */ | 91 | /** use regex to validate the format of the email address */ |
| 90 | function validateEmailAddress($sEmailAddress) { | 92 | function validateEmailAddress($sEmailAddress) { |
| 91 | - $bResult = ereg ("^[^@ ]+@[^@ ]+\.[^@ \.]+$", $sEmailAddress ); | ||
| 92 | - if ($bResult) { | ||
| 93 | - return TRUE; | 93 | + $aEmailAddresses = array(); |
| 94 | + if (strpos($sEmailAddress, ";")) { | ||
| 95 | + $aEmailAddresses = explode(";", $sEmailAddress); | ||
| 94 | } else { | 96 | } else { |
| 95 | - return FALSE; | 97 | + $aEmailAddresses[] = $sEmailAddress; |
| 96 | } | 98 | } |
| 99 | + $bToReturn = true; | ||
| 100 | + for ($i=0; $i<count($aEmailAddresses); $i++) { | ||
| 101 | + $bResult = ereg ("^[^@ ]+@[^@ ]+\.[^@ \.]+$", $aEmailAddresses[$i] ); | ||
| 102 | + $bToReturn = $bToReturn && $bResult; | ||
| 103 | + } | ||
| 104 | + return $bToReturn; | ||
| 97 | } | 105 | } |
| 98 | 106 | ||
| 99 | ?> | 107 | ?> |
presentation/lookAndFeel/knowledgeTree/documentmanagement/emailUI.inc
| @@ -38,10 +38,10 @@ function getDocumentEmailPage($oDocument) { | @@ -38,10 +38,10 @@ function getDocumentEmailPage($oDocument) { | ||
| 38 | global $default; | 38 | global $default; |
| 39 | $sToRender = getDocumentPath($oDocument) . "\n<br>\n"; | 39 | $sToRender = getDocumentPath($oDocument) . "\n<br>\n"; |
| 40 | $sToRender .= "<table>\n"; | 40 | $sToRender .= "<table>\n"; |
| 41 | - $sToRender .= "<th colspan=\"2\" align=\"left\">Email details</th>\n"; | 41 | + $sToRender .= "<th colspan=\"2\" align=\"left\">Email details</th>\n"; |
| 42 | $sToRender .= "<tr><td> </td><td> </td></tr>\n"; | 42 | $sToRender .= "<tr><td> </td><td> </td></tr>\n"; |
| 43 | $sToRender .= "<tr><td>Recipient name:</td><td><input type=\"text\" name=\"fToName\" /></td></tr>\n"; | 43 | $sToRender .= "<tr><td>Recipient name:</td><td><input type=\"text\" name=\"fToName\" /></td></tr>\n"; |
| 44 | - $sToRender .= "<tr><td>Email address:</td><td><input type=\"text\" name=\"fToEmail\" /></td></tr>\n"; | 44 | + $sToRender .= "<tr><td>Email address:</td><td><input type=\"text\" name=\"fToEmail\" />(separate multiple addresses with a semicolon)</td></tr>\n"; |
| 45 | $sToRender .= "<tr><td> </td><td> </td></tr>\n"; | 45 | $sToRender .= "<tr><td> </td><td> </td></tr>\n"; |
| 46 | $sToRender .= "<tr><td><table><tr><td><input type=\"image\" src=\"$default->graphicsUrl/widgets/email.gif\" /></td><td><a href=\"$default->rootUrl/control.php?action=viewDocument&fDocumentID=" . $oDocument->getID() . "\"><img src=\"$default->graphicsUrl/widgets/cancel.gif\" border=\"0\"/></a></td></tr></table></td>\n"; | 46 | $sToRender .= "<tr><td><table><tr><td><input type=\"image\" src=\"$default->graphicsUrl/widgets/email.gif\" /></td><td><a href=\"$default->rootUrl/control.php?action=viewDocument&fDocumentID=" . $oDocument->getID() . "\"><img src=\"$default->graphicsUrl/widgets/cancel.gif\" border=\"0\"/></a></td></tr></table></td>\n"; |
| 47 | $sToRender .= "</table>\n"; | 47 | $sToRender .= "</table>\n"; |