2006-05-26 05:17:33 +04:00
|
|
|
<?php
|
|
|
|
// ***** BEGIN LICENSE BLOCK *****
|
|
|
|
//
|
|
|
|
// Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
//
|
|
|
|
// The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
// 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
// the License. You may obtain a copy of the License at
|
|
|
|
// http://www.mozilla.org/MPL/
|
|
|
|
//
|
|
|
|
// Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
// WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
// for the specific language governing rights and limitations under the
|
|
|
|
// License.
|
|
|
|
//
|
|
|
|
// The Original Code is AUS.
|
|
|
|
//
|
|
|
|
// The Initial Developer of the Original Code is Mike Morgan.
|
|
|
|
//
|
|
|
|
// Portions created by the Initial Developer are Copyright (C) 2006
|
|
|
|
// the Initial Developer. All Rights Reserved.
|
|
|
|
//
|
|
|
|
// Contributor(s):
|
|
|
|
// Mike Morgan <morgamic@mozilla.com>
|
|
|
|
//
|
|
|
|
// Alternatively, the contents of this file may be used under the terms of
|
|
|
|
// either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
|
|
// the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
// in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
// of those above. If you wish to allow use of your version of this file only
|
|
|
|
// under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
// use your version of this file under the terms of the MPL, indicate your
|
|
|
|
// decision by deleting the provisions above and replace them with the notice
|
|
|
|
// and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
// the provisions above, a recipient may use your version of this file under
|
|
|
|
// the terms of any one of the MPL, the GPL or the LGPL.
|
|
|
|
//
|
|
|
|
// ***** END LICENSE BLOCK *****
|
|
|
|
|
|
|
|
/**
|
2006-06-02 18:20:36 +04:00
|
|
|
* AUS main script.
|
|
|
|
* @package aus
|
2006-05-26 05:17:33 +04:00
|
|
|
* @subpackage docs
|
|
|
|
* @author Mike Morgan
|
|
|
|
*
|
|
|
|
* This script handles incoming requests, reads the related build
|
|
|
|
* snippet and returns a properly formatted XML file for testing.
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Require config and supporting libraries.
|
|
|
|
require_once('./inc/init.php');
|
|
|
|
|
|
|
|
// Instantiate XML object.
|
|
|
|
$xml = new Xml();
|
|
|
|
|
2007-07-24 05:37:42 +04:00
|
|
|
// Check to see if the user is explicitly requesting an update. If they are,
|
|
|
|
// skip throttling. If they aren't, and throttling is enabled, randomly serve
|
|
|
|
// updates based on the configured random seed.
|
2007-09-13 23:37:52 +04:00
|
|
|
if ( (empty($_GET['force']) || $_GET['force']!=1) &&
|
2007-07-24 05:37:42 +04:00
|
|
|
defined('THROTTLE') &&
|
|
|
|
THROTTLE &&
|
|
|
|
defined('THROTTLE_LEVEL') &&
|
|
|
|
mt_rand(0,100) > THROTTLE_LEVEL ) {
|
2007-06-19 23:03:45 +04:00
|
|
|
|
|
|
|
if (defined('THROTTLE_LOGGING') && THROTTLE_LOGGING) {
|
|
|
|
|
|
|
|
//Are we behind a proxy and given the IP via an alternate enviroment variable? If so, use it.
|
|
|
|
if (!empty($_SERVER["HTTP_X_FORWARDED_FOR"])) {
|
|
|
|
$ip = $_SERVER["HTTP_X_FORWARDED_FOR"];
|
|
|
|
} else {
|
|
|
|
$ip = $_SERVER["REMOTE_ADDR"];
|
|
|
|
}
|
|
|
|
error_log('AUS2 THROTTLE: '.$ip.' '.$_SERVER['REQUEST_URI']);
|
|
|
|
}
|
|
|
|
|
2007-06-15 06:25:50 +04:00
|
|
|
$xml->printXml();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
2006-05-26 05:17:33 +04:00
|
|
|
// Find everything between our CWD and 255 in QUERY_STRING.
|
|
|
|
$rawPath = substr(urldecode($_SERVER['QUERY_STRING']),5,255);
|
|
|
|
|
2008-03-27 11:24:35 +03:00
|
|
|
// Connect to memcache and try to pull output.
|
|
|
|
$memcache = new Memcaching();
|
|
|
|
$_cached_xml = $memcache->get($rawPath);
|
|
|
|
|
|
|
|
if ($_cached_xml) {
|
|
|
|
$xml = $_cached_xml;
|
|
|
|
} else {
|
|
|
|
// Munge he resulting string and store it in $path.
|
|
|
|
$path = explode('/',$rawPath);
|
|
|
|
|
|
|
|
// Determine incoming request and clean inputs.
|
|
|
|
// These are common URI elements, agreed upon in revision 0.
|
|
|
|
// For successive versions, the path of least resistence is to append and not reorder.
|
|
|
|
$clean = Array();
|
|
|
|
$clean['updateVersion'] = isset($path[0]) ? intval($path[0]) : null;
|
|
|
|
$clean['product'] = isset($path[1]) ? trim($path[1]) : null;
|
|
|
|
$clean['version'] = isset($path[2]) ? urlencode($path[2]) : null;
|
|
|
|
$clean['build'] = isset($path[3]) ? trim($path[3]) : null;
|
|
|
|
$clean['platform'] = isset($path[4]) ? trim($path[4]) : null;
|
|
|
|
$clean['locale'] = isset($path[5]) ? trim($path[5]) : null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* For each updateVersion, we will run separate code when it differs.
|
|
|
|
* Our case statements below are ordered by date added, desc (recent ones first).
|
|
|
|
*
|
|
|
|
* If the only difference is an added parameter, etc., then we may blend cases
|
|
|
|
* together by omitting a break.
|
2006-05-26 05:17:33 +04:00
|
|
|
*/
|
2008-03-27 11:24:35 +03:00
|
|
|
switch ($clean['updateVersion']) {
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This is for the fourth revision, adding %DISTRIBUTION% and
|
|
|
|
* %DISTRIBUTION_VERSION%.
|
|
|
|
* /update/3/%PRODUCT%/%VERSION%/%BUILD_ID%/%BUILD_TARGET%/%LOCALE%/%CHANNEL%/%OS_VERSION%/%DISTRIBUTION%/%DISTRIBUTION_VERSION%/update.xml
|
|
|
|
*/
|
|
|
|
case 3:
|
|
|
|
// Parse out dist information. For now, though, we aren't doing
|
|
|
|
// anything with it.
|
|
|
|
$clean['dist'] = isset($path[8]) ? trim($path[8]) : null;
|
|
|
|
$clean['distVersion'] = isset($path[9]) ? trim($path[9]) : null;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This is for the third revision of the URI schema, with %OS_VERSION%.
|
|
|
|
* /update2/2/%PRODUCT%/%VERSION%/%BUILD_ID%/%BUILD_TARGET%/%LOCALE%/%CHANNEL%/%OS_VERSION%/update.xml
|
|
|
|
*/
|
|
|
|
case 2:
|
|
|
|
|
|
|
|
// Parse out the %OS_VERSION% if it exists.
|
|
|
|
$clean['platformVersion'] = isset($path[7]) ? trim($path[7]) : null;
|
|
|
|
|
|
|
|
// Check for OS_VERSION values and scrub the URI to make sure we aren't getting a malformed request
|
|
|
|
// from a client suffering from bug 360127.
|
|
|
|
if (empty($clean['platformVersion']) || $clean['platformVersion']=='%OS_VERSION%' || preg_match('/^1\.5.*$/',$clean['version'])) {
|
|
|
|
break;
|
2006-05-26 05:17:33 +04:00
|
|
|
}
|
|
|
|
|
2008-03-27 11:24:35 +03:00
|
|
|
// Check to see if the %OS_VERSION% value passed in the URI is in our no-longer-supported
|
|
|
|
// array which is set in our config.
|
|
|
|
if (!empty($clean['platformVersion']) && !empty($unsupportedPlatforms) && is_array($unsupportedPlatforms) && in_array($clean['platformVersion'], $unsupportedPlatforms)) {
|
2006-09-14 03:34:04 +04:00
|
|
|
|
2008-03-27 11:24:35 +03:00
|
|
|
// If the passed OS_VERSION is in our array of unsupportedPlatforms, break the switch() and skip to the end.
|
|
|
|
//
|
|
|
|
// The default behavior is "no updates", so essentially the client would get an empty XML doc.
|
|
|
|
break;
|
2006-09-14 03:34:04 +04:00
|
|
|
}
|
2006-09-20 00:30:15 +04:00
|
|
|
|
2008-03-27 11:24:35 +03:00
|
|
|
/*
|
|
|
|
* This is for the second revision of the URI schema, with %CHANNEL% added.
|
|
|
|
* /update2/1/%PRODUCT%/%VERSION%/%BUILD_ID%/%BUILD_TARGET%/%LOCALE%/%CHANNEL%/update.xml
|
|
|
|
*/
|
|
|
|
case 1:
|
|
|
|
|
|
|
|
// Check for a set channel.
|
|
|
|
$clean['channel'] = isset($path[6]) ? trim($path[6]) : null;
|
|
|
|
|
|
|
|
// Instantiate Update object and set updateVersion.
|
|
|
|
$update = new Update();
|
|
|
|
|
|
|
|
// Instantiate our complete patch.
|
|
|
|
$completePatch = new Patch($productBranchVersions,$nightlyChannels,'complete');
|
|
|
|
|
|
|
|
// If our complete patch exists and is valid, set the patch line.
|
|
|
|
if ($completePatch->findPatch($clean['product'],$clean['platform'],$clean['locale'],$clean['version'],$clean['build'],$clean['channel']) && $completePatch->isPatch()) {
|
|
|
|
|
|
|
|
// Set our patchLine.
|
|
|
|
$xml->setPatchLine($completePatch);
|
|
|
|
|
|
|
|
// If available, pull update information from the build snippet.
|
|
|
|
if ($completePatch->hasUpdateInfo()) {
|
|
|
|
$update->setVersion($completePatch->updateVersion);
|
|
|
|
$update->setExtensionVersion($completePatch->updateExtensionVersion);
|
|
|
|
$update->setBuild($completePatch->build);
|
|
|
|
}
|
|
|
|
|
|
|
|
// If there is details url information, add it to the update object.
|
|
|
|
if ($completePatch->hasDetailsUrl()) {
|
|
|
|
$update->setDetails($completePatch->detailsUrl);
|
|
|
|
}
|
|
|
|
|
|
|
|
// If we found an update type, pass it along.
|
|
|
|
if ($completePatch->hasUpdateType()) {
|
|
|
|
$update->setType($completePatch->updateType);
|
|
|
|
}
|
|
|
|
|
|
|
|
// If we have a license URL, pass it along.
|
|
|
|
if ($completePatch->hasLicenseUrl()) {
|
|
|
|
$update->setLicense($completePatch->licenseUrl);
|
|
|
|
}
|
2006-09-20 00:30:15 +04:00
|
|
|
}
|
2006-05-26 05:17:33 +04:00
|
|
|
|
2008-03-27 11:24:35 +03:00
|
|
|
// Instantiate our partial patch.
|
|
|
|
$partialPatch = new Patch($productBranchVersions,$nightlyChannels,'partial');
|
|
|
|
|
|
|
|
// If our partial patch exists and is valid, set the patch line.
|
|
|
|
if ($partialPatch->findPatch($clean['product'],$clean['platform'],$clean['locale'],$clean['version'],$clean['build'],$clean['channel'])
|
|
|
|
&& $partialPatch->isPatch()
|
|
|
|
&& $partialPatch->isOneStepFromLatest($completePatch->build)) {
|
|
|
|
$xml->setPatchLine($partialPatch);
|
|
|
|
}
|
|
|
|
|
|
|
|
// If we have valid patchLine(s), set up our output.
|
|
|
|
if ($xml->hasPatchLine()) {
|
|
|
|
$xml->startUpdate($update);
|
|
|
|
$xml->drawPatchLines();
|
|
|
|
$xml->endUpdate();
|
|
|
|
}
|
|
|
|
break;
|
2006-05-26 05:17:33 +04:00
|
|
|
|
2008-03-27 11:24:35 +03:00
|
|
|
/*
|
|
|
|
* This is for the first revision of the URI schema.
|
|
|
|
* /update2/0/%PRODUCT%/%VERSION%/%BUILD_ID%/%BUILD_TARGET%/%LOCALE%/update.xml
|
|
|
|
*/
|
|
|
|
case 0:
|
|
|
|
default:
|
2006-05-26 05:17:33 +04:00
|
|
|
|
2008-03-27 11:24:35 +03:00
|
|
|
// Instantiate Update object and set updateVersion.
|
|
|
|
$update = new Update();
|
2006-05-26 05:17:33 +04:00
|
|
|
|
2008-03-27 11:24:35 +03:00
|
|
|
// Instantiate Patch object and set Path based on passed args.
|
|
|
|
$patch = new Patch($productBranchVersions,$nightlyChannels,'complete');
|
2006-05-26 05:17:33 +04:00
|
|
|
|
2008-03-27 11:24:35 +03:00
|
|
|
$patch->findPatch($clean['product'],$clean['platform'],$clean['locale'],$clean['version'],$clean['build'],null);
|
2006-05-26 05:17:33 +04:00
|
|
|
|
2008-03-27 11:24:35 +03:00
|
|
|
if ($patch->isPatch()) {
|
|
|
|
$xml->setPatchLine($patch);
|
|
|
|
}
|
2006-05-26 05:17:33 +04:00
|
|
|
|
2008-03-27 11:24:35 +03:00
|
|
|
// If we have a new build, draw the update block and patch line.
|
|
|
|
// If there is no valid patch file, client will receive no updates by default.
|
|
|
|
if ($xml->hasPatchLine()) {
|
|
|
|
$xml->startUpdate($update);
|
|
|
|
$xml->drawPatchLines();
|
|
|
|
$xml->endUpdate();
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
2006-05-26 05:17:33 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
// If we are debugging output plaintext and exit.
|
|
|
|
if ( defined('DEBUG') && DEBUG == true ) {
|
|
|
|
|
|
|
|
echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">'."\n";
|
|
|
|
echo '<html xmlns="http://www.w3.org/1999/xhtml">'."\n";
|
|
|
|
echo '<head>'."\n";
|
|
|
|
echo '<title>AUS Debug Information</title>'."\n";
|
|
|
|
echo '</head>'."\n";
|
|
|
|
echo '<body>'."\n";
|
|
|
|
echo '<h1>AUS Debug Information</h1>'."\n";
|
|
|
|
|
|
|
|
echo '<h2>XML Output</h2>'."\n";
|
|
|
|
echo '<pre>'."\n";
|
|
|
|
echo htmlentities($xml->getOutput());
|
|
|
|
echo '</pre>'."\n";
|
|
|
|
|
|
|
|
if (!empty($clean)) {
|
|
|
|
echo '<h2>Inputs</h2>'."\n";
|
|
|
|
echo '<pre>'."\n";
|
|
|
|
print_r($clean);
|
|
|
|
echo '</pre>'."\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
echo '<h2>Patch Objects</h2>'."\n";
|
|
|
|
echo '<pre>'."\n";
|
|
|
|
if (!empty($patch)) {
|
|
|
|
print_r($patch);
|
|
|
|
}
|
|
|
|
if (!empty($completePatch)) {
|
|
|
|
print_r($completePatch);
|
|
|
|
}
|
|
|
|
if (!empty($partialPatch)) {
|
|
|
|
print_r($partialPatch);
|
|
|
|
}
|
|
|
|
echo '</pre>'."\n";
|
|
|
|
|
|
|
|
if (!empty($update)) {
|
|
|
|
echo '<h2>Update Object</h2>'."\n";
|
|
|
|
echo '<pre>'."\n";
|
|
|
|
print_r($update);
|
|
|
|
echo '</pre>'."\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
echo '</body>'."\n";
|
|
|
|
echo '</html>';
|
|
|
|
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set header and send info.
|
2008-03-27 11:24:35 +03:00
|
|
|
$memcache->set($rawPath,$xml);
|
2007-06-15 06:25:50 +04:00
|
|
|
$xml->printXml();
|
2006-05-26 05:17:33 +04:00
|
|
|
exit;
|
|
|
|
?>
|