From: Christian Weiske Date: Thu, 21 Aug 2014 15:20:04 +0000 (+0200) Subject: Support oauth on apache+fastcgi X-Git-Tag: v0.1.0~12 X-Git-Url: https://git.cweiske.de/grauphel.git/commitdiff_plain/95103edfeeaf1bc750369ec35346fb53225af83b?hp=6a35b4262cccf97f932efbfe3cd9f546ead1be52 Support oauth on apache+fastcgi --- diff --git a/lib/oauth.php b/lib/oauth.php index e2eb651..d6c72e8 100644 --- a/lib/oauth.php +++ b/lib/oauth.php @@ -140,7 +140,27 @@ class OAuth */ public static function getProvider() { - return new \OAuthProvider(); + //$_SERVER['REDIRECT_HTTP_AUTHORIZATION'] = $_SERVER['HTTP_AUTHORIZATION']; + //unset($_SERVER['HTTP_AUTHORIZATION']); + + $params = array(); + if (!isset($_SERVER['HTTP_AUTHORIZATION']) + && isset($_SERVER['REDIRECT_HTTP_AUTHORIZATION']) + ) { + //FastCgi puts the headers in REDIRECT_HTTP_AUTHORIZATION, + // but the oauth extension does not read that. + // we have to parse the parameters manually + $regex = "/(oauth_[a-z_-]*)=(?:\"([^\"]*)\"|([^,]*))/"; + preg_match_all( + $regex, $_SERVER['REDIRECT_HTTP_AUTHORIZATION'], $matches + ); + + foreach ($matches[1] as $key => $paramName) { + $params[$paramName] = urldecode($matches[2][$key]); + } + } + + return new \OAuthProvider($params); } } ?>