| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 | <?php/** * Copyright 2019 Huawei Technologies Co.,Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); you may not use * this file except in compliance with the License.  You may obtain a copy of the * License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software distributed * under the License 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 Obs\Internal\Signature;use Obs\Internal\Resource\Constants;use Obs\Internal\Common\Model;use Obs\Internal\Resource\V2Constants;class DefaultSignature extends AbstractSignature{	const INTEREST_HEADER_KEY_LIST = array('content-type', 'content-md5', 'date');			public function __construct($ak, $sk, $pathStyle, $endpoint, $methodName, $signature, $securityToken=false, $isCname=false)	{	    	    parent::__construct($ak, $sk, $pathStyle, $endpoint, $methodName, $signature, $securityToken, $isCname);	}		public function doAuth(array &$requestConfig, array &$params, Model $model)	{   		$result = $this -> prepareAuth($requestConfig, $params, $model);				$result['headers']['Date'] = gmdate('D, d M Y H:i:s \G\M\T');		$canonicalstring = $this-> makeCanonicalstring($result['method'], $result['headers'], $result['pathArgs'], $result['dnsParam'], $result['uriParam']);				$result['cannonicalRequest'] = $canonicalstring;				$signature = base64_encode(hash_hmac('sha1', $canonicalstring, $this->sk, true));				$constants = Constants::selectConstants($this -> signature);		$signatureFlag = $constants::FLAG;				$authorization = $signatureFlag . ' ' . $this->ak . ':' . $signature;				$result['headers']['Authorization'] = $authorization;				return $result;	}			public function makeCanonicalstring($method, $headers, $pathArgs, $bucketName, $objectKey, $expires = null)	{		$buffer = [];		$buffer[] = $method;		$buffer[] = "\n";			$interestHeaders = [];		$constants = Constants::selectConstants($this -> signature);				foreach ($headers as $key => $value){            $key = strtolower($key);			if(in_array($key, self::INTEREST_HEADER_KEY_LIST) || strpos($key, $constants::HEADER_PREFIX) === 0){				$interestHeaders[$key] = $value;			}		}				if(array_key_exists($constants::ALTERNATIVE_DATE_HEADER, $interestHeaders)){			$interestHeaders['date'] = '';		} 				if($expires !== null){			$interestHeaders['date'] = strval($expires);		}				if(!array_key_exists('content-type', $interestHeaders)){			$interestHeaders['content-type'] = '';		}				if(!array_key_exists('content-md5', $interestHeaders)){			$interestHeaders['content-md5'] = '';		}				ksort($interestHeaders);				foreach ($interestHeaders as $key => $value){		    if(strpos($key, $constants::HEADER_PREFIX) === 0){				$buffer[] = $key . ':' . $value;			}else{				$buffer[] = $value;			}			$buffer[] = "\n";		}				$uri = '';		$bucketName = $this->isCname ? $headers['Host'] : $bucketName;		if($bucketName){			$uri .= '/';			$uri .= $bucketName;			if(!$this->pathStyle){				$uri .= '/';			}		}				if($objectKey){			if(!($pos=strripos($uri, '/')) || strlen($uri)-1 !== $pos){				$uri .= '/';			}			$uri .= $objectKey;		}		$buffer[] = $uri === ''? '/' : $uri;		if(!empty($pathArgs)){			ksort($pathArgs);			$_pathArgs = [];			foreach ($pathArgs as $key => $value){			    if(in_array(strtolower($key), $constants::ALLOWED_RESOURCE_PARAMTER_NAMES) || strpos($key, $constants::HEADER_PREFIX) === 0){					$_pathArgs[] = $value === null || $value === '' ? $key : $key . '=' . urldecode($value);				}			}			if(!empty($_pathArgs)){				$buffer[] = '?';				$buffer[] = implode('&', $_pathArgs);			}		}		return implode('', $buffer);	}}
 |