<?php
/************************************************************************
- * MXChange v0.2.1 Start: 04/25/2004 *
- * ================ Last change: 04/29/2004 *
+ * Mailer v0.2.1-FINAL Start: 04/25/2004 *
+ * =================== Last change: 04/29/2004 *
* *
* -------------------------------------------------------------------- *
- * File : newsletter_functions.php *
+ * File : newsletter_functions.php *
* -------------------------------------------------------------------- *
* Short description : Functions for the HTML extension *
* -------------------------------------------------------------------- *
* Kurzbeschreibung : Funktionen fuer die HTML-Erweiterung *
* -------------------------------------------------------------------- *
- * *
+ * $Revision:: $ *
+ * $Date:: $ *
+ * $Tag:: 0.2.1-FINAL $ *
+ * $Author:: $ *
* -------------------------------------------------------------------- *
- * Copyright (c) 2003 - 2008 by Roland Haeder *
+ * Copyright (c) 2003 - 2009 by Roland Haeder *
+ * Copyright (c) 2009, 2010 by Mailer Developer Team *
* For more information visit: http://www.mxchange.org *
* *
* This program is free software; you can redistribute it and/or modify *
************************************************************************/
// Some security stuff...
-if (ereg(basename(__FILE__), $_SERVER['PHP_SELF']))
-{
- $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4) . "/security.php";
- require($INC);
-}
-//
-function NL_ADD_VALID_TAGS()
-{
- global $HTML_TAGS; $OUT = "";
- if (!is_array($HTML_TAGS)) return "";
- foreach ($HTML_TAGS as $tag)
- {
- $OUT .= ", ".strtoupper($tag);
- }
- $OUT = substr($OUT, 2);
- return $OUT;
-}
-//
-function NL_CHECK_TAGS($html)
-{
- global $HTML_TAGS;
- $test = stripslashes($html);
- while (ereg("<", $test) && ereg(">", $test))
- {
- $check = strtolower(substr($test, strpos($test, "<") + 1, strpos($test, ">") - strpos($test, "<") - 1));
- $check = str_replace("/", "", $check);
- if (!in_array($check, $HTML_TAGS))
- {
- // Invalid tag found!
- return "";
- }
- $test = substr($test, strpos($test, ">") + 1);
- }
- // Return tested code
- return $html;
+if (!defined('__SECURITY')) {
+ die();
}
+
//
-function NL_INSERT_URLS($text)
-{
- global $URL_ENDS, $VALID_EMAIL_CHARS;
+function insertNewsletterUrls ($text) {
$test = $text;
// First replace URLs...
- while (ereg("http://", $test))
- {
- $check = substr($test, strpos($test, "http://")); $check2 = $check;
+ while (isInString('http://', $test)) {
+ $check = substr($test, strpos($test, 'http://')); $check2 = $check;
// See ext-html.php if you want to add more URL ends...
- foreach ($URL_ENDS as $end)
- {
- if (ereg($end, $check)) $check = substr($check, 0, strpos($check, $end));
- }
+ foreach ($GLOBALS['url_ends'] as $end) {
+ if (isInString($end, $check)) $check = substr($check, 0, strpos($check, $end));
+ } // END - foreach
// Now replace the URL against anchor container and pray...
- $text = substr($text, 0, strpos($text, $check2)) . DEREFERER($check) . substr($text, strpos($text, $check2) + strlen($check));
+ $text = substr($text, 0, strpos($text, $check2)) . generateDerefererUrl($check) . substr($text, strpos($text, $check2) + strlen($check));
// Finally remove the url from testing string (or we have a loop and maybe server overload!)
$test = substr($test, strpos($test, $check) + strlen($check));
- }
+ } // END - while
// Now do the (nearly) same thing with email addresses
// but now we have the problem that email addresses didn't have
// ... what will the email address be out the @... ;-)
$PARTS = array();
- while (ereg("@", $test))
- {
- $pos = strpos($test, "@");
+ while (isInString('@', $test)) {
+ $pos = strpos($test, '@');
$test2 = substr($test, 0, $pos);
// First check backwards
$idx = $pos - 1;
- while ($idx > 0)
- {
+ while ($idx > 0) {
$check = substr($test2, $idx, 1);
- if (!in_array($check, $VALID_EMAIL_CHARS))
+ if (!in_array($check, $GLOBALS['valid_email_chars']))
{
// Char found so we end here
break;
}
$idx--;
}
- if ($idx > 0)
- {
+
+ if ($idx > 0) {
// Starting mark is found
$check2 = substr($test, 0, ($idx + 1));
$test = substr($test, ($idx + 1));
}
// And now go forward...
- $idx = 0;
- while ($idx < strlen($test))
- {
+ $idx = '0';
+ while ($idx < strlen($test)) {
$check = substr($test, $idx, 1);
- if ((!in_array($check, $VALID_EMAIL_CHARS)) && ($check != "@"))
- {
+ if ((!in_array($check, $GLOBALS['valid_email_chars'])) && ($check != '@')) {
// Char found so end here again
break;
}
$idx++;
}
- if ($idx > 0)
- {
+
+ if ($idx > 0) {
// Maybe this is the email address?
$check = substr($test, 0, $idx);
}
// Now replace the email against anchor with mailto and pray...
- $PARTS[] = $check2.$check;
+ $PARTS[] = $check2 . $check;
// Remove email from testing string (see above why...)
$test = substr($test, strlen($check));
}
+
// Now put all parts together
- $text = ""; $PARTS[] = $test;
- foreach ($PARTS as $part)
- {
+ $text = ''; $PARTS[] = $test;
+ foreach ($PARTS as $part) {
$text .= $part;
}
- // Compile possible own HTML tags out...
- return COMPILE_CODE($text);
+ // Pre-ompile possible own HTML tags out...
+ return preCompileCode($text);
}
-//
-function SEND_NEWSLETTER($TO, $SUBJECT, $MSG, $MODE)
-{
- global $_POST;
+
+// Wrapper for sending newsletter and wrapping URLs / HTML mail
+function sendNewsletter ($to, $subject, $message, $mode) {
// Send mail away as HTML
- if ($_POST['auto_urls'] == "Y") {
+ if (postRequestParameter('auto_urls') == 'Y') {
// Automatically insert URLs into newsletter
- if ((EXT_IS_ACTIVE("html")) && ($MODE == "html")) {
+ if ((isExtensionActive('html_mail')) && ($mode == 'html')) {
// Send HTML mail
- SEND_EMAIL($TO, $SUBJECT, HTML_INSERT_URLS($MSG), 'Y');
+ sendEmail($to, $subject, insertUrlsIntoHtml($message), 'Y');
} else {
// Send normal mail
- SEND_EMAIL($TO, $SUBJECT, NL_INSERT_URLS($MSG), 'N');
+ sendEmail($to, $subject, insertNewsletterUrls($message), 'N');
}
} else {
// Regular send-out
- if ((EXT_IS_ACTIVE("html")) && ($MODE == "html")) {
- SEND_EMAIL($TO, $SUBJECT, $MSG, 'Y');
+ if ((isExtensionActive('html_mail')) && ($mode == 'html')) {
+ sendEmail($to, $subject, $message, 'Y');
} else {
- SEND_EMAIL($TO, $SUBJECT, $MSG);
+ sendEmail($to, $subject, $message, 'N');
}
}
}
+
//
?>