]> git.mxchange.org Git - mailer.git/blobdiff - inc/libs/newsletter_functions.php
More usage of wrapper functions
[mailer.git] / inc / libs / newsletter_functions.php
index 5dcf9d87e28c1a9ec380d4743a786da46d398b00..1cb6390749e8ad16c4cbc38ba3d61736ae86f332 100644 (file)
@@ -1,18 +1,22 @@
 <?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 - 2011 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 - if
+               } // 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
@@ -100,86 +70,82 @@ function NL_INSERT_URLS($text)
 
        // ... 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');
                }
        }
 }
+
 //
 ?>