123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466 |
- <?php
- namespace QCloud\COSSTS;
- class Sts{
- // 临时密钥计算样例
- function _hex2bin($data) {
- $len = strlen($data);
- return pack("H" . $len, $data);
- }
- // obj 转 query string
- function json2str($obj, $notEncode = false) {
- ksort($obj);
- $arr = array();
- if(!is_array($obj)){
- throw new \Exception('$obj must be an array, the actual value is:' . json_encode($obj));
- }
- foreach ($obj as $key => $val) {
- array_push($arr, $key . '=' . ($notEncode ? $val : rawurlencode($val)));
- }
- return join('&', $arr);
- }
- // 计算临时密钥用的签名
- function getSignature($opt, $key, $method, $config) {
- $host = "sts.tencentcloudapi.com";
- if (array_key_exists('domain', $config)) {
- $host = $config['domain'];
- }
- if (array_key_exists('endpoint', $config)) {
- $host = "sts." . $config['endpoint'];
- }
- $formatString = $method . $host . '/?' . $this->json2str($opt, 1);
- $sign = hash_hmac('sha1', $formatString, $key);
- $sign = base64_encode($this->_hex2bin($sign));
- return $sign;
- }
- // v2接口的key首字母小写,v3改成大写,此处做了向下兼容
- function backwardCompat($result) {
- if(!is_array($result)){
- throw new \Exception('$result must be an array, the actual value is:' . json_encode($result));
- }
- $compat = array();
- foreach ($result as $key => $value) {
- if(is_array($value)) {
- $compat[lcfirst($key)] = $this->backwardCompat($value);
- } elseif ($key == 'Token') {
- $compat['sessionToken'] = $value;
- } else {
- $compat[lcfirst($key)] = $value;
- }
- }
- return $compat;
- }
- // 获取临时密钥
- function getTempKeys($config) {
- $result = null;
- try{
- if(array_key_exists('policy', $config)){
- $policy = $config['policy'];
- }else{
- if(array_key_exists('bucket', $config)){
- $ShortBucketName = substr($config['bucket'],0, strripos($config['bucket'], '-'));
- $AppId = substr($config['bucket'], 1 + strripos($config['bucket'], '-'));
- }else{
- throw new \Exception("bucket== null");
- }
- if(array_key_exists('allowPrefix', $config)){
- $resource = array();
- foreach($config['allowPrefix'] as &$val) {
- if (!(strpos($val, '/') === 0)) {
- $allow = '/' . $val;
- }
- $resource[] = 'qcs::cos:' . $config['region'] . ':uid/' . $AppId . ':' . $config['bucket'] . '/' . $val;
- }
- // 处理万象资源
- if(array_key_exists('allowCiSource', $config) && $config['allowCiSource'] === true) {
- $resource[] = 'qcs::ci:' . $config['region'] . ':uid/' . $AppId . ':' . 'bucket/' . $config['bucket'] . '/*';
- }
- }else{
- throw new \Exception("allowPrefix == null");
- }
- if(!array_key_exists('region', $config)) {
- throw new \Exception("region == null");
- }
- if (!array_key_exists('condition', $config)) {
- $policy = array(
- 'version'=> '2.0',
- 'statement'=> array(
- array(
- 'action'=> $config['allowActions'],
- 'effect'=> 'allow',
- 'resource'=> $resource
- )
- )
- );
- } else {
- $policy = array(
- 'version'=> '2.0',
- 'statement'=> array(
- array(
- 'action'=> $config['allowActions'],
- 'effect'=> 'allow',
- 'resource'=> $resource,
- 'condition'=>$config['condition']
- )
- )
- );
- }
- }
- $policyStr = str_replace('\\/', '/', json_encode($policy));
- $Action = 'GetFederationToken';
- $Nonce = rand(10000, 20000);
- $Timestamp = time();
- $Method = 'POST';
- if(array_key_exists('durationSeconds', $config)){
- if(!(is_integer($config['durationSeconds']))){
- throw new \Exception("durationSeconds must be a int type");
- }
- }
- $params = array(
- 'SecretId'=> $config['secretId'],
- 'Timestamp'=> $Timestamp,
- 'Nonce'=> $Nonce,
- 'Action'=> $Action,
- 'DurationSeconds'=> $config['durationSeconds'],
- 'Version'=>'2018-08-13',
- 'Name'=> 'cos',
- 'Region'=> $config['region'],
- 'Policy'=> urlencode($policyStr)
- );
- $params['Signature'] = $this->getSignature($params, $config['secretKey'], $Method, $config);
- $url = 'https://sts.tencentcloudapi.com/';
- if(array_key_exists('url', $config)) {
- $url = $config['url'];
- }
- if(!array_key_exists('url', $config) && array_key_exists('domain', $config)) {
- $url = 'https://sts.' . $config['domain'];
- }
- if(array_key_exists('endpoint', $config)) {
- $url = 'https://sts.' . $config['endpoint'];
- }
- $ch = curl_init($url);
- if(array_key_exists('proxy', $config)){
- $config['proxy'] && curl_setopt($ch, CURLOPT_PROXY, $config['proxy']);
- }
- curl_setopt($ch, CURLOPT_HEADER, 0);
- curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,0);
- curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,0);
- curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
- curl_setopt($ch, CURLOPT_POST, 1);
- curl_setopt($ch, CURLOPT_POSTFIELDS, $this->json2str($params));
- $result = curl_exec($ch);
- if(curl_errno($ch)) $result = curl_error($ch);
- curl_close($ch);
- $result = json_decode($result, 1);
- if (isset($result['Response'])) {
- $result = $result['Response'];
- if(isset($result['Error'])){
- throw new \Exception("get cam failed");
- }
- $result['startTime'] = $result['ExpiredTime'] - $config['durationSeconds'];
- }
- $result = $this->backwardCompat($result);
- return $result;
- }catch(\Exception $e){
- if($result == null){
- $result = "error: " . $e->getMessage();
- }else{
- $result = json_encode($result);
- }
- throw new \Exception($result);
- }
- }
- // 获取临时密钥-兼容万象资源 不在维护,请使用getTempKeys函数,$config的ci_source字段
- function getTempKeys4Ci($config) {
- $result = null;
- try{
- if(array_key_exists('policy', $config)){
- $policy = $config['policy'];
- }else{
- if(array_key_exists('bucket', $config)){
- $ShortBucketName = substr($config['bucket'],0, strripos($config['bucket'], '-'));
- $AppId = substr($config['bucket'], 1 + strripos($config['bucket'], '-'));
- }else{
- throw new Exception("bucket== null");
- }
- $resource = array();
- $resource[] = 'qcs::ci:' . $config['region'] . ':uid/' . $AppId . ':' . 'bucket/' . $config['bucket'] . '/*';
- if(array_key_exists('allowPrefix', $config)){
- foreach($config['allowPrefix'] as &$val) {
- if (!(strpos($val, '/') === 0)) {
- $allow = '/' . $val;
- }
- $resource[] = 'qcs::cos:' . $config['region'] . ':uid/' . $AppId . ':' . $config['bucket'] . '/' . $val;
- }
- }else{
- throw new \Exception("allowPrefix == null");
- }
- if(!array_key_exists('region', $config)) {
- throw new \Exception("region == null");
- }
- if (!array_key_exists('condition', $config)) {
- $policy = array(
- 'version'=> '2.0',
- 'statement'=> array(
- array(
- 'action'=> $config['allowActions'],
- 'effect'=> 'allow',
- 'resource'=> $resource
- )
- )
- );
- } else {
- $policy = array(
- 'version'=> '2.0',
- 'statement'=> array(
- array(
- 'action'=> $config['allowActions'],
- 'effect'=> 'allow',
- 'resource'=> $resource,
- 'condition'=>$config['condition']
- )
- )
- );
- }
- }
- $policyStr = str_replace('\\/', '/', json_encode($policy));
- $Action = 'GetFederationToken';
- $Nonce = rand(10000, 20000);
- $Timestamp = time();
- $Method = 'POST';
- if(array_key_exists('durationSeconds', $config)){
- if(!(is_integer($config['durationSeconds']))){
- throw new \Exception("durationSeconds must be a int type");
- }
- }
- $params = array(
- 'SecretId'=> $config['secretId'],
- 'Timestamp'=> $Timestamp,
- 'Nonce'=> $Nonce,
- 'Action'=> $Action,
- 'DurationSeconds'=> $config['durationSeconds'],
- 'Version'=>'2018-08-13',
- 'Name'=> 'cos',
- 'Region'=> $config['region'],
- 'Policy'=> urlencode($policyStr)
- );
- $params['Signature'] = $this->getSignature($params, $config['secretKey'], $Method, $config);
- $url = 'https://sts.tencentcloudapi.com/';
- if(array_key_exists('url', $config)) {
- $url = $config['url'];
- }
- if(!array_key_exists('url', $config) && array_key_exists('domain', $config)) {
- $url = 'https://sts.' . $config['domain'];
- }
- if(array_key_exists('endpoint', $config)) {
- $url = 'https://sts.' . $config['endpoint'];
- }
- $ch = curl_init($url);
- if(array_key_exists('proxy', $config)){
- $config['proxy'] && curl_setopt($ch, CURLOPT_PROXY, $config['proxy']);
- }
- curl_setopt($ch, CURLOPT_HEADER, 0);
- curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,0);
- curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,0);
- curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
- curl_setopt($ch, CURLOPT_POST, 1);
- curl_setopt($ch, CURLOPT_POSTFIELDS, $this->json2str($params));
- $result = curl_exec($ch);
- if(curl_errno($ch)) $result = curl_error($ch);
- curl_close($ch);
- $result = json_decode($result, 1);
- if (isset($result['Response'])) {
- $result = $result['Response'];
- if(isset($result['Error'])){
- throw new \Exception("get cam failed");
- }
- $result['startTime'] = $result['ExpiredTime'] - $config['durationSeconds'];
- }
- $result = $this->backwardCompat($result);
- return $result;
- }catch(\Exception $e){
- if($result == null){
- $result = "error: " . $e->getMessage();
- }else{
- $result = json_encode($result);
- }
- throw new \Exception($result);
- }
- }
- //申请角色授权
- function getRoleCredential($config) {
- $result = null;
- try{
- if(array_key_exists('policy', $config)){
- $policy = $config['policy'];
- }else{
- if(array_key_exists('bucket', $config)){
- $ShortBucketName = substr($config['bucket'],0, strripos($config['bucket'], '-'));
- $AppId = substr($config['bucket'], 1 + strripos($config['bucket'], '-'));
- }else{
- throw new \Exception("bucket== null");
- }
- if(array_key_exists('allowPrefix', $config)){
- $resource = array();
- foreach($config['allowPrefix'] as &$val) {
- if (!(strpos($val, '/') === 0)) {
- $allow = '/' . $val;
- }
- $resource[] = 'qcs::cos:' . $config['region'] . ':uid/' . $AppId . ':' . $config['bucket'] . '/' . $val;
- }
- }else{
- throw new \Exception("allowPrefix == null");
- }
- if(!array_key_exists('region', $config)) {
- throw new \Exception("region == null");
- }
- if (!array_key_exists('condition', $config)) {
- $policy = array(
- 'version'=> '2.0',
- 'statement'=> array(
- array(
- 'action'=> $config['allowActions'],
- 'effect'=> 'allow',
- 'resource'=> $resource
- )
- )
- );
- } else {
- $policy = array(
- 'version'=> '2.0',
- 'statement'=> array(
- array(
- 'action'=> $config['allowActions'],
- 'effect'=> 'allow',
- 'resource'=> $resource,
- 'condition'=>$config['condition']
- )
- )
- );
- }
- }
- if (array_key_exists('roleArn', $config)) {
- $RoleArn = $config['roleArn'];
- } else {
- throw new \Exception("roleArn == null");
- }
- $policyStr = str_replace('\\/', '/', json_encode($policy));
- $Action = 'AssumeRole';
- $Nonce = rand(10000, 20000);
- $Timestamp = time();
- $Method = 'POST';
- $ExternalId = "";
- if (array_key_exists('externalId', $config)) {
- $ExternalId = $config['externalId'];
- }
- if(array_key_exists('durationSeconds', $config)){
- if(!(is_integer($config['durationSeconds']))){
- throw new \Exception("durationSeconds must be a int type");
- }
- }
- $params = array(
- 'SecretId'=> $config['secretId'],
- 'Timestamp'=> $Timestamp,
- 'RoleArn'=> $RoleArn,
- 'Action'=> $Action,
- 'Nonce'=> $Nonce,
- 'DurationSeconds'=> $config['durationSeconds'],
- 'Version'=>'2018-08-13',
- 'RoleSessionName'=> 'cos',
- 'Region'=> $config['region'],
- 'ExternalId' => $ExternalId,
- 'Policy'=> urlencode($policyStr)
- );
- $params['Signature'] = $this->getSignature($params, $config['secretKey'], $Method, $config);
- $url = 'https://sts.internal.tencentcloudapi.com/';
- if(array_key_exists('endpoint', $config)) {
- $url = 'https://sts.' . $config['endpoint'];
- }
- $ch = curl_init($url);
- if(array_key_exists('proxy', $config)){
- $config['proxy'] && curl_setopt($ch, CURLOPT_PROXY, $config['proxy']);
- }
- curl_setopt($ch, CURLOPT_HEADER, 0);
- curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,0);
- curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,0);
- curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
- curl_setopt($ch, CURLOPT_POST, 1);
- curl_setopt($ch, CURLOPT_POSTFIELDS, $this->json2str($params));
- $result = curl_exec($ch);
- if(curl_errno($ch)) $result = curl_error($ch);
- curl_close($ch);
- $result = json_decode($result, 1);
- if (isset($result['Response'])) {
- $result = $result['Response'];
- if(isset($result['Error'])){
- throw new \Exception("get cam failed");
- }
- $result['startTime'] = $result['ExpiredTime'] - $config['durationSeconds'];
- }
- $result = $this->backwardCompat($result);
- return $result;
- }catch(\Exception $e){
- if($result == null){
- $result = "error: " . $e->getMessage();
- }else{
- $result = json_encode($result);
- }
- throw new \Exception($result);
- }
- }
- // get policy
- function getPolicy($scopes){
- if (!is_array($scopes)){
- return null;
- }
- $statements = array();
- for($i=0, $counts=count($scopes); $i < $counts; $i++){
- $actions=array();
- $resources = array();
- array_push($actions, $scopes[$i]->get_action());
- array_push($resources, $scopes[$i]->get_resource());
- $statement = array(
- 'action' => $actions,
- 'effect' => $scopes[$i]->get_effect(),
- 'resource' => $resources
- );
- array_push($statements, $statement);
- }
- $policy = array(
- 'version' => '2.0',
- 'statement' => $statements
- );
- return $policy;
- }
- }
- ?>
|