2011-01-25 11:57:47 -08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/*
|
2012-01-11 16:07:36 -08:00
|
|
|
* Copyright 2012 Facebook, Inc.
|
2011-01-25 11:57:47 -08:00
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2012-01-11 16:07:36 -08:00
|
|
|
/**
|
|
|
|
* @task uri URI Validation
|
|
|
|
*/
|
2011-01-31 11:55:26 -08:00
|
|
|
final class PhabricatorEnv {
|
|
|
|
private static $env;
|
|
|
|
|
|
|
|
public static function setEnvConfig(array $config) {
|
|
|
|
self::$env = $config;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function getEnvConfig($key, $default = null) {
|
|
|
|
return idx(self::$env, $key, $default);
|
2011-01-25 11:57:47 -08:00
|
|
|
}
|
2011-01-31 11:55:26 -08:00
|
|
|
|
2011-04-29 22:20:52 -07:00
|
|
|
public static function envConfigExists($key) {
|
|
|
|
return array_key_exists($key, self::$env);
|
|
|
|
}
|
|
|
|
|
2011-01-31 11:55:26 -08:00
|
|
|
public static function getURI($path) {
|
|
|
|
return rtrim(self::getEnvConfig('phabricator.base-uri'), '/').$path;
|
|
|
|
}
|
2011-02-26 20:57:21 -08:00
|
|
|
|
2011-04-04 14:22:16 -07:00
|
|
|
public static function getProductionURI($path) {
|
|
|
|
$uri = self::getEnvConfig('phabricator.production-uri');
|
|
|
|
if (!$uri) {
|
|
|
|
$uri = self::getEnvConfig('phabricator.base-uri');
|
|
|
|
}
|
|
|
|
return rtrim($uri, '/').$path;
|
|
|
|
}
|
|
|
|
|
2011-02-11 16:48:43 -08:00
|
|
|
public static function getAllConfigKeys() {
|
|
|
|
return self::$env;
|
|
|
|
}
|
2011-01-31 11:55:26 -08:00
|
|
|
|
2011-05-19 13:40:12 -07:00
|
|
|
public static function getDoclink($resource) {
|
|
|
|
return 'http://phabricator.com/docs/phabricator/'.$resource;
|
|
|
|
}
|
|
|
|
|
2012-01-11 16:07:36 -08:00
|
|
|
|
|
|
|
/* -( URI Validation )----------------------------------------------------- */
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Detect if a URI satisfies either @{method:isValidLocalWebResource} or
|
|
|
|
* @{method:isValidRemoteWebResource}, i.e. is a page on this server or the
|
|
|
|
* URI of some other resource which has a valid protocol. This rejects
|
|
|
|
* garbage URIs and URIs with protocols which do not appear in the
|
|
|
|
* ##uri.allowed-protocols## configuration, notably 'javascript:' URIs.
|
|
|
|
*
|
|
|
|
* NOTE: This method is generally intended to reject URIs which it may be
|
|
|
|
* unsafe to put in an "href" link attribute.
|
|
|
|
*
|
|
|
|
* @param string URI to test.
|
|
|
|
* @return bool True if the URI identifies a web resource.
|
|
|
|
* @task uri
|
|
|
|
*/
|
|
|
|
public static function isValidWebResource($uri) {
|
|
|
|
return self::isValidLocalWebResource($uri) ||
|
|
|
|
self::isValidRemoteWebResource($uri);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Detect if a URI identifies some page on this server.
|
|
|
|
*
|
|
|
|
* NOTE: This method is generally intended to reject URIs which it may be
|
|
|
|
* unsafe to issue a "Location:" redirect to.
|
|
|
|
*
|
|
|
|
* @param string URI to test.
|
|
|
|
* @return bool True if the URI identifies a local page.
|
|
|
|
* @task uri
|
|
|
|
*/
|
|
|
|
public static function isValidLocalWebResource($uri) {
|
|
|
|
$uri = (string)$uri;
|
|
|
|
|
|
|
|
if (!strlen($uri)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (preg_match('/\s/', $uri)) {
|
|
|
|
// PHP hasn't been vulnerable to header injection attacks for a bunch of
|
|
|
|
// years, but we can safely reject these anyway since they're never valid.
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Valid URIs must begin with '/', followed by the end of the string or some
|
|
|
|
// other non-'/' character. This rejects protocol-relative URIs like
|
|
|
|
// "//evil.com/evil_stuff/".
|
|
|
|
return (bool)preg_match('@^/([^/]|$)@', $uri);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Detect if a URI identifies some valid remote resource.
|
|
|
|
*
|
|
|
|
* @param string URI to test.
|
|
|
|
* @return bool True if a URI idenfies a remote resource with an allowed
|
|
|
|
* protocol.
|
|
|
|
* @task uri
|
|
|
|
*/
|
|
|
|
public static function isValidRemoteWebResource($uri) {
|
|
|
|
$uri = (string)$uri;
|
|
|
|
|
|
|
|
$proto = id(new PhutilURI($uri))->getProtocol();
|
|
|
|
if (!$proto) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$allowed = self::getEnvConfig('uri.allowed-protocols');
|
|
|
|
if (empty($allowed[$proto])) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2011-01-25 11:57:47 -08:00
|
|
|
}
|