diff -r 000000000000 -r 4eba9c11703f web/Zend/Service/WindowsAzure/Credentials/SharedKeyLite.php --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/web/Zend/Service/WindowsAzure/Credentials/SharedKeyLite.php Mon Dec 13 18:29:26 2010 +0100 @@ -0,0 +1,166 @@ +_usePathStyleUri) { + $path = substr($path, strpos($path, '/')); + } + + // Determine query + $queryString = $this->_prepareQueryStringForSigning($queryString); + + // Build canonicalized resource string + $canonicalizedResource = '/' . $this->_accountName; + if ($this->_usePathStyleUri) { + $canonicalizedResource .= '/' . $this->_accountName; + } + $canonicalizedResource .= $path; + if ($queryString !== '') { + $canonicalizedResource .= $queryString; + } + + // Request date + $requestDate = ''; + if (isset($headers[Zend_Service_WindowsAzure_Credentials_CredentialsAbstract::PREFIX_STORAGE_HEADER . 'date'])) { + $requestDate = $headers[Zend_Service_WindowsAzure_Credentials_CredentialsAbstract::PREFIX_STORAGE_HEADER . 'date']; + } else { + $requestDate = gmdate('D, d M Y H:i:s', time()) . ' GMT'; // RFC 1123 + } + + // Create string to sign + $stringToSign = array(); + $stringToSign[] = $requestDate; // Date + $stringToSign[] = $canonicalizedResource; // Canonicalized resource + $stringToSign = implode("\n", $stringToSign); + $signString = base64_encode(hash_hmac('sha256', $stringToSign, $this->_accountKey, true)); + + // Sign request + $headers[Zend_Service_WindowsAzure_Credentials_CredentialsAbstract::PREFIX_STORAGE_HEADER . 'date'] = $requestDate; + $headers['Authorization'] = 'SharedKeyLite ' . $this->_accountName . ':' . $signString; + + // Return headers + return $headers; + } + + /** + * Prepare query string for signing + * + * @param string $value Original query string + * @return string Query string for signing + */ + protected function _prepareQueryStringForSigning($value) + { + // Check for 'comp=' + if (strpos($value, 'comp=') === false) { + // If not found, no query string needed + return ''; + } else { + // If found, make sure it is the only parameter being used + if (strlen($value) > 0 && strpos($value, '?') === 0) { + $value = substr($value, 1); + } + + // Split parts + $queryParts = explode('&', $value); + foreach ($queryParts as $queryPart) { + if (strpos($queryPart, 'comp=') !== false) { + return '?' . $queryPart; + } + } + + // Should never happen... + return ''; + } + } +}