123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155 |
- <?php
- abstract class RpcAcsRequest extends AcsRequest
- {
-
- private $dateTimeFormat = 'Y-m-d\TH:i:s\Z';
-
- private $domainParameters = array();
-
- protected $method = 'GET';
-
- protected $acceptFormat = 'JSON';
-
- private function prepareValue($value)
- {
- if (is_bool($value)) {
- if ($value) {
- return 'true';
- }
- return 'false';
- }
- return $value;
- }
-
- public function composeUrl($iSigner, $credential, $domain)
- {
- $apiParams = parent::getQueryParameters();
- foreach ($apiParams as $key => $value) {
- $apiParams[$key] = $this->prepareValue($value);
- }
- $apiParams['RegionId'] = $this->getRegionId();
- $apiParams['AccessKeyId'] = $credential->getAccessKeyId();
- $apiParams['Format'] = $this->getAcceptFormat();
- $apiParams['SignatureMethod'] = $iSigner->getSignatureMethod();
- $apiParams['SignatureVersion'] = $iSigner->getSignatureVersion();
- if ($iSigner->getSignatureType() != null) {
- $apiParams['SignatureType'] = $iSigner->getSignatureType();
- }
- $apiParams['SignatureNonce'] = md5(uniqid(mt_rand(), true));
- $apiParams['Timestamp'] = gmdate($this->dateTimeFormat);
- $apiParams['Action'] = $this->getActionName();
- $apiParams['Version'] = $this->getVersion();
- if ($credential->getSecurityToken() != null) {
- $apiParams['SecurityToken'] = $credential->getSecurityToken();
- }
- if ($credential instanceof BearerTokenCredential) {
- $apiParams['BearerToken'] = $credential->getBearerToken();
- }
- $apiParams['Signature'] = $this->computeSignature($apiParams, $credential->getAccessSecret(), $iSigner);
- if (parent::getMethod() === 'POST') {
- $requestUrl = $this->getProtocol() . '://' . $domain . '/';
- foreach ($apiParams as $apiParamKey => $apiParamValue) {
- $this->putDomainParameters($apiParamKey, $apiParamValue);
- }
- return $requestUrl;
- }
- $requestUrl = $this->getProtocol() . '://' . $domain . '/?';
- foreach ($apiParams as $apiParamKey => $apiParamValue) {
- $requestUrl .= "$apiParamKey=" . urlencode($apiParamValue) . '&';
- }
- return substr($requestUrl, 0, -1);
- }
-
- private function computeSignature($parameters, $accessKeySecret, $iSigner)
- {
- ksort($parameters);
- $canonicalizedQueryString = '';
- foreach ($parameters as $key => $value) {
- $canonicalizedQueryString .= '&' . $this->percentEncode($key) . '=' . $this->percentEncode($value);
- }
- $this->stringToBeSigned =
- parent::getMethod() . '&%2F&' . $this->percentEncode(substr($canonicalizedQueryString, 1));
- return $iSigner->signString($this->stringToBeSigned, $accessKeySecret . '&');
- }
-
- protected function percentEncode($str)
- {
- $res = urlencode($str);
- $res = str_replace(array('+', '*'), array('%20', '%2A'), $res);
- $res = preg_replace('/%7E/', '~', $res);
- return $res;
- }
-
- public function getDomainParameter()
- {
- return $this->domainParameters;
- }
-
- public function putDomainParameters($name, $value)
- {
- $this->domainParameters[$name] = $value;
- }
- }
|