request['auth']['user'], $http->request['auth']['pass'])) { if (!isset($http->config['request']['auth']['realm']) && !self::_getServerInformation($http)) { return; } $http->request['header']['Authorization'] = self::_generateHeader($http); } } /** * Retrive information about the authetication * * @param HttpSocket $http * @return boolean */ protected static function _getServerInformation(HttpSocket $http) { $originalRequest = $http->request; $http->request['auth'] = array('method' => false); $http->request($http->request); $http->request = $originalRequest; if (empty($http->response['header']['WWW-Authenticate'])) { return false; } preg_match_all('@(\w+)=(?:(?:")([^"]+)"|([^\s,$]+))@', $http->response['header']['WWW-Authenticate'], $matches, PREG_SET_ORDER); foreach ($matches as $match) { $http->config['request']['auth'][$match[1]] = $match[2]; } if (!empty($http->config['request']['auth']['qop']) && empty($http->config['request']['auth']['nc'])) { $http->config['request']['auth']['nc'] = 1; } return true; } /** * Generate the header Authorization * * @param HttpSocket $http * @return string */ protected static function _generateHeader(HttpSocket $http) { $a1 = md5($http->request['auth']['user'] . ':' . $http->config['request']['auth']['realm'] . ':' . $http->request['auth']['pass']); $a2 = md5($http->request['method'] . ':' . $http->request['uri']['path']); if (empty($http->config['request']['auth']['qop'])) { $response = md5($a1 . ':' . $http->config['request']['auth']['nonce'] . ':' . $a2); } else { $http->config['request']['auth']['cnonce'] = uniqid(); $nc = sprintf('%08x', $http->config['request']['auth']['nc']++); $response = md5($a1 . ':' . $http->config['request']['auth']['nonce'] . ':' . $nc . ':' . $http->config['request']['auth']['cnonce'] . ':auth:' . $a2); } $authHeader = 'Digest '; $authHeader .= 'username="' . str_replace(array('\\', '"'), array('\\\\', '\\"'), $http->request['auth']['user']) . '", '; $authHeader .= 'realm="' . $http->config['request']['auth']['realm'] . '", '; $authHeader .= 'nonce="' . $http->config['request']['auth']['nonce'] . '", '; $authHeader .= 'uri="' . $http->request['uri']['path'] . '", '; $authHeader .= 'response="' . $response . '"'; if (!empty($http->config['request']['auth']['opaque'])) { $authHeader .= ', opaque="' . $http->config['request']['auth']['opaque'] . '"'; } if (!empty($http->config['request']['auth']['qop'])) { $authHeader .= ', qop="auth", nc=' . $nc . ', cnonce="' . $http->config['request']['auth']['cnonce'] . '"'; } return $authHeader; } }