First batch of removal of the headers needed for revision-functions.php
[mailer.git] / ref.php
diff --git a/ref.php b/ref.php
index 6e639520a2dd2137663d1c5042a1ffb4554ccbfd..bb890ca8cc8308340a228f746110efda5a12a093 100644 (file)
--- a/ref.php
+++ b/ref.php
@@ -1,24 +1,18 @@
 <?php
 /************************************************************************
- * MXChange v0.2.1                                    Start: 10/13/2003 *
- * ===============                              Last change: 09/04/2004 *
+ * Mailer v0.2.1-FINAL                                Start: 10/13/2003 *
+ * ===================                          Last change: 09/04/2004 *
  *                                                                      *
  * -------------------------------------------------------------------- *
  * File              : ref.php                                          *
  * -------------------------------------------------------------------- *
- * Short description : Redirection for the referal link                 *
+ * Short description : Redirection for the referral link                *
  * -------------------------------------------------------------------- *
- * Kurzbeschreibung  : Weiterleitungsscript fuer die Referal-Links      *
+ * Kurzbeschreibung  : Weiterleitungsscript fuer die Referral-Links     *
  * -------------------------------------------------------------------- *
- * $Revision::                                                        $ *
- * $Date::                                                            $ *
- * $Tag:: 0.2.1-FINAL                                                 $ *
- * $Author::                                                          $ *
- * Needs to be in all Files and every File needs "svn propset           *
- * svn:keywords Date Revision" (autoprobset!) at least!!!!!!            *
- * -------------------------------------------------------------------- *
- * Copyright (c) 2003 - 2008 by Roland Haeder                           *
- * For more information visit: http://www.mxchange.org                  *
+ * Copyright (c) 2003 - 2009 by Roland Haeder                           *
+ * Copyright (c) 2009 - 2013 by Mailer Developer Team                   *
+ * For more information visit: http://mxchange.org                      *
  *                                                                      *
  * This program is free software; you can redistribute it and/or modify *
  * it under the terms of the GNU General Public License as published by *
 // Load security stuff here
 require('inc/libs/security_functions.php');
 
-// Init "action" and "what"
-$GLOBALS['what'] = '';
-$GLOBALS['action'] = '';
+// Init start time
+$GLOBALS['__start_time'] = microtime(TRUE);
 
 // Set module
-$GLOBALS['module'] = 'ref';
-$GLOBALS['output_mode'] = -1;
+$GLOBALS['__module']      = 'ref';
+$GLOBALS['__output_mode'] = -1;
 
 // Load the required file(s)
 require('inc/config-global.php');
 
-// Redirect only to registration page when this script is installed
-if (isInstalled()) {
+// Set content type for e.g. search engines
+setContentType('text/html');
+
+// No refid by default
+$url = 'modules.php?module=index';
+
+// Check for determined referral id
+if ((isExtensionActive('user')) && (isValidReferralId()) && (isValidId(determineReferralId()))) {
+       // Run filter chain for updating referral data
+       runFilterChain('update_referral_data');
+
        // Base URL for redirection
-       switch (getConfig('refid_target'))
-       {
+       switch (getConfig('refid_target')) {
                case 'register':
-                       $URL = 'modules.php?module=index&amp;what=register&amp;refid=';
+                       $url = 'modules.php?module=index&amp;what=register';
                        break;
 
                case 'index':
-                       $URL = 'index.php?refid=';
+                       $url = 'modules.php?module=index';
                        break;
-       }
-
-       // Get referal ID from ref or refid variable
-       if (REQUEST_ISSET_GET(('ref')))        $ref = REQUEST_GET('ref');
-       elseif (REQUEST_ISSET_GET(('refid'))) $ref = REQUEST_GET('refid');
-
-       if (!empty($ref)) {
-               // Test if nickname or numeric id
-               if ($ref != ''.($ref + 0).'') {
-                       if (EXT_IS_ACTIVE('nickname')) {
-                               // Nickname in URL, so load the ID
-                               $result = SQL_QUERY_ESC("SELECT userid FROM `{!_MYSQL_PREFIX!}_user_data` WHERE nickname='%s' LIMIT 1",
-                               array($ref), __FILE__, __LINE__);
-
-                               // Load userid
-                               list($ref) = SQL_FETCHROW($result);
 
-                               // Free result
-                               SQL_FREERESULT($result);
-                       } else {
-                               // Invalid request!
-                               $ref = 0;
-                       }
-               } // END - if
-
-               // Also edit this 0 !
-               if (empty($ref)) $ref = 0;
-
-               // Update session
-               setSession('refid', $ref);
-
-               // We have an refid here. So we simply add it
-               $URL .= bigintval($ref);
-
-               // Is the refid valid?
-               if ($ref > 0) {
-                       // Update ref counter
-                       SQL_QUERY_ESC("UPDATE `{!_MYSQL_PREFIX!}_user_data` SET ref_clicks=ref_clicks+1 WHERE userid=%s LIMIT 1",
-                       array(bigintval($ref)), __FILE__, __LINE__);
-               } // END - if
-       } else {
-               // No refid and we add our refid (don't forget to set $def_refid!)
-               $URL = 'index.php';
-       }
-
-       // Load the URL
-       redirectToUrl($URL);
-} else {
-       // You have to install first!
-       redirectToUrl('install.php');
-}
+               default: // Is not valid
+                       reportBug(__FILE__, __LINE__, 'Invalid refid target ' . getConfig('refid_target') . ' detected.');
+                       break;
+       } // END - switch
+} // END - if
 
-// Really all done here... ;-)
-shutdown();
+// Load the URL
+redirectToUrl($url);
 
-//
+// [EOF]
 ?>