Ensure that we offer https access to atom if it is available. Fixes #5298 props rubys.

git-svn-id: http://svn.automattic.com/wordpress/trunk@6339 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
westi 2007-11-17 11:21:34 +00:00
parent ab845b0000
commit b296c5f19e
4 changed files with 48 additions and 11 deletions

View File

@ -68,7 +68,6 @@ class AtomServer {
var $MEDIA_SINGLE_PATH = "attachment"; var $MEDIA_SINGLE_PATH = "attachment";
var $params = array(); var $params = array();
var $script_name = "wp-app.php";
var $media_content_types = array('image/*','audio/*','video/*'); var $media_content_types = array('image/*','audio/*','video/*');
var $atom_content_types = array('application/atom+xml'); var $atom_content_types = array('application/atom+xml');
@ -80,6 +79,10 @@ class AtomServer {
function AtomServer() { function AtomServer() {
$this->script_name = array_pop(explode('/',$_SERVER['SCRIPT_NAME'])); $this->script_name = array_pop(explode('/',$_SERVER['SCRIPT_NAME']));
$this->app_base = get_bloginfo('url') . '/' . $this->script_name . '/';
if ( isset($_SERVER['HTTPS']) && strtolower($_SERVER['HTTPS']) == 'on' ) {
$this->app_base = preg_replace( '/^http:\/\//', 'https://', $this->app_base );
}
$this->selectors = array( $this->selectors = array(
'@/service$@' => '@/service$@' =>
@ -594,7 +597,7 @@ EOD;
} else { } else {
$path = $this->ENTRIES_PATH; $path = $this->ENTRIES_PATH;
} }
$url = get_bloginfo('url') . '/' . $this->script_name . '/' . $path; $url = $this->app_base . $path;
if(isset($page) && is_int($page)) { if(isset($page) && is_int($page)) {
$url .= "/$page"; $url .= "/$page";
} }
@ -607,7 +610,7 @@ EOD;
} }
function get_categories_url($page = NULL) { function get_categories_url($page = NULL) {
return get_bloginfo('url') . '/' . $this->script_name . '/' . $this->CATEGORIES_PATH; return $this->app_base . $this->CATEGORIES_PATH;
} }
function the_categories_url() { function the_categories_url() {
@ -616,7 +619,7 @@ EOD;
} }
function get_attachments_url($page = NULL) { function get_attachments_url($page = NULL) {
$url = get_bloginfo('url') . '/' . $this->script_name . '/' . $this->MEDIA_PATH; $url = $this->app_base . $this->MEDIA_PATH;
if(isset($page) && is_int($page)) { if(isset($page) && is_int($page)) {
$url .= "/$page"; $url .= "/$page";
} }
@ -629,7 +632,7 @@ EOD;
} }
function get_service_url() { function get_service_url() {
return get_bloginfo('url') . '/' . $this->script_name . '/' . $this->SERVICE_PATH; return $this->app_base . $this->SERVICE_PATH;
} }
function get_entry_url($postID = NULL) { function get_entry_url($postID = NULL) {
@ -638,7 +641,7 @@ EOD;
$postID = (int) $GLOBALS['post']->ID; $postID = (int) $GLOBALS['post']->ID;
} }
$url = get_bloginfo('url') . '/' . $this->script_name . '/' . $this->ENTRY_PATH . "/$postID"; $url = $this->app_base . $this->ENTRY_PATH . "/$postID";
log_app('function',"get_entry_url() = $url"); log_app('function',"get_entry_url() = $url");
return $url; return $url;
@ -655,7 +658,7 @@ EOD;
$postID = (int) $GLOBALS['post']->ID; $postID = (int) $GLOBALS['post']->ID;
} }
$url = get_bloginfo('url') . '/' . $this->script_name . '/' . $this->MEDIA_SINGLE_PATH ."/file/$postID"; $url = $this->app_base . $this->MEDIA_SINGLE_PATH ."/file/$postID";
log_app('function',"get_media_url() = $url"); log_app('function',"get_media_url() = $url");
return $url; return $url;
@ -919,7 +922,7 @@ EOD;
$ctloc = $this->get_entry_url($post_ID); $ctloc = $this->get_entry_url($post_ID);
break; break;
case 'attachment': case 'attachment':
$edit = get_bloginfo('url') . '/' . $this->script_name . "/attachments/$post_ID"; $edit = $this->app_base . "attachments/$post_ID";
break; break;
} }
header("Content-Type: $this->ATOM_CONTENT_TYPE"); header("Content-Type: $this->ATOM_CONTENT_TYPE");

View File

@ -134,6 +134,9 @@ add_filter('comment_flood_filter', 'wp_throttle_comment_flood', 10, 3);
add_filter('pre_comment_content', 'wp_rel_nofollow', 15); add_filter('pre_comment_content', 'wp_rel_nofollow', 15);
add_filter('comment_email', 'antispambot'); add_filter('comment_email', 'antispambot');
//Atom SSL support
add_filter('atom_service_url','atom_service_url_filter');
// Actions // Actions
add_action('wp_head', 'rsd_link'); add_action('wp_head', 'rsd_link');
add_action('wp_head', 'wlwmanifest_link'); add_action('wp_head', 'wlwmanifest_link');

View File

@ -1484,4 +1484,36 @@ function absint( $maybeint ) {
return abs( intval( $maybeint ) ); return abs( intval( $maybeint ) );
} }
/**
* Determines if the blog can be accessed over SSL
* @return bool whether of not SSL access is available
*/
function url_is_accessable_via_ssl($url)
{
if (in_array('curl', get_loaded_extensions())) {
$ssl = preg_replace( '/^http:\/\//', 'https://', $url );
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $ssl);
curl_setopt($ch, CURLOPT_FAILONERROR, true);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
$data = curl_exec ($ch);
$status = curl_getinfo($ch, CURLINFO_HTTP_CODE);
curl_close ($ch);
if ($status == 200 || $status == 401) {
return true;
}
}
return false;
}
function atom_service_url_filter($url)
{
if ( url_is_accessable_via_ssl($url) )
return preg_replace( '/^http:\/\//', 'https://', $url );
}
?> ?>

View File

@ -19,7 +19,6 @@ include('./wp-config.php');
if ( isset( $_GET['rsd'] ) ) { // http://archipelago.phrasewise.com/rsd if ( isset( $_GET['rsd'] ) ) { // http://archipelago.phrasewise.com/rsd
header('Content-Type: text/xml; charset=' . get_option('blog_charset'), true); header('Content-Type: text/xml; charset=' . get_option('blog_charset'), true);
?> ?>
<?php echo '<?xml version="1.0" encoding="'.get_option('blog_charset').'"?'.'>'; ?> <?php echo '<?xml version="1.0" encoding="'.get_option('blog_charset').'"?'.'>'; ?>
<rsd version="1.0" xmlns="http://archipelago.phrasewise.com/rsd"> <rsd version="1.0" xmlns="http://archipelago.phrasewise.com/rsd">
@ -32,7 +31,7 @@ header('Content-Type: text/xml; charset=' . get_option('blog_charset'), true);
<api name="Movable Type" blogID="1" preferred="false" apiLink="<?php bloginfo_rss('wpurl') ?>/xmlrpc.php" /> <api name="Movable Type" blogID="1" preferred="false" apiLink="<?php bloginfo_rss('wpurl') ?>/xmlrpc.php" />
<api name="MetaWeblog" blogID="1" preferred="false" apiLink="<?php bloginfo_rss('wpurl') ?>/xmlrpc.php" /> <api name="MetaWeblog" blogID="1" preferred="false" apiLink="<?php bloginfo_rss('wpurl') ?>/xmlrpc.php" />
<api name="Blogger" blogID="1" preferred="false" apiLink="<?php bloginfo_rss('wpurl') ?>/xmlrpc.php" /> <api name="Blogger" blogID="1" preferred="false" apiLink="<?php bloginfo_rss('wpurl') ?>/xmlrpc.php" />
<api name="Atom" blogID="1" preferred="false" apiLink="<?php bloginfo_rss('wpurl') ?>/wp-app.php/service" /> <api name="Atom" blogID="" preferred="false" apiLink="<?php echo apply_filters('atom_service_url', (get_bloginfo('url')."/wp-app.php/service"))?>" />
</apis> </apis>
</service> </service>
</rsd> </rsd>