2013-07-08 13:11:07 +04:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Copyright 2010-2013 Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License").
|
|
|
|
* You may not use this file except in compliance with the License.
|
|
|
|
* A copy of the License is located at
|
|
|
|
*
|
|
|
|
* http://aws.amazon.com/apache2.0
|
|
|
|
*
|
|
|
|
* or in the "license" file accompanying this file. This file 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Aws\Common\Signature;
|
|
|
|
|
|
|
|
use Aws\Common\Credentials\CredentialsInterface;
|
|
|
|
use Guzzle\Http\Message\RequestInterface;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Implementation of Signature Version 2
|
|
|
|
* @link http://aws.amazon.com/articles/1928
|
|
|
|
*/
|
|
|
|
class SignatureV2 extends AbstractSignature
|
|
|
|
{
|
|
|
|
public function signRequest(RequestInterface $request, CredentialsInterface $credentials)
|
|
|
|
{
|
|
|
|
// refresh the cached timestamp
|
2014-08-28 02:10:31 +04:00
|
|
|
$timestamp = $this->getTimestamp(true);
|
2013-07-08 13:11:07 +04:00
|
|
|
|
|
|
|
// set values we need in CanonicalizedParameterString
|
2014-08-28 02:10:31 +04:00
|
|
|
$this->addParameter($request, 'Timestamp', gmdate('c', $timestamp));
|
2013-07-08 13:11:07 +04:00
|
|
|
$this->addParameter($request, 'SignatureVersion', '2');
|
|
|
|
$this->addParameter($request, 'SignatureMethod', 'HmacSHA256');
|
|
|
|
$this->addParameter($request, 'AWSAccessKeyId', $credentials->getAccessKeyId());
|
|
|
|
|
|
|
|
if ($token = $credentials->getSecurityToken()) {
|
|
|
|
$this->addParameter($request, 'SecurityToken', $token);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get the path and ensure it's absolute
|
|
|
|
$path = '/' . ltrim($request->getUrl(true)->normalizePath()->getPath(), '/');
|
|
|
|
|
|
|
|
// build string to sign
|
|
|
|
$sign = $request->getMethod() . "\n"
|
|
|
|
. $request->getHost() . "\n"
|
|
|
|
. $path . "\n"
|
|
|
|
. $this->getCanonicalizedParameterString($request);
|
|
|
|
|
|
|
|
// Add the string to sign to the request for debugging purposes
|
|
|
|
$request->getParams()->set('aws.string_to_sign', $sign);
|
|
|
|
|
|
|
|
$signature = base64_encode(
|
|
|
|
hash_hmac(
|
|
|
|
'sha256',
|
|
|
|
$sign,
|
|
|
|
$credentials->getSecretKey(),
|
|
|
|
true
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->addParameter($request, 'Signature', $signature);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a parameter key and value to the request according to type
|
|
|
|
*
|
|
|
|
* @param RequestInterface $request The request
|
|
|
|
* @param string $key The name of the parameter
|
|
|
|
* @param string $value The value of the parameter
|
|
|
|
*/
|
|
|
|
public function addParameter(RequestInterface $request, $key, $value)
|
|
|
|
{
|
|
|
|
if ($request->getMethod() == 'POST') {
|
|
|
|
$request->setPostField($key, $value);
|
|
|
|
} else {
|
|
|
|
$request->getQuery()->set($key, $value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the canonicalized query/parameter string for a request
|
|
|
|
*
|
|
|
|
* @param RequestInterface $request Request used to build canonicalized string
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2014-08-28 02:10:31 +04:00
|
|
|
private function getCanonicalizedParameterString(RequestInterface $request)
|
2013-07-08 13:11:07 +04:00
|
|
|
{
|
|
|
|
if ($request->getMethod() == 'POST') {
|
|
|
|
$params = $request->getPostFields()->toArray();
|
|
|
|
} else {
|
|
|
|
$params = $request->getQuery()->toArray();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Don't resign a previous signature value
|
|
|
|
unset($params['Signature']);
|
|
|
|
uksort($params, 'strcmp');
|
|
|
|
|
|
|
|
$str = '';
|
|
|
|
foreach ($params as $key => $val) {
|
|
|
|
$str .= rawurlencode($key) . '=' . rawurlencode($val) . '&';
|
|
|
|
}
|
|
|
|
|
|
|
|
return substr($str, 0, -1);
|
|
|
|
}
|
|
|
|
}
|