wupengfei 2 anni fa
parent
commit
144d2660b8
38 ha cambiato i file con 2471 aggiunte e 11 eliminazioni
  1. 1 0
      .idea/gaoyixia.iml
  2. 1 0
      .idea/php.xml
  3. 47 7
      .idea/workspace.xml
  4. 108 0
      application/api/controller/OssManage.php
  5. 2 1
      composer.json
  6. 50 1
      composer.lock
  7. 15 0
      vendor/alibabacloud/sts-20150401/.gitignore
  8. 65 0
      vendor/alibabacloud/sts-20150401/.php_cs.dist
  9. 18 0
      vendor/alibabacloud/sts-20150401/ChangeLog.md
  10. 201 0
      vendor/alibabacloud/sts-20150401/LICENSE
  11. 35 0
      vendor/alibabacloud/sts-20150401/README-CN.md
  12. 35 0
      vendor/alibabacloud/sts-20150401/README.md
  13. 17 0
      vendor/alibabacloud/sts-20150401/autoload.php
  14. 33 0
      vendor/alibabacloud/sts-20150401/composer.json
  15. 83 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleRequest.php
  16. 61 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleResponse.php
  17. 73 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleResponseBody.php
  18. 59 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleResponseBody/assumedRoleUser.php
  19. 83 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleResponseBody/credentials.php
  20. 119 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCRequest.php
  21. 61 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponse.php
  22. 86 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponseBody.php
  23. 71 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponseBody/OIDCTokenInfo.php
  24. 59 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponseBody/assumedRoleUser.php
  25. 83 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponseBody/credentials.php
  26. 95 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLRequest.php
  27. 61 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponse.php
  28. 86 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponseBody.php
  29. 83 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponseBody/SAMLAssertionInfo.php
  30. 59 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponseBody/assumedRoleUser.php
  31. 83 0
      vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponseBody/credentials.php
  32. 61 0
      vendor/alibabacloud/sts-20150401/src/Models/GetCallerIdentityResponse.php
  33. 119 0
      vendor/alibabacloud/sts-20150401/src/Models/GetCallerIdentityResponseBody.php
  34. 289 0
      vendor/alibabacloud/sts-20150401/src/Sts.php
  35. 1 0
      vendor/composer/autoload_psr4.php
  36. 5 0
      vendor/composer/autoload_static.php
  37. 52 0
      vendor/composer/installed.json
  38. 11 2
      vendor/composer/installed.php

+ 1 - 0
.idea/gaoyixia.iml

@@ -8,6 +8,7 @@
       <excludeFolder url="file://$MODULE_DIR$/vendor/alibabacloud/gateway-spi" />
       <excludeFolder url="file://$MODULE_DIR$/vendor/alibabacloud/openapi-util" />
       <excludeFolder url="file://$MODULE_DIR$/vendor/alibabacloud/sdk" />
+      <excludeFolder url="file://$MODULE_DIR$/vendor/alibabacloud/sts-20150401" />
       <excludeFolder url="file://$MODULE_DIR$/vendor/alibabacloud/tea" />
       <excludeFolder url="file://$MODULE_DIR$/vendor/alibabacloud/tea-utils" />
       <excludeFolder url="file://$MODULE_DIR$/vendor/alibabacloud/tea-xml" />

+ 1 - 0
.idea/php.xml

@@ -79,6 +79,7 @@
       <path value="$PROJECT_DIR$/vendor/voduploadsdk/aliyun-php-sdk-oss" />
       <path value="$PROJECT_DIR$/vendor/voduploadsdk/aliyun-php-sdk-vod" />
       <path value="$PROJECT_DIR$/vendor/voduploadsdk/aliyun-php-sdk-core" />
+      <path value="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401" />
     </include_path>
   </component>
 </project>

+ 47 - 7
.idea/workspace.xml

@@ -2,8 +2,44 @@
 <project version="4">
   <component name="ChangeListManager">
     <list default="true" id="1a36929e-c054-4875-a943-593a74e55fa4" name="Default Changelist" comment="">
-      <change afterPath="$PROJECT_DIR$/application/operate/controller/Forum.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/application/api/controller/OssManage.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/.gitignore" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/.php_cs.dist" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/ChangeLog.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/LICENSE" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/README-CN.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/README.md" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/autoload.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/composer.json" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleRequest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleResponse.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleResponseBody.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleResponseBody/assumedRoleUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleResponseBody/credentials.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCRequest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponse.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponseBody.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponseBody/OIDCTokenInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponseBody/assumedRoleUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponseBody/credentials.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLRequest.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponse.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponseBody.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponseBody/SAMLAssertionInfo.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponseBody/assumedRoleUser.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponseBody/credentials.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/GetCallerIdentityResponse.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Models/GetCallerIdentityResponseBody.php" afterDir="false" />
+      <change afterPath="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401/src/Sts.php" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/.idea/gaoyixia.iml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/gaoyixia.iml" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/.idea/php.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/php.xml" afterDir="false" />
       <change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/composer.json" beforeDir="false" afterPath="$PROJECT_DIR$/composer.json" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/composer.lock" beforeDir="false" afterPath="$PROJECT_DIR$/composer.lock" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/vendor/composer/autoload_psr4.php" beforeDir="false" afterPath="$PROJECT_DIR$/vendor/composer/autoload_psr4.php" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/vendor/composer/autoload_static.php" beforeDir="false" afterPath="$PROJECT_DIR$/vendor/composer/autoload_static.php" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/vendor/composer/installed.json" beforeDir="false" afterPath="$PROJECT_DIR$/vendor/composer/installed.json" afterDir="false" />
+      <change beforePath="$PROJECT_DIR$/vendor/composer/installed.php" beforeDir="false" afterPath="$PROJECT_DIR$/vendor/composer/installed.php" afterDir="false" />
     </list>
     <option name="SHOW_DIALOG" value="false" />
     <option name="HIGHLIGHT_CONFLICTS" value="true" />
@@ -105,6 +141,7 @@
       <path value="$PROJECT_DIR$/vendor/voduploadsdk/aliyun-php-sdk-oss" />
       <path value="$PROJECT_DIR$/vendor/voduploadsdk/aliyun-php-sdk-vod" />
       <path value="$PROJECT_DIR$/vendor/voduploadsdk/aliyun-php-sdk-core" />
+      <path value="$PROJECT_DIR$/vendor/alibabacloud/sts-20150401" />
     </include_path>
   </component>
   <component name="ProjectId" id="2CCTRIjtQujUBealCzdAl9v5TA4" />
@@ -121,7 +158,7 @@
     <property name="WebServerToolWindowPanel.toolwindow.show.date" value="false" />
     <property name="WebServerToolWindowPanel.toolwindow.show.permissions" value="false" />
     <property name="WebServerToolWindowPanel.toolwindow.show.size" value="false" />
-    <property name="last_opened_file_path" value="$PROJECT_DIR$" />
+    <property name="last_opened_file_path" value="$PROJECT_DIR$/application/api/controller" />
     <property name="node.js.detected.package.eslint" value="true" />
     <property name="node.js.detected.package.tslint" value="true" />
     <property name="node.js.path.for.package.eslint" value="project" />
@@ -132,11 +169,11 @@
   </component>
   <component name="RecentsManager">
     <key name="CopyFile.RECENT_KEYS">
+      <recent name="D:\zs\gaoyixia\application\api\controller" />
       <recent name="D:\zs\gaoyixia\application\nutrition\view" />
       <recent name="D:\zs\gaoyixia\application\nutrition\controller" />
       <recent name="D:\zs\gaoyixia\application\nutrition\view\video_comment" />
       <recent name="D:\zs\gaoyixia\vendor" />
-      <recent name="D:\zs\gaoyixia\application\api\controller" />
     </key>
   </component>
   <component name="SvnConfiguration">
@@ -187,6 +224,9 @@
       <workItem from="1660957004772" duration="1360000" />
       <workItem from="1661130333783" duration="5129000" />
       <workItem from="1661216727179" duration="3238000" />
+      <workItem from="1661310616095" duration="2405000" />
+      <workItem from="1661389160192" duration="1198000" />
+      <workItem from="1661481696813" duration="3477000" />
     </task>
     <servers />
   </component>
@@ -202,18 +242,18 @@
       <screen x="0" y="0" width="2560" height="1400" />
     </state>
     <state x="1175" y="519" key="#com.intellij.fileTypes.FileTypeChooser/0.0.2560.1400@0.0.2560.1400" timestamp="1659079177590" />
-    <state x="1106" y="469" key="#com.jetbrains.php.actions.copyPaste.importReferences.PhpImportReferencesDialog" timestamp="1660893338386">
+    <state x="1106" y="469" key="#com.jetbrains.php.actions.copyPaste.importReferences.PhpImportReferencesDialog" timestamp="1661501213708">
       <screen x="0" y="0" width="2560" height="1400" />
     </state>
-    <state x="1106" y="469" key="#com.jetbrains.php.actions.copyPaste.importReferences.PhpImportReferencesDialog/0.0.2560.1400@0.0.2560.1400" timestamp="1660893338386" />
+    <state x="1106" y="469" key="#com.jetbrains.php.actions.copyPaste.importReferences.PhpImportReferencesDialog/0.0.2560.1400@0.0.2560.1400" timestamp="1661501213708" />
     <state x="283" y="145" width="1942" height="1088" key="DiffContextDialog" timestamp="1660792261626">
       <screen x="0" y="0" width="2560" height="1400" />
     </state>
     <state x="283" y="145" width="1942" height="1088" key="DiffContextDialog/0.0.2560.1400@0.0.2560.1400" timestamp="1660792261626" />
-    <state x="1281" y="514" key="FileChooserDialogImpl" timestamp="1660888424112">
+    <state x="1281" y="514" key="FileChooserDialogImpl" timestamp="1661481717801">
       <screen x="0" y="0" width="2560" height="1400" />
     </state>
-    <state x="1281" y="514" key="FileChooserDialogImpl/0.0.2560.1400@0.0.2560.1400" timestamp="1660888424112" />
+    <state x="1281" y="514" key="FileChooserDialogImpl/0.0.2560.1400@0.0.2560.1400" timestamp="1661481717801" />
     <state x="1035" y="389" key="MultipleFileMergeDialog" timestamp="1659576166292">
       <screen x="0" y="0" width="2560" height="1400" />
     </state>

+ 108 - 0
application/api/controller/OssManage.php

@@ -0,0 +1,108 @@
+<?php
+namespace app\api\controller;
+use AlibabaCloud\SDK\Sts\V20150401\Sts;
+use \Exception;
+use AlibabaCloud\Tea\Exception\TeaError;
+use AlibabaCloud\Tea\Utils\Utils;
+use Darabonba\OpenApi\Models\Config;
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleRequest;
+use AlibabaCloud\Tea\Utils\Utils\RuntimeOptions;
+use AlibabaCloud\SDK\Vod\V20170321\Models\GetVideoPlayAuthRequest;
+require_once '../vendor/aliyunmail/aliyun-php-sdk-core/Config.php';   // 假定您的源码文件和aliyun-php-sdk处于同一目录
+$path = __DIR__ . \DIRECTORY_SEPARATOR . '..' . \DIRECTORY_SEPARATOR . 'vendor' . \DIRECTORY_SEPARATOR . 'autoload.php';
+if (file_exists($path)) require_once $path;
+date_default_timezone_set('PRC');
+
+/**
+ * @title OssManage
+ * @controller OssManage
+ * @group base
+ */
+class OssManage extends Base
+{
+
+    protected $access_key = 'LTAI5tGJE1WU5ytYK2zBxnDx';// key
+    protected $access_secret = 'uNyByodVajsN1lrMSCxpbrJF46Pwx3';//secret
+
+    protected $role_arn= 'acs:ram::1122764885952286:role/ramoss';//role_arn
+    protected $role_session_name= 'RamOss';//role_session_name
+
+    /**
+     * 使用AK&SK初始化账号Client
+     * @param string $accessKeyId
+     * @param string $accessKeySecret
+     * @return Sts Client
+     */
+    public static function createClient($accessKeyId, $accessKeySecret){
+        $config = new Config([
+            // 您的 AccessKey ID
+            "accessKeyId" => $accessKeyId,
+            // 您的 AccessKey Secret
+            "accessKeySecret" => $accessKeySecret
+        ]);
+        // 访问的域名
+        $config->endpoint = "sts.cn-shanghai.aliyuncs.com";
+        return new Sts($config);
+    }
+
+    /**
+     * @title 获取STS临时身份凭证
+     * @desc 获取STS临时身份凭证
+     * @author qc
+     * @url /api/Oss_manage/getOssCredentials
+     * @method GET
+     * @tag 视频播放凭证
+     * @header name:Authorization require:1 desc:Token
+     * @return name:RequestId type:string default:-- desc:RequestId
+     * @return name:Arn type:string default:-- desc:RoleArn(Arn)
+     * @return name:AssumedRoleId type:string default:-- desc:AssumedRoleId
+     * @return name:SecurityToken type:string default:-- desc:SecurityToken
+     * @return name:AccessKeyId type:string default:-- desc:AccessKeyId
+     * @return name:AccessKeySecret type:string default:-- desc:AccessKeySecret
+     * @return name:Expiration type:string default:-- desc:Expiration
+     */
+    public function getOssCredentials()
+    {
+        $client = self::createClient($this->access_key,$this->access_secret);
+        $assumeRoleRequest = new AssumeRoleRequest([
+            'roleArn' => $this->role_arn,
+            'roleSessionName' =>$this->role_session_name,
+        ]);
+        $runtime = new RuntimeOptions([]);
+        try {
+            // 复制代码运行请自行打印 API 的返回值
+           $res =  $client->assumeRoleWithOptions($assumeRoleRequest, $runtime);
+            $json_res =  json_encode($res,true);
+            $res_arr = json_decode($json_res,true);
+        }
+        catch (Exception $error) {
+            if (!($error instanceof TeaError)) {
+                $error = new TeaError([], $error->getMessage(), $error->getCode(), $error);
+            }
+            $this->error($error->message);
+        }
+        $this->success('ok',$res_arr['body'] );
+    }
+
+
+
+
+}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+

+ 2 - 1
composer.json

@@ -28,7 +28,8 @@
     "alibabacloud/client": "^1.5",
     "qiniu/php-sdk": "^7.6",
     "alibabacloud/sdk": "^1.8",
-    "alibabacloud/vod-20170321": "2.16.9"
+    "alibabacloud/vod-20170321": "2.16.9",
+    "alibabacloud/sts-20150401": "1.1.1"
   },
   "repositories": {
     "packagist": {

+ 50 - 1
composer.lock

@@ -4,7 +4,7 @@
         "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
         "This file is @generated automatically"
     ],
-    "content-hash": "c052b497a47e8db2e96412cee3888406",
+    "content-hash": "83131bbd5384aa539639e39af084d97a",
     "packages": [
         {
             "name": "adbario/php-dot-notation",
@@ -684,6 +684,55 @@
             "time": "2022-07-14T07:58:13+00:00"
         },
         {
+            "name": "alibabacloud/sts-20150401",
+            "version": "1.1.1",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/alibabacloud-sdk-php/sts-20150401.git",
+                "reference": "1273545fb137dcaa63ea877dc7bc8204b534b6e5"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/alibabacloud-sdk-php/sts-20150401/zipball/1273545fb137dcaa63ea877dc7bc8204b534b6e5",
+                "reference": "1273545fb137dcaa63ea877dc7bc8204b534b6e5",
+                "shasum": "",
+                "mirrors": [
+                    {
+                        "url": "https://mirrors.aliyun.com/composer/dists/%package%/%reference%.%type%",
+                        "preferred": true
+                    }
+                ]
+            },
+            "require": {
+                "alibabacloud/darabonba-openapi": "^0.2.5",
+                "alibabacloud/endpoint-util": "^0.1.0",
+                "alibabacloud/openapi-util": "^0.1.10",
+                "alibabacloud/tea-utils": "^0.2.0",
+                "php": ">5.5"
+            },
+            "type": "library",
+            "autoload": {
+                "psr-4": {
+                    "AlibabaCloud\\SDK\\Sts\\V20150401\\": "src"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "Apache-2.0"
+            ],
+            "authors": [
+                {
+                    "name": "Alibaba Cloud SDK",
+                    "email": "sdk-team@alibabacloud.com"
+                }
+            ],
+            "description": "Alibaba Cloud Sts (20150401) SDK Library for PHP",
+            "support": {
+                "source": "https://github.com/alibabacloud-sdk-php/sts-20150401/tree/1.1.1"
+            },
+            "time": "2022-03-26T04:28:44+00:00"
+        },
+        {
             "name": "alibabacloud/tea",
             "version": "3.1.24",
             "source": {

+ 15 - 0
vendor/alibabacloud/sts-20150401/.gitignore

@@ -0,0 +1,15 @@
+composer.phar
+/vendor/
+
+# Commit your application's lock file https://getcomposer.org/doc/01-basic-usage.md#commit-your-composer-lock-file-to-version-control
+# You may choose to ignore a library lock file http://getcomposer.org/doc/02-libraries.md#lock-file
+composer.lock
+
+.vscode/
+.idea
+.DS_Store
+
+cache/
+*.cache
+runtime/
+.php_cs.cache

+ 65 - 0
vendor/alibabacloud/sts-20150401/.php_cs.dist

@@ -0,0 +1,65 @@
+<?php
+/*
+ * This document has been generated with
+ * https://mlocati.github.io/php-cs-fixer-configurator/#version:2.15|configurator
+ * you can change this configuration by importing this file.
+ */
+
+return PhpCsFixer\Config::create()
+    ->setRiskyAllowed(true)
+    ->setIndent('    ')
+    ->setRules([
+        '@PSR2'                                       => true,
+        '@PhpCsFixer'                                 => true,
+        '@Symfony:risky'                              => true,
+        'concat_space'                                => ['spacing' => 'one'],
+        'array_syntax'                                => ['syntax' => 'short'],
+        'array_indentation'                           => true,
+        'combine_consecutive_unsets'                  => true,
+        'method_separation'                           => true,
+        'single_quote'                                => true,
+        'declare_equal_normalize'                     => true,
+        'function_typehint_space'                     => true,
+        'hash_to_slash_comment'                       => true,
+        'include'                                     => true,
+        'lowercase_cast'                              => true,
+        'no_multiline_whitespace_before_semicolons'   => true,
+        'no_leading_import_slash'                     => true,
+        'no_multiline_whitespace_around_double_arrow' => true,
+        'no_spaces_around_offset'                     => true,
+        'no_unneeded_control_parentheses'             => true,
+        'no_unused_imports'                           => true,
+        'no_whitespace_before_comma_in_array'         => true,
+        'no_whitespace_in_blank_line'                 => true,
+        'object_operator_without_whitespace'          => true,
+        'single_blank_line_before_namespace'          => true,
+        'single_class_element_per_statement'          => true,
+        'space_after_semicolon'                       => true,
+        'standardize_not_equals'                      => true,
+        'ternary_operator_spaces'                     => true,
+        'trailing_comma_in_multiline_array'           => true,
+        'trim_array_spaces'                           => true,
+        'unary_operator_spaces'                       => true,
+        'whitespace_after_comma_in_array'             => true,
+        'no_extra_consecutive_blank_lines'            => [
+            'curly_brace_block',
+            'extra',
+            'parenthesis_brace_block',
+            'square_brace_block',
+            'throw',
+            'use',
+        ],
+        'binary_operator_spaces'       => [
+            'align_double_arrow' => true,
+            'align_equals'       => true,
+        ],
+        'braces'                                    => [
+            'allow_single_line_closure' => true,
+        ],
+    ])
+    ->setFinder(
+        PhpCsFixer\Finder::create()
+            ->exclude('vendor')
+            ->exclude('tests')
+            ->in(__DIR__)
+  );

+ 18 - 0
vendor/alibabacloud/sts-20150401/ChangeLog.md

@@ -0,0 +1,18 @@
+2022-03-26 Version: 1.1.1
+- Generated php 2015-04-01 for Sts.
+
+2021-09-29 Version: 1.1.0
+- Supported AssumeRoleWithOIDC.
+
+2021-07-27 Version: 1.0.1
+- Generated php 2015-04-01 for Sts.
+
+2020-12-30 Version: 1.0.0
+- AMP Version Change.
+
+2020-12-30 Version: 1.0.0
+- AMP Version Change.
+
+2020-12-30 Version: 1.0.0
+- AMP Version Change.
+

+ 201 - 0
vendor/alibabacloud/sts-20150401/LICENSE

@@ -0,0 +1,201 @@
+                                 Apache License
+                           Version 2.0, January 2004
+                        http://www.apache.org/licenses/
+
+   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+   1. Definitions.
+
+      "License" shall mean the terms and conditions for use, reproduction,
+      and distribution as defined by Sections 1 through 9 of this document.
+
+      "Licensor" shall mean the copyright owner or entity authorized by
+      the copyright owner that is granting the License.
+
+      "Legal Entity" shall mean the union of the acting entity and all
+      other entities that control, are controlled by, or are under common
+      control with that entity. For the purposes of this definition,
+      "control" means (i) the power, direct or indirect, to cause the
+      direction or management of such entity, whether by contract or
+      otherwise, or (ii) ownership of fifty percent (50%) or more of the
+      outstanding shares, or (iii) beneficial ownership of such entity.
+
+      "You" (or "Your") shall mean an individual or Legal Entity
+      exercising permissions granted by this License.
+
+      "Source" form shall mean the preferred form for making modifications,
+      including but not limited to software source code, documentation
+      source, and configuration files.
+
+      "Object" form shall mean any form resulting from mechanical
+      transformation or translation of a Source form, including but
+      not limited to compiled object code, generated documentation,
+      and conversions to other media types.
+
+      "Work" shall mean the work of authorship, whether in Source or
+      Object form, made available under the License, as indicated by a
+      copyright notice that is included in or attached to the work
+      (an example is provided in the Appendix below).
+
+      "Derivative Works" shall mean any work, whether in Source or Object
+      form, that is based on (or derived from) the Work and for which the
+      editorial revisions, annotations, elaborations, or other modifications
+      represent, as a whole, an original work of authorship. For the purposes
+      of this License, Derivative Works shall not include works that remain
+      separable from, or merely link (or bind by name) to the interfaces of,
+      the Work and Derivative Works thereof.
+
+      "Contribution" shall mean any work of authorship, including
+      the original version of the Work and any modifications or additions
+      to that Work or Derivative Works thereof, that is intentionally
+      submitted to Licensor for inclusion in the Work by the copyright owner
+      or by an individual or Legal Entity authorized to submit on behalf of
+      the copyright owner. For the purposes of this definition, "submitted"
+      means any form of electronic, verbal, or written communication sent
+      to the Licensor or its representatives, including but not limited to
+      communication on electronic mailing lists, source code control systems,
+      and issue tracking systems that are managed by, or on behalf of, the
+      Licensor for the purpose of discussing and improving the Work, but
+      excluding communication that is conspicuously marked or otherwise
+      designated in writing by the copyright owner as "Not a Contribution."
+
+      "Contributor" shall mean Licensor and any individual or Legal Entity
+      on behalf of whom a Contribution has been received by Licensor and
+      subsequently incorporated within the Work.
+
+   2. Grant of Copyright License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      copyright license to reproduce, prepare Derivative Works of,
+      publicly display, publicly perform, sublicense, and distribute the
+      Work and such Derivative Works in Source or Object form.
+
+   3. Grant of Patent License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      (except as stated in this section) patent license to make, have made,
+      use, offer to sell, sell, import, and otherwise transfer the Work,
+      where such license applies only to those patent claims licensable
+      by such Contributor that are necessarily infringed by their
+      Contribution(s) alone or by combination of their Contribution(s)
+      with the Work to which such Contribution(s) was submitted. If You
+      institute patent litigation against any entity (including a
+      cross-claim or counterclaim in a lawsuit) alleging that the Work
+      or a Contribution incorporated within the Work constitutes direct
+      or contributory patent infringement, then any patent licenses
+      granted to You under this License for that Work shall terminate
+      as of the date such litigation is filed.
+
+   4. Redistribution. You may reproduce and distribute copies of the
+      Work or Derivative Works thereof in any medium, with or without
+      modifications, and in Source or Object form, provided that You
+      meet the following conditions:
+
+      (a) You must give any other recipients of the Work or
+          Derivative Works a copy of this License; and
+
+      (b) You must cause any modified files to carry prominent notices
+          stating that You changed the files; and
+
+      (c) You must retain, in the Source form of any Derivative Works
+          that You distribute, all copyright, patent, trademark, and
+          attribution notices from the Source form of the Work,
+          excluding those notices that do not pertain to any part of
+          the Derivative Works; and
+
+      (d) If the Work includes a "NOTICE" text file as part of its
+          distribution, then any Derivative Works that You distribute must
+          include a readable copy of the attribution notices contained
+          within such NOTICE file, excluding those notices that do not
+          pertain to any part of the Derivative Works, in at least one
+          of the following places: within a NOTICE text file distributed
+          as part of the Derivative Works; within the Source form or
+          documentation, if provided along with the Derivative Works; or,
+          within a display generated by the Derivative Works, if and
+          wherever such third-party notices normally appear. The contents
+          of the NOTICE file are for informational purposes only and
+          do not modify the License. You may add Your own attribution
+          notices within Derivative Works that You distribute, alongside
+          or as an addendum to the NOTICE text from the Work, provided
+          that such additional attribution notices cannot be construed
+          as modifying the License.
+
+      You may add Your own copyright statement to Your modifications and
+      may provide additional or different license terms and conditions
+      for use, reproduction, or distribution of Your modifications, or
+      for any such Derivative Works as a whole, provided Your use,
+      reproduction, and distribution of the Work otherwise complies with
+      the conditions stated in this License.
+
+   5. Submission of Contributions. Unless You explicitly state otherwise,
+      any Contribution intentionally submitted for inclusion in the Work
+      by You to the Licensor shall be under the terms and conditions of
+      this License, without any additional terms or conditions.
+      Notwithstanding the above, nothing herein shall supersede or modify
+      the terms of any separate license agreement you may have executed
+      with Licensor regarding such Contributions.
+
+   6. Trademarks. This License does not grant permission to use the trade
+      names, trademarks, service marks, or product names of the Licensor,
+      except as required for reasonable and customary use in describing the
+      origin of the Work and reproducing the content of the NOTICE file.
+
+   7. Disclaimer of Warranty. Unless required by applicable law or
+      agreed to in writing, Licensor provides the Work (and each
+      Contributor provides its Contributions) on an "AS IS" BASIS,
+      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+      implied, including, without limitation, any warranties or conditions
+      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+      PARTICULAR PURPOSE. You are solely responsible for determining the
+      appropriateness of using or redistributing the Work and assume any
+      risks associated with Your exercise of permissions under this License.
+
+   8. Limitation of Liability. In no event and under no legal theory,
+      whether in tort (including negligence), contract, or otherwise,
+      unless required by applicable law (such as deliberate and grossly
+      negligent acts) or agreed to in writing, shall any Contributor be
+      liable to You for damages, including any direct, indirect, special,
+      incidental, or consequential damages of any character arising as a
+      result of this License or out of the use or inability to use the
+      Work (including but not limited to damages for loss of goodwill,
+      work stoppage, computer failure or malfunction, or any and all
+      other commercial damages or losses), even if such Contributor
+      has been advised of the possibility of such damages.
+
+   9. Accepting Warranty or Additional Liability. While redistributing
+      the Work or Derivative Works thereof, You may choose to offer,
+      and charge a fee for, acceptance of support, warranty, indemnity,
+      or other liability obligations and/or rights consistent with this
+      License. However, in accepting such obligations, You may act only
+      on Your own behalf and on Your sole responsibility, not on behalf
+      of any other Contributor, and only if You agree to indemnify,
+      defend, and hold each Contributor harmless for any liability
+      incurred by, or claims asserted against, such Contributor by reason
+      of your accepting any such warranty or additional liability.
+
+   END OF TERMS AND CONDITIONS
+
+   APPENDIX: How to apply the Apache License to your work.
+
+      To apply the Apache License to your work, attach the following
+      boilerplate notice, with the fields enclosed by brackets "[]"
+      replaced with your own identifying information. (Don't include
+      the brackets!)  The text should be enclosed in the appropriate
+      comment syntax for the file format. We also recommend that a
+      file or class name and description of purpose be included on the
+      same "printed page" as the copyright notice for easier
+      identification within third-party archives.
+
+   Copyright (c) 2009-present, Alibaba Cloud 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.
+   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.

+ 35 - 0
vendor/alibabacloud/sts-20150401/README-CN.md

@@ -0,0 +1,35 @@
+[English](README.md) | 简体中文
+
+![](https://aliyunsdk-pages.alicdn.com/icons/AlibabaCloud.svg)
+
+# Alibaba Cloud Sts SDK for PHP
+
+## 安装
+
+### Composer
+
+```bash
+composer require alibabacloud/sts-20150401
+```
+
+## 问题
+
+[提交 Issue](https://github.com/aliyun/alibabacloud-php-sdk/issues/new),不符合指南的问题可能会立即关闭。
+
+## 使用说明
+
+[快速使用](https://github.com/aliyun/alibabacloud-php-sdk/blob/master/docs/0-Examples-CN.md#%E5%BF%AB%E9%80%9F%E4%BD%BF%E7%94%A8)
+
+## 发行说明
+
+每个版本的详细更改记录在[发行说明](./ChangeLog.txt)中。
+
+## 相关
+
+* [最新源码](https://github.com/aliyun/alibabacloud-php-sdk/)
+
+## 许可证
+
+[Apache-2.0](http://www.apache.org/licenses/LICENSE-2.0)
+
+Copyright (c) 2009-present, Alibaba Cloud All rights reserved.

+ 35 - 0
vendor/alibabacloud/sts-20150401/README.md

@@ -0,0 +1,35 @@
+English | [简体中文](README-CN.md)
+
+![](https://aliyunsdk-pages.alicdn.com/icons/AlibabaCloud.svg)
+
+# Alibaba Cloud Sts SDK for PHP
+
+## Installation
+
+### Composer
+
+```bash
+composer require alibabacloud/sts-20150401
+```
+
+## Issues
+
+[Opening an Issue](https://github.com/aliyun/alibabacloud-php-sdk/issues/new), Issues not conforming to the guidelines may be closed immediately.
+
+## Usage
+
+[Quick Examples](https://github.com/aliyun/alibabacloud-php-sdk/blob/master/docs/0-Examples-EN.md#quick-examples)
+
+## Changelog
+
+Detailed changes for each release are documented in the [release notes](./ChangeLog.txt).
+
+## References
+
+* [Latest Release](https://github.com/aliyun/alibabacloud-php-sdk/)
+
+## License
+
+[Apache-2.0](http://www.apache.org/licenses/LICENSE-2.0)
+
+Copyright (c) 2009-present, Alibaba Cloud All rights reserved.

+ 17 - 0
vendor/alibabacloud/sts-20150401/autoload.php

@@ -0,0 +1,17 @@
+<?php
+
+if (file_exists(__DIR__ . \DIRECTORY_SEPARATOR . 'vendor' . \DIRECTORY_SEPARATOR . 'autoload.php')) {
+    require_once __DIR__ . \DIRECTORY_SEPARATOR . 'vendor' . \DIRECTORY_SEPARATOR . 'autoload.php';
+}
+
+spl_autoload_register(function ($class) {
+    $name = str_replace('AlibabaCloud\\SDK\\Sts\\V20150401\\', '', $class);
+    $file = __DIR__ . \DIRECTORY_SEPARATOR . 'src' . \DIRECTORY_SEPARATOR . str_replace('\\', \DIRECTORY_SEPARATOR, $name) . '.php';
+    if (file_exists($file)) {
+        require_once $file;
+
+        return true;
+    }
+
+    return false;
+});

+ 33 - 0
vendor/alibabacloud/sts-20150401/composer.json

@@ -0,0 +1,33 @@
+{
+  "name": "alibabacloud/sts-20150401",
+  "description": "Alibaba Cloud Sts (20150401) SDK Library for PHP",
+  "type": "library",
+  "license": "Apache-2.0",
+  "authors": [
+    {
+      "name": "Alibaba Cloud SDK",
+      "email": "sdk-team@alibabacloud.com"
+    }
+  ],
+  "require": {
+    "php": ">5.5",
+    "alibabacloud/tea-utils": "^0.2.0",
+    "alibabacloud/darabonba-openapi": "^0.2.5",
+    "alibabacloud/openapi-util": "^0.1.10",
+    "alibabacloud/endpoint-util": "^0.1.0"
+  },
+  "autoload": {
+    "psr-4": {
+      "AlibabaCloud\\SDK\\Sts\\V20150401\\": "src"
+    }
+  },
+  "scripts": {
+    "fixer": "php-cs-fixer fix ./"
+  },
+  "config": {
+    "sort-packages": true,
+    "preferred-install": "dist",
+    "optimize-autoloader": true
+  },
+  "prefer-stable": true
+}

+ 83 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleRequest.php

@@ -0,0 +1,83 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models;
+
+use AlibabaCloud\Tea\Model;
+
+class AssumeRoleRequest extends Model
+{
+    /**
+     * @var int
+     */
+    public $durationSeconds;
+
+    /**
+     * @var string
+     */
+    public $policy;
+
+    /**
+     * @var string
+     */
+    public $roleArn;
+
+    /**
+     * @var string
+     */
+    public $roleSessionName;
+    protected $_name = [
+        'durationSeconds' => 'DurationSeconds',
+        'policy'          => 'Policy',
+        'roleArn'         => 'RoleArn',
+        'roleSessionName' => 'RoleSessionName',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->durationSeconds) {
+            $res['DurationSeconds'] = $this->durationSeconds;
+        }
+        if (null !== $this->policy) {
+            $res['Policy'] = $this->policy;
+        }
+        if (null !== $this->roleArn) {
+            $res['RoleArn'] = $this->roleArn;
+        }
+        if (null !== $this->roleSessionName) {
+            $res['RoleSessionName'] = $this->roleSessionName;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return AssumeRoleRequest
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['DurationSeconds'])) {
+            $model->durationSeconds = $map['DurationSeconds'];
+        }
+        if (isset($map['Policy'])) {
+            $model->policy = $map['Policy'];
+        }
+        if (isset($map['RoleArn'])) {
+            $model->roleArn = $map['RoleArn'];
+        }
+        if (isset($map['RoleSessionName'])) {
+            $model->roleSessionName = $map['RoleSessionName'];
+        }
+
+        return $model;
+    }
+}

+ 61 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleResponse.php

@@ -0,0 +1,61 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models;
+
+use AlibabaCloud\Tea\Model;
+
+class AssumeRoleResponse extends Model
+{
+    /**
+     * @var string[]
+     */
+    public $headers;
+
+    /**
+     * @var AssumeRoleResponseBody
+     */
+    public $body;
+    protected $_name = [
+        'headers' => 'headers',
+        'body'    => 'body',
+    ];
+
+    public function validate()
+    {
+        Model::validateRequired('headers', $this->headers, true);
+        Model::validateRequired('body', $this->body, true);
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->headers) {
+            $res['headers'] = $this->headers;
+        }
+        if (null !== $this->body) {
+            $res['body'] = null !== $this->body ? $this->body->toMap() : null;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return AssumeRoleResponse
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['headers'])) {
+            $model->headers = $map['headers'];
+        }
+        if (isset($map['body'])) {
+            $model->body = AssumeRoleResponseBody::fromMap($map['body']);
+        }
+
+        return $model;
+    }
+}

+ 73 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleResponseBody.php

@@ -0,0 +1,73 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models;
+
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleResponseBody\assumedRoleUser;
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleResponseBody\credentials;
+use AlibabaCloud\Tea\Model;
+
+class AssumeRoleResponseBody extends Model
+{
+    /**
+     * @var assumedRoleUser
+     */
+    public $assumedRoleUser;
+
+    /**
+     * @var credentials
+     */
+    public $credentials;
+
+    /**
+     * @var string
+     */
+    public $requestId;
+    protected $_name = [
+        'assumedRoleUser' => 'AssumedRoleUser',
+        'credentials'     => 'Credentials',
+        'requestId'       => 'RequestId',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->assumedRoleUser) {
+            $res['AssumedRoleUser'] = null !== $this->assumedRoleUser ? $this->assumedRoleUser->toMap() : null;
+        }
+        if (null !== $this->credentials) {
+            $res['Credentials'] = null !== $this->credentials ? $this->credentials->toMap() : null;
+        }
+        if (null !== $this->requestId) {
+            $res['RequestId'] = $this->requestId;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return AssumeRoleResponseBody
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['AssumedRoleUser'])) {
+            $model->assumedRoleUser = assumedRoleUser::fromMap($map['AssumedRoleUser']);
+        }
+        if (isset($map['Credentials'])) {
+            $model->credentials = credentials::fromMap($map['Credentials']);
+        }
+        if (isset($map['RequestId'])) {
+            $model->requestId = $map['RequestId'];
+        }
+
+        return $model;
+    }
+}

+ 59 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleResponseBody/assumedRoleUser.php

@@ -0,0 +1,59 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleResponseBody;
+
+use AlibabaCloud\Tea\Model;
+
+class assumedRoleUser extends Model
+{
+    /**
+     * @var string
+     */
+    public $arn;
+
+    /**
+     * @var string
+     */
+    public $assumedRoleId;
+    protected $_name = [
+        'arn'           => 'Arn',
+        'assumedRoleId' => 'AssumedRoleId',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->arn) {
+            $res['Arn'] = $this->arn;
+        }
+        if (null !== $this->assumedRoleId) {
+            $res['AssumedRoleId'] = $this->assumedRoleId;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return assumedRoleUser
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['Arn'])) {
+            $model->arn = $map['Arn'];
+        }
+        if (isset($map['AssumedRoleId'])) {
+            $model->assumedRoleId = $map['AssumedRoleId'];
+        }
+
+        return $model;
+    }
+}

+ 83 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleResponseBody/credentials.php

@@ -0,0 +1,83 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleResponseBody;
+
+use AlibabaCloud\Tea\Model;
+
+class credentials extends Model
+{
+    /**
+     * @var string
+     */
+    public $accessKeyId;
+
+    /**
+     * @var string
+     */
+    public $accessKeySecret;
+
+    /**
+     * @var string
+     */
+    public $expiration;
+
+    /**
+     * @var string
+     */
+    public $securityToken;
+    protected $_name = [
+        'accessKeyId'     => 'AccessKeyId',
+        'accessKeySecret' => 'AccessKeySecret',
+        'expiration'      => 'Expiration',
+        'securityToken'   => 'SecurityToken',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->accessKeyId) {
+            $res['AccessKeyId'] = $this->accessKeyId;
+        }
+        if (null !== $this->accessKeySecret) {
+            $res['AccessKeySecret'] = $this->accessKeySecret;
+        }
+        if (null !== $this->expiration) {
+            $res['Expiration'] = $this->expiration;
+        }
+        if (null !== $this->securityToken) {
+            $res['SecurityToken'] = $this->securityToken;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return credentials
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['AccessKeyId'])) {
+            $model->accessKeyId = $map['AccessKeyId'];
+        }
+        if (isset($map['AccessKeySecret'])) {
+            $model->accessKeySecret = $map['AccessKeySecret'];
+        }
+        if (isset($map['Expiration'])) {
+            $model->expiration = $map['Expiration'];
+        }
+        if (isset($map['SecurityToken'])) {
+            $model->securityToken = $map['SecurityToken'];
+        }
+
+        return $model;
+    }
+}

+ 119 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCRequest.php

@@ -0,0 +1,119 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models;
+
+use AlibabaCloud\Tea\Model;
+
+class AssumeRoleWithOIDCRequest extends Model
+{
+    /**
+     * @description Session过期时间,单位为秒。
+     *
+     * @var int
+     */
+    public $durationSeconds;
+
+    /**
+     * @description OIDC Provider的ARN
+     *
+     * @var string
+     */
+    public $OIDCProviderArn;
+
+    /**
+     * @description OIDC的ID Token,需输入原始Token,无需Base64解码
+     *
+     * @var string
+     */
+    public $OIDCToken;
+
+    /**
+     * @description 权限策略。 生成STS Token时可以指定一个额外的权限策略,以进一步限制STS Token的权限。若不指定则返回的Token拥有指定角色的所有权限。
+     *
+     * @var string
+     */
+    public $policy;
+
+    /**
+     * @description 需要扮演的角色的ARN
+     *
+     * @var string
+     */
+    public $roleArn;
+
+    /**
+     * @description 用户自定义参数。此参数用来区分不同的令牌,可用于用户级别的访问审计。
+     *
+     * @var string
+     */
+    public $roleSessionName;
+    protected $_name = [
+        'durationSeconds' => 'DurationSeconds',
+        'OIDCProviderArn' => 'OIDCProviderArn',
+        'OIDCToken'       => 'OIDCToken',
+        'policy'          => 'Policy',
+        'roleArn'         => 'RoleArn',
+        'roleSessionName' => 'RoleSessionName',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->durationSeconds) {
+            $res['DurationSeconds'] = $this->durationSeconds;
+        }
+        if (null !== $this->OIDCProviderArn) {
+            $res['OIDCProviderArn'] = $this->OIDCProviderArn;
+        }
+        if (null !== $this->OIDCToken) {
+            $res['OIDCToken'] = $this->OIDCToken;
+        }
+        if (null !== $this->policy) {
+            $res['Policy'] = $this->policy;
+        }
+        if (null !== $this->roleArn) {
+            $res['RoleArn'] = $this->roleArn;
+        }
+        if (null !== $this->roleSessionName) {
+            $res['RoleSessionName'] = $this->roleSessionName;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return AssumeRoleWithOIDCRequest
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['DurationSeconds'])) {
+            $model->durationSeconds = $map['DurationSeconds'];
+        }
+        if (isset($map['OIDCProviderArn'])) {
+            $model->OIDCProviderArn = $map['OIDCProviderArn'];
+        }
+        if (isset($map['OIDCToken'])) {
+            $model->OIDCToken = $map['OIDCToken'];
+        }
+        if (isset($map['Policy'])) {
+            $model->policy = $map['Policy'];
+        }
+        if (isset($map['RoleArn'])) {
+            $model->roleArn = $map['RoleArn'];
+        }
+        if (isset($map['RoleSessionName'])) {
+            $model->roleSessionName = $map['RoleSessionName'];
+        }
+
+        return $model;
+    }
+}

+ 61 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponse.php

@@ -0,0 +1,61 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models;
+
+use AlibabaCloud\Tea\Model;
+
+class AssumeRoleWithOIDCResponse extends Model
+{
+    /**
+     * @var string[]
+     */
+    public $headers;
+
+    /**
+     * @var AssumeRoleWithOIDCResponseBody
+     */
+    public $body;
+    protected $_name = [
+        'headers' => 'headers',
+        'body'    => 'body',
+    ];
+
+    public function validate()
+    {
+        Model::validateRequired('headers', $this->headers, true);
+        Model::validateRequired('body', $this->body, true);
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->headers) {
+            $res['headers'] = $this->headers;
+        }
+        if (null !== $this->body) {
+            $res['body'] = null !== $this->body ? $this->body->toMap() : null;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return AssumeRoleWithOIDCResponse
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['headers'])) {
+            $model->headers = $map['headers'];
+        }
+        if (isset($map['body'])) {
+            $model->body = AssumeRoleWithOIDCResponseBody::fromMap($map['body']);
+        }
+
+        return $model;
+    }
+}

+ 86 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponseBody.php

@@ -0,0 +1,86 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models;
+
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithOIDCResponseBody\assumedRoleUser;
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithOIDCResponseBody\credentials;
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithOIDCResponseBody\OIDCTokenInfo;
+use AlibabaCloud\Tea\Model;
+
+class AssumeRoleWithOIDCResponseBody extends Model
+{
+    /**
+     * @var assumedRoleUser
+     */
+    public $assumedRoleUser;
+
+    /**
+     * @var credentials
+     */
+    public $credentials;
+
+    /**
+     * @var OIDCTokenInfo
+     */
+    public $OIDCTokenInfo;
+
+    /**
+     * @var string
+     */
+    public $requestId;
+    protected $_name = [
+        'assumedRoleUser' => 'AssumedRoleUser',
+        'credentials'     => 'Credentials',
+        'OIDCTokenInfo'   => 'OIDCTokenInfo',
+        'requestId'       => 'RequestId',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->assumedRoleUser) {
+            $res['AssumedRoleUser'] = null !== $this->assumedRoleUser ? $this->assumedRoleUser->toMap() : null;
+        }
+        if (null !== $this->credentials) {
+            $res['Credentials'] = null !== $this->credentials ? $this->credentials->toMap() : null;
+        }
+        if (null !== $this->OIDCTokenInfo) {
+            $res['OIDCTokenInfo'] = null !== $this->OIDCTokenInfo ? $this->OIDCTokenInfo->toMap() : null;
+        }
+        if (null !== $this->requestId) {
+            $res['RequestId'] = $this->requestId;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return AssumeRoleWithOIDCResponseBody
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['AssumedRoleUser'])) {
+            $model->assumedRoleUser = assumedRoleUser::fromMap($map['AssumedRoleUser']);
+        }
+        if (isset($map['Credentials'])) {
+            $model->credentials = credentials::fromMap($map['Credentials']);
+        }
+        if (isset($map['OIDCTokenInfo'])) {
+            $model->OIDCTokenInfo = OIDCTokenInfo::fromMap($map['OIDCTokenInfo']);
+        }
+        if (isset($map['RequestId'])) {
+            $model->requestId = $map['RequestId'];
+        }
+
+        return $model;
+    }
+}

+ 71 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponseBody/OIDCTokenInfo.php

@@ -0,0 +1,71 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithOIDCResponseBody;
+
+use AlibabaCloud\Tea\Model;
+
+class OIDCTokenInfo extends Model
+{
+    /**
+     * @var string
+     */
+    public $clientIds;
+
+    /**
+     * @var string
+     */
+    public $issuer;
+
+    /**
+     * @var string
+     */
+    public $subject;
+    protected $_name = [
+        'clientIds' => 'ClientIds',
+        'issuer'    => 'Issuer',
+        'subject'   => 'Subject',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->clientIds) {
+            $res['ClientIds'] = $this->clientIds;
+        }
+        if (null !== $this->issuer) {
+            $res['Issuer'] = $this->issuer;
+        }
+        if (null !== $this->subject) {
+            $res['Subject'] = $this->subject;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return OIDCTokenInfo
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['ClientIds'])) {
+            $model->clientIds = $map['ClientIds'];
+        }
+        if (isset($map['Issuer'])) {
+            $model->issuer = $map['Issuer'];
+        }
+        if (isset($map['Subject'])) {
+            $model->subject = $map['Subject'];
+        }
+
+        return $model;
+    }
+}

+ 59 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponseBody/assumedRoleUser.php

@@ -0,0 +1,59 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithOIDCResponseBody;
+
+use AlibabaCloud\Tea\Model;
+
+class assumedRoleUser extends Model
+{
+    /**
+     * @var string
+     */
+    public $arn;
+
+    /**
+     * @var string
+     */
+    public $assumedRoleId;
+    protected $_name = [
+        'arn'           => 'Arn',
+        'assumedRoleId' => 'AssumedRoleId',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->arn) {
+            $res['Arn'] = $this->arn;
+        }
+        if (null !== $this->assumedRoleId) {
+            $res['AssumedRoleId'] = $this->assumedRoleId;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return assumedRoleUser
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['Arn'])) {
+            $model->arn = $map['Arn'];
+        }
+        if (isset($map['AssumedRoleId'])) {
+            $model->assumedRoleId = $map['AssumedRoleId'];
+        }
+
+        return $model;
+    }
+}

+ 83 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithOIDCResponseBody/credentials.php

@@ -0,0 +1,83 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithOIDCResponseBody;
+
+use AlibabaCloud\Tea\Model;
+
+class credentials extends Model
+{
+    /**
+     * @var string
+     */
+    public $accessKeyId;
+
+    /**
+     * @var string
+     */
+    public $accessKeySecret;
+
+    /**
+     * @var string
+     */
+    public $expiration;
+
+    /**
+     * @var string
+     */
+    public $securityToken;
+    protected $_name = [
+        'accessKeyId'     => 'AccessKeyId',
+        'accessKeySecret' => 'AccessKeySecret',
+        'expiration'      => 'Expiration',
+        'securityToken'   => 'SecurityToken',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->accessKeyId) {
+            $res['AccessKeyId'] = $this->accessKeyId;
+        }
+        if (null !== $this->accessKeySecret) {
+            $res['AccessKeySecret'] = $this->accessKeySecret;
+        }
+        if (null !== $this->expiration) {
+            $res['Expiration'] = $this->expiration;
+        }
+        if (null !== $this->securityToken) {
+            $res['SecurityToken'] = $this->securityToken;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return credentials
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['AccessKeyId'])) {
+            $model->accessKeyId = $map['AccessKeyId'];
+        }
+        if (isset($map['AccessKeySecret'])) {
+            $model->accessKeySecret = $map['AccessKeySecret'];
+        }
+        if (isset($map['Expiration'])) {
+            $model->expiration = $map['Expiration'];
+        }
+        if (isset($map['SecurityToken'])) {
+            $model->securityToken = $map['SecurityToken'];
+        }
+
+        return $model;
+    }
+}

+ 95 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLRequest.php

@@ -0,0 +1,95 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models;
+
+use AlibabaCloud\Tea\Model;
+
+class AssumeRoleWithSAMLRequest extends Model
+{
+    /**
+     * @var int
+     */
+    public $durationSeconds;
+
+    /**
+     * @var string
+     */
+    public $policy;
+
+    /**
+     * @var string
+     */
+    public $roleArn;
+
+    /**
+     * @var string
+     */
+    public $SAMLAssertion;
+
+    /**
+     * @var string
+     */
+    public $SAMLProviderArn;
+    protected $_name = [
+        'durationSeconds' => 'DurationSeconds',
+        'policy'          => 'Policy',
+        'roleArn'         => 'RoleArn',
+        'SAMLAssertion'   => 'SAMLAssertion',
+        'SAMLProviderArn' => 'SAMLProviderArn',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->durationSeconds) {
+            $res['DurationSeconds'] = $this->durationSeconds;
+        }
+        if (null !== $this->policy) {
+            $res['Policy'] = $this->policy;
+        }
+        if (null !== $this->roleArn) {
+            $res['RoleArn'] = $this->roleArn;
+        }
+        if (null !== $this->SAMLAssertion) {
+            $res['SAMLAssertion'] = $this->SAMLAssertion;
+        }
+        if (null !== $this->SAMLProviderArn) {
+            $res['SAMLProviderArn'] = $this->SAMLProviderArn;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return AssumeRoleWithSAMLRequest
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['DurationSeconds'])) {
+            $model->durationSeconds = $map['DurationSeconds'];
+        }
+        if (isset($map['Policy'])) {
+            $model->policy = $map['Policy'];
+        }
+        if (isset($map['RoleArn'])) {
+            $model->roleArn = $map['RoleArn'];
+        }
+        if (isset($map['SAMLAssertion'])) {
+            $model->SAMLAssertion = $map['SAMLAssertion'];
+        }
+        if (isset($map['SAMLProviderArn'])) {
+            $model->SAMLProviderArn = $map['SAMLProviderArn'];
+        }
+
+        return $model;
+    }
+}

+ 61 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponse.php

@@ -0,0 +1,61 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models;
+
+use AlibabaCloud\Tea\Model;
+
+class AssumeRoleWithSAMLResponse extends Model
+{
+    /**
+     * @var string[]
+     */
+    public $headers;
+
+    /**
+     * @var AssumeRoleWithSAMLResponseBody
+     */
+    public $body;
+    protected $_name = [
+        'headers' => 'headers',
+        'body'    => 'body',
+    ];
+
+    public function validate()
+    {
+        Model::validateRequired('headers', $this->headers, true);
+        Model::validateRequired('body', $this->body, true);
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->headers) {
+            $res['headers'] = $this->headers;
+        }
+        if (null !== $this->body) {
+            $res['body'] = null !== $this->body ? $this->body->toMap() : null;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return AssumeRoleWithSAMLResponse
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['headers'])) {
+            $model->headers = $map['headers'];
+        }
+        if (isset($map['body'])) {
+            $model->body = AssumeRoleWithSAMLResponseBody::fromMap($map['body']);
+        }
+
+        return $model;
+    }
+}

+ 86 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponseBody.php

@@ -0,0 +1,86 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models;
+
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithSAMLResponseBody\assumedRoleUser;
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithSAMLResponseBody\credentials;
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithSAMLResponseBody\SAMLAssertionInfo;
+use AlibabaCloud\Tea\Model;
+
+class AssumeRoleWithSAMLResponseBody extends Model
+{
+    /**
+     * @var assumedRoleUser
+     */
+    public $assumedRoleUser;
+
+    /**
+     * @var credentials
+     */
+    public $credentials;
+
+    /**
+     * @var string
+     */
+    public $requestId;
+
+    /**
+     * @var SAMLAssertionInfo
+     */
+    public $SAMLAssertionInfo;
+    protected $_name = [
+        'assumedRoleUser'   => 'AssumedRoleUser',
+        'credentials'       => 'Credentials',
+        'requestId'         => 'RequestId',
+        'SAMLAssertionInfo' => 'SAMLAssertionInfo',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->assumedRoleUser) {
+            $res['AssumedRoleUser'] = null !== $this->assumedRoleUser ? $this->assumedRoleUser->toMap() : null;
+        }
+        if (null !== $this->credentials) {
+            $res['Credentials'] = null !== $this->credentials ? $this->credentials->toMap() : null;
+        }
+        if (null !== $this->requestId) {
+            $res['RequestId'] = $this->requestId;
+        }
+        if (null !== $this->SAMLAssertionInfo) {
+            $res['SAMLAssertionInfo'] = null !== $this->SAMLAssertionInfo ? $this->SAMLAssertionInfo->toMap() : null;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return AssumeRoleWithSAMLResponseBody
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['AssumedRoleUser'])) {
+            $model->assumedRoleUser = assumedRoleUser::fromMap($map['AssumedRoleUser']);
+        }
+        if (isset($map['Credentials'])) {
+            $model->credentials = credentials::fromMap($map['Credentials']);
+        }
+        if (isset($map['RequestId'])) {
+            $model->requestId = $map['RequestId'];
+        }
+        if (isset($map['SAMLAssertionInfo'])) {
+            $model->SAMLAssertionInfo = SAMLAssertionInfo::fromMap($map['SAMLAssertionInfo']);
+        }
+
+        return $model;
+    }
+}

+ 83 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponseBody/SAMLAssertionInfo.php

@@ -0,0 +1,83 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithSAMLResponseBody;
+
+use AlibabaCloud\Tea\Model;
+
+class SAMLAssertionInfo extends Model
+{
+    /**
+     * @var string
+     */
+    public $issuer;
+
+    /**
+     * @var string
+     */
+    public $recipient;
+
+    /**
+     * @var string
+     */
+    public $subject;
+
+    /**
+     * @var string
+     */
+    public $subjectType;
+    protected $_name = [
+        'issuer'      => 'Issuer',
+        'recipient'   => 'Recipient',
+        'subject'     => 'Subject',
+        'subjectType' => 'SubjectType',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->issuer) {
+            $res['Issuer'] = $this->issuer;
+        }
+        if (null !== $this->recipient) {
+            $res['Recipient'] = $this->recipient;
+        }
+        if (null !== $this->subject) {
+            $res['Subject'] = $this->subject;
+        }
+        if (null !== $this->subjectType) {
+            $res['SubjectType'] = $this->subjectType;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return SAMLAssertionInfo
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['Issuer'])) {
+            $model->issuer = $map['Issuer'];
+        }
+        if (isset($map['Recipient'])) {
+            $model->recipient = $map['Recipient'];
+        }
+        if (isset($map['Subject'])) {
+            $model->subject = $map['Subject'];
+        }
+        if (isset($map['SubjectType'])) {
+            $model->subjectType = $map['SubjectType'];
+        }
+
+        return $model;
+    }
+}

+ 59 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponseBody/assumedRoleUser.php

@@ -0,0 +1,59 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithSAMLResponseBody;
+
+use AlibabaCloud\Tea\Model;
+
+class assumedRoleUser extends Model
+{
+    /**
+     * @var string
+     */
+    public $arn;
+
+    /**
+     * @var string
+     */
+    public $assumedRoleId;
+    protected $_name = [
+        'arn'           => 'Arn',
+        'assumedRoleId' => 'AssumedRoleId',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->arn) {
+            $res['Arn'] = $this->arn;
+        }
+        if (null !== $this->assumedRoleId) {
+            $res['AssumedRoleId'] = $this->assumedRoleId;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return assumedRoleUser
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['Arn'])) {
+            $model->arn = $map['Arn'];
+        }
+        if (isset($map['AssumedRoleId'])) {
+            $model->assumedRoleId = $map['AssumedRoleId'];
+        }
+
+        return $model;
+    }
+}

+ 83 - 0
vendor/alibabacloud/sts-20150401/src/Models/AssumeRoleWithSAMLResponseBody/credentials.php

@@ -0,0 +1,83 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithSAMLResponseBody;
+
+use AlibabaCloud\Tea\Model;
+
+class credentials extends Model
+{
+    /**
+     * @var string
+     */
+    public $accessKeyId;
+
+    /**
+     * @var string
+     */
+    public $accessKeySecret;
+
+    /**
+     * @var string
+     */
+    public $expiration;
+
+    /**
+     * @var string
+     */
+    public $securityToken;
+    protected $_name = [
+        'accessKeyId'     => 'AccessKeyId',
+        'accessKeySecret' => 'AccessKeySecret',
+        'expiration'      => 'Expiration',
+        'securityToken'   => 'SecurityToken',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->accessKeyId) {
+            $res['AccessKeyId'] = $this->accessKeyId;
+        }
+        if (null !== $this->accessKeySecret) {
+            $res['AccessKeySecret'] = $this->accessKeySecret;
+        }
+        if (null !== $this->expiration) {
+            $res['Expiration'] = $this->expiration;
+        }
+        if (null !== $this->securityToken) {
+            $res['SecurityToken'] = $this->securityToken;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return credentials
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['AccessKeyId'])) {
+            $model->accessKeyId = $map['AccessKeyId'];
+        }
+        if (isset($map['AccessKeySecret'])) {
+            $model->accessKeySecret = $map['AccessKeySecret'];
+        }
+        if (isset($map['Expiration'])) {
+            $model->expiration = $map['Expiration'];
+        }
+        if (isset($map['SecurityToken'])) {
+            $model->securityToken = $map['SecurityToken'];
+        }
+
+        return $model;
+    }
+}

+ 61 - 0
vendor/alibabacloud/sts-20150401/src/Models/GetCallerIdentityResponse.php

@@ -0,0 +1,61 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models;
+
+use AlibabaCloud\Tea\Model;
+
+class GetCallerIdentityResponse extends Model
+{
+    /**
+     * @var string[]
+     */
+    public $headers;
+
+    /**
+     * @var GetCallerIdentityResponseBody
+     */
+    public $body;
+    protected $_name = [
+        'headers' => 'headers',
+        'body'    => 'body',
+    ];
+
+    public function validate()
+    {
+        Model::validateRequired('headers', $this->headers, true);
+        Model::validateRequired('body', $this->body, true);
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->headers) {
+            $res['headers'] = $this->headers;
+        }
+        if (null !== $this->body) {
+            $res['body'] = null !== $this->body ? $this->body->toMap() : null;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return GetCallerIdentityResponse
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['headers'])) {
+            $model->headers = $map['headers'];
+        }
+        if (isset($map['body'])) {
+            $model->body = GetCallerIdentityResponseBody::fromMap($map['body']);
+        }
+
+        return $model;
+    }
+}

+ 119 - 0
vendor/alibabacloud/sts-20150401/src/Models/GetCallerIdentityResponseBody.php

@@ -0,0 +1,119 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401\Models;
+
+use AlibabaCloud\Tea\Model;
+
+class GetCallerIdentityResponseBody extends Model
+{
+    /**
+     * @var string
+     */
+    public $accountId;
+
+    /**
+     * @var string
+     */
+    public $arn;
+
+    /**
+     * @var string
+     */
+    public $identityType;
+
+    /**
+     * @var string
+     */
+    public $principalId;
+
+    /**
+     * @var string
+     */
+    public $requestId;
+
+    /**
+     * @var string
+     */
+    public $roleId;
+
+    /**
+     * @var string
+     */
+    public $userId;
+    protected $_name = [
+        'accountId'    => 'AccountId',
+        'arn'          => 'Arn',
+        'identityType' => 'IdentityType',
+        'principalId'  => 'PrincipalId',
+        'requestId'    => 'RequestId',
+        'roleId'       => 'RoleId',
+        'userId'       => 'UserId',
+    ];
+
+    public function validate()
+    {
+    }
+
+    public function toMap()
+    {
+        $res = [];
+        if (null !== $this->accountId) {
+            $res['AccountId'] = $this->accountId;
+        }
+        if (null !== $this->arn) {
+            $res['Arn'] = $this->arn;
+        }
+        if (null !== $this->identityType) {
+            $res['IdentityType'] = $this->identityType;
+        }
+        if (null !== $this->principalId) {
+            $res['PrincipalId'] = $this->principalId;
+        }
+        if (null !== $this->requestId) {
+            $res['RequestId'] = $this->requestId;
+        }
+        if (null !== $this->roleId) {
+            $res['RoleId'] = $this->roleId;
+        }
+        if (null !== $this->userId) {
+            $res['UserId'] = $this->userId;
+        }
+
+        return $res;
+    }
+
+    /**
+     * @param array $map
+     *
+     * @return GetCallerIdentityResponseBody
+     */
+    public static function fromMap($map = [])
+    {
+        $model = new self();
+        if (isset($map['AccountId'])) {
+            $model->accountId = $map['AccountId'];
+        }
+        if (isset($map['Arn'])) {
+            $model->arn = $map['Arn'];
+        }
+        if (isset($map['IdentityType'])) {
+            $model->identityType = $map['IdentityType'];
+        }
+        if (isset($map['PrincipalId'])) {
+            $model->principalId = $map['PrincipalId'];
+        }
+        if (isset($map['RequestId'])) {
+            $model->requestId = $map['RequestId'];
+        }
+        if (isset($map['RoleId'])) {
+            $model->roleId = $map['RoleId'];
+        }
+        if (isset($map['UserId'])) {
+            $model->userId = $map['UserId'];
+        }
+
+        return $model;
+    }
+}

+ 289 - 0
vendor/alibabacloud/sts-20150401/src/Sts.php

@@ -0,0 +1,289 @@
+<?php
+
+// This file is auto-generated, don't edit it. Thanks.
+
+namespace AlibabaCloud\SDK\Sts\V20150401;
+
+use AlibabaCloud\Endpoint\Endpoint;
+use AlibabaCloud\OpenApiUtil\OpenApiUtilClient;
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleRequest;
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleResponse;
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithOIDCRequest;
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithOIDCResponse;
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithSAMLRequest;
+use AlibabaCloud\SDK\Sts\V20150401\Models\AssumeRoleWithSAMLResponse;
+use AlibabaCloud\SDK\Sts\V20150401\Models\GetCallerIdentityResponse;
+use AlibabaCloud\Tea\Utils\Utils;
+use AlibabaCloud\Tea\Utils\Utils\RuntimeOptions;
+use Darabonba\OpenApi\Models\OpenApiRequest;
+use Darabonba\OpenApi\Models\Params;
+use Darabonba\OpenApi\OpenApiClient;
+
+class Sts extends OpenApiClient
+{
+    public function __construct($config)
+    {
+        parent::__construct($config);
+        $this->_endpointRule = 'regional';
+        $this->_endpointMap  = [
+            'ap-northeast-2-pop'          => 'sts.aliyuncs.com',
+            'cn-beijing-finance-1'        => 'sts.aliyuncs.com',
+            'cn-beijing-finance-pop'      => 'sts.aliyuncs.com',
+            'cn-beijing-gov-1'            => 'sts.aliyuncs.com',
+            'cn-beijing-nu16-b01'         => 'sts.aliyuncs.com',
+            'cn-edge-1'                   => 'sts.aliyuncs.com',
+            'cn-fujian'                   => 'sts.aliyuncs.com',
+            'cn-haidian-cm12-c01'         => 'sts.aliyuncs.com',
+            'cn-hangzhou-bj-b01'          => 'sts.aliyuncs.com',
+            'cn-hangzhou-finance'         => 'sts.aliyuncs.com',
+            'cn-hangzhou-internal-prod-1' => 'sts.aliyuncs.com',
+            'cn-hangzhou-internal-test-1' => 'sts.aliyuncs.com',
+            'cn-hangzhou-internal-test-2' => 'sts.aliyuncs.com',
+            'cn-hangzhou-internal-test-3' => 'sts.aliyuncs.com',
+            'cn-hangzhou-test-306'        => 'sts.aliyuncs.com',
+            'cn-hongkong-finance-pop'     => 'sts.aliyuncs.com',
+            'cn-huhehaote-nebula-1'       => 'sts.aliyuncs.com',
+            'cn-north-2-gov-1'            => 'sts-vpc.cn-north-2-gov-1.aliyuncs.com',
+            'cn-qingdao-nebula'           => 'sts.aliyuncs.com',
+            'cn-shanghai-et15-b01'        => 'sts.aliyuncs.com',
+            'cn-shanghai-et2-b01'         => 'sts.aliyuncs.com',
+            'cn-shanghai-inner'           => 'sts.aliyuncs.com',
+            'cn-shanghai-internal-test-1' => 'sts.aliyuncs.com',
+            'cn-shenzhen-finance-1'       => 'sts-vpc.cn-shenzhen-finance-1.aliyuncs.com',
+            'cn-shenzhen-inner'           => 'sts.aliyuncs.com',
+            'cn-shenzhen-st4-d01'         => 'sts.aliyuncs.com',
+            'cn-shenzhen-su18-b01'        => 'sts.aliyuncs.com',
+            'cn-wuhan'                    => 'sts.aliyuncs.com',
+            'cn-yushanfang'               => 'sts.aliyuncs.com',
+            'cn-zhangbei'                 => 'sts.aliyuncs.com',
+            'cn-zhangbei-na61-b01'        => 'sts.aliyuncs.com',
+            'cn-zhangjiakou-na62-a01'     => 'sts.aliyuncs.com',
+            'cn-zhengzhou-nebula-1'       => 'sts.aliyuncs.com',
+            'eu-west-1-oxs'               => 'sts.aliyuncs.com',
+            'rus-west-1-pop'              => 'sts.aliyuncs.com',
+        ];
+        $this->checkConfig($config);
+        $this->_endpoint = $this->getEndpoint('sts', $this->_regionId, $this->_endpointRule, $this->_network, $this->_suffix, $this->_endpointMap, $this->_endpoint);
+    }
+
+    /**
+     * @param string   $productId
+     * @param string   $regionId
+     * @param string   $endpointRule
+     * @param string   $network
+     * @param string   $suffix
+     * @param string[] $endpointMap
+     * @param string   $endpoint
+     *
+     * @return string
+     */
+    public function getEndpoint($productId, $regionId, $endpointRule, $network, $suffix, $endpointMap, $endpoint)
+    {
+        if (!Utils::empty_($endpoint)) {
+            return $endpoint;
+        }
+        if (!Utils::isUnset($endpointMap) && !Utils::empty_(@$endpointMap[$regionId])) {
+            return @$endpointMap[$regionId];
+        }
+
+        return Endpoint::getEndpointRules($productId, $regionId, $endpointRule, $network, $suffix);
+    }
+
+    /**
+     * @param AssumeRoleRequest $request
+     * @param RuntimeOptions    $runtime
+     *
+     * @return AssumeRoleResponse
+     */
+    public function assumeRoleWithOptions($request, $runtime)
+    {
+        Utils::validateModel($request);
+        $query = [];
+        if (!Utils::isUnset($request->durationSeconds)) {
+            $query['DurationSeconds'] = $request->durationSeconds;
+        }
+        if (!Utils::isUnset($request->policy)) {
+            $query['Policy'] = $request->policy;
+        }
+        if (!Utils::isUnset($request->roleArn)) {
+            $query['RoleArn'] = $request->roleArn;
+        }
+        if (!Utils::isUnset($request->roleSessionName)) {
+            $query['RoleSessionName'] = $request->roleSessionName;
+        }
+        $req = new OpenApiRequest([
+            'query' => OpenApiUtilClient::query($query),
+        ]);
+        $params = new Params([
+            'action'      => 'AssumeRole',
+            'version'     => '2015-04-01',
+            'protocol'    => 'HTTPS',
+            'pathname'    => '/',
+            'method'      => 'POST',
+            'authType'    => 'AK',
+            'style'       => 'RPC',
+            'reqBodyType' => 'formData',
+            'bodyType'    => 'json',
+        ]);
+
+        return AssumeRoleResponse::fromMap($this->callApi($params, $req, $runtime));
+    }
+
+    /**
+     * @param AssumeRoleRequest $request
+     *
+     * @return AssumeRoleResponse
+     */
+    public function assumeRole($request)
+    {
+        $runtime = new RuntimeOptions([]);
+
+        return $this->assumeRoleWithOptions($request, $runtime);
+    }
+
+    /**
+     * @param AssumeRoleWithOIDCRequest $request
+     * @param RuntimeOptions            $runtime
+     *
+     * @return AssumeRoleWithOIDCResponse
+     */
+    public function assumeRoleWithOIDCWithOptions($request, $runtime)
+    {
+        Utils::validateModel($request);
+        $query = [];
+        if (!Utils::isUnset($request->durationSeconds)) {
+            $query['DurationSeconds'] = $request->durationSeconds;
+        }
+        if (!Utils::isUnset($request->OIDCProviderArn)) {
+            $query['OIDCProviderArn'] = $request->OIDCProviderArn;
+        }
+        if (!Utils::isUnset($request->OIDCToken)) {
+            $query['OIDCToken'] = $request->OIDCToken;
+        }
+        if (!Utils::isUnset($request->policy)) {
+            $query['Policy'] = $request->policy;
+        }
+        if (!Utils::isUnset($request->roleArn)) {
+            $query['RoleArn'] = $request->roleArn;
+        }
+        if (!Utils::isUnset($request->roleSessionName)) {
+            $query['RoleSessionName'] = $request->roleSessionName;
+        }
+        $req = new OpenApiRequest([
+            'query' => OpenApiUtilClient::query($query),
+        ]);
+        $params = new Params([
+            'action'      => 'AssumeRoleWithOIDC',
+            'version'     => '2015-04-01',
+            'protocol'    => 'HTTPS',
+            'pathname'    => '/',
+            'method'      => 'POST',
+            'authType'    => 'Anonymous',
+            'style'       => 'RPC',
+            'reqBodyType' => 'formData',
+            'bodyType'    => 'json',
+        ]);
+
+        return AssumeRoleWithOIDCResponse::fromMap($this->callApi($params, $req, $runtime));
+    }
+
+    /**
+     * @param AssumeRoleWithOIDCRequest $request
+     *
+     * @return AssumeRoleWithOIDCResponse
+     */
+    public function assumeRoleWithOIDC($request)
+    {
+        $runtime = new RuntimeOptions([]);
+
+        return $this->assumeRoleWithOIDCWithOptions($request, $runtime);
+    }
+
+    /**
+     * @param AssumeRoleWithSAMLRequest $request
+     * @param RuntimeOptions            $runtime
+     *
+     * @return AssumeRoleWithSAMLResponse
+     */
+    public function assumeRoleWithSAMLWithOptions($request, $runtime)
+    {
+        Utils::validateModel($request);
+        $query = [];
+        if (!Utils::isUnset($request->durationSeconds)) {
+            $query['DurationSeconds'] = $request->durationSeconds;
+        }
+        if (!Utils::isUnset($request->policy)) {
+            $query['Policy'] = $request->policy;
+        }
+        if (!Utils::isUnset($request->roleArn)) {
+            $query['RoleArn'] = $request->roleArn;
+        }
+        if (!Utils::isUnset($request->SAMLAssertion)) {
+            $query['SAMLAssertion'] = $request->SAMLAssertion;
+        }
+        if (!Utils::isUnset($request->SAMLProviderArn)) {
+            $query['SAMLProviderArn'] = $request->SAMLProviderArn;
+        }
+        $req = new OpenApiRequest([
+            'query' => OpenApiUtilClient::query($query),
+        ]);
+        $params = new Params([
+            'action'      => 'AssumeRoleWithSAML',
+            'version'     => '2015-04-01',
+            'protocol'    => 'HTTPS',
+            'pathname'    => '/',
+            'method'      => 'POST',
+            'authType'    => 'Anonymous',
+            'style'       => 'RPC',
+            'reqBodyType' => 'formData',
+            'bodyType'    => 'json',
+        ]);
+
+        return AssumeRoleWithSAMLResponse::fromMap($this->callApi($params, $req, $runtime));
+    }
+
+    /**
+     * @param AssumeRoleWithSAMLRequest $request
+     *
+     * @return AssumeRoleWithSAMLResponse
+     */
+    public function assumeRoleWithSAML($request)
+    {
+        $runtime = new RuntimeOptions([]);
+
+        return $this->assumeRoleWithSAMLWithOptions($request, $runtime);
+    }
+
+    /**
+     * @param RuntimeOptions $runtime
+     *
+     * @return GetCallerIdentityResponse
+     */
+    public function getCallerIdentityWithOptions($runtime)
+    {
+        $req    = new OpenApiRequest([]);
+        $params = new Params([
+            'action'      => 'GetCallerIdentity',
+            'version'     => '2015-04-01',
+            'protocol'    => 'HTTPS',
+            'pathname'    => '/',
+            'method'      => 'POST',
+            'authType'    => 'AK',
+            'style'       => 'RPC',
+            'reqBodyType' => 'formData',
+            'bodyType'    => 'json',
+        ]);
+
+        return GetCallerIdentityResponse::fromMap($this->callApi($params, $req, $runtime));
+    }
+
+    /**
+     * @return GetCallerIdentityResponse
+     */
+    public function getCallerIdentity()
+    {
+        $runtime = new RuntimeOptions([]);
+
+        return $this->getCallerIdentityWithOptions($runtime);
+    }
+}

+ 1 - 0
vendor/composer/autoload_psr4.php

@@ -65,6 +65,7 @@ return array(
     'AlibabaCloud\\Tea\\Utils\\' => array($vendorDir . '/alibabacloud/tea-utils/src'),
     'AlibabaCloud\\Tea\\' => array($vendorDir . '/alibabacloud/tea/src'),
     'AlibabaCloud\\SDK\\Vod\\V20170321\\' => array($vendorDir . '/alibabacloud/vod-20170321/src'),
+    'AlibabaCloud\\SDK\\Sts\\V20150401\\' => array($vendorDir . '/alibabacloud/sts-20150401/src'),
     'AlibabaCloud\\OpenApiUtil\\' => array($vendorDir . '/alibabacloud/openapi-util/src'),
     'AlibabaCloud\\Endpoint\\' => array($vendorDir . '/alibabacloud/endpoint-util/src'),
     'AlibabaCloud\\Credentials\\' => array($vendorDir . '/alibabacloud/credentials/src'),

+ 5 - 0
vendor/composer/autoload_static.php

@@ -142,6 +142,7 @@ class ComposerStaticInit4d241e9f8bb10d006cd7432f945fdb5b
             'AlibabaCloud\\Tea\\Utils\\' => 23,
             'AlibabaCloud\\Tea\\' => 17,
             'AlibabaCloud\\SDK\\Vod\\V20170321\\' => 31,
+            'AlibabaCloud\\SDK\\Sts\\V20150401\\' => 31,
             'AlibabaCloud\\OpenApiUtil\\' => 25,
             'AlibabaCloud\\Endpoint\\' => 22,
             'AlibabaCloud\\Credentials\\' => 25,
@@ -392,6 +393,10 @@ class ComposerStaticInit4d241e9f8bb10d006cd7432f945fdb5b
         array (
             0 => __DIR__ . '/..' . '/alibabacloud/vod-20170321/src',
         ),
+        'AlibabaCloud\\SDK\\Sts\\V20150401\\' => 
+        array (
+            0 => __DIR__ . '/..' . '/alibabacloud/sts-20150401/src',
+        ),
         'AlibabaCloud\\OpenApiUtil\\' => 
         array (
             0 => __DIR__ . '/..' . '/alibabacloud/openapi-util/src',

+ 52 - 0
vendor/composer/installed.json

@@ -698,6 +698,58 @@
             "install-path": "../alibabacloud/sdk"
         },
         {
+            "name": "alibabacloud/sts-20150401",
+            "version": "1.1.1",
+            "version_normalized": "1.1.1.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/alibabacloud-sdk-php/sts-20150401.git",
+                "reference": "1273545fb137dcaa63ea877dc7bc8204b534b6e5"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/alibabacloud-sdk-php/sts-20150401/zipball/1273545fb137dcaa63ea877dc7bc8204b534b6e5",
+                "reference": "1273545fb137dcaa63ea877dc7bc8204b534b6e5",
+                "shasum": "",
+                "mirrors": [
+                    {
+                        "url": "https://mirrors.aliyun.com/composer/dists/%package%/%reference%.%type%",
+                        "preferred": true
+                    }
+                ]
+            },
+            "require": {
+                "alibabacloud/darabonba-openapi": "^0.2.5",
+                "alibabacloud/endpoint-util": "^0.1.0",
+                "alibabacloud/openapi-util": "^0.1.10",
+                "alibabacloud/tea-utils": "^0.2.0",
+                "php": ">5.5"
+            },
+            "time": "2022-03-26T04:28:44+00:00",
+            "type": "library",
+            "installation-source": "dist",
+            "autoload": {
+                "psr-4": {
+                    "AlibabaCloud\\SDK\\Sts\\V20150401\\": "src"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "Apache-2.0"
+            ],
+            "authors": [
+                {
+                    "name": "Alibaba Cloud SDK",
+                    "email": "sdk-team@alibabacloud.com"
+                }
+            ],
+            "description": "Alibaba Cloud Sts (20150401) SDK Library for PHP",
+            "support": {
+                "source": "https://github.com/alibabacloud-sdk-php/sts-20150401/tree/1.1.1"
+            },
+            "install-path": "../alibabacloud/sts-20150401"
+        },
+        {
             "name": "alibabacloud/tea",
             "version": "3.1.24",
             "version_normalized": "3.1.24.0",

+ 11 - 2
vendor/composer/installed.php

@@ -3,7 +3,7 @@
         'name' => 'zoujingli/thinkadmin',
         'pretty_version' => 'dev-master',
         'version' => 'dev-master',
-        'reference' => 'bb42c13b2384b5853b8e06a8b1b101af9898e0e6',
+        'reference' => 'd2cb3f673f8c135db6dcab8f0a7eeaf9b085c1b6',
         'type' => 'project',
         'install_path' => __DIR__ . '/../../',
         'aliases' => array(),
@@ -976,6 +976,15 @@
                 0 => '1.8.1392',
             ),
         ),
+        'alibabacloud/sts-20150401' => array(
+            'pretty_version' => '1.1.1',
+            'version' => '1.1.1.0',
+            'reference' => '1273545fb137dcaa63ea877dc7bc8204b534b6e5',
+            'type' => 'library',
+            'install_path' => __DIR__ . '/../alibabacloud/sts-20150401',
+            'aliases' => array(),
+            'dev_requirement' => false,
+        ),
         'alibabacloud/taginner' => array(
             'dev_requirement' => false,
             'replaced' => array(
@@ -1678,7 +1687,7 @@
         'zoujingli/thinkadmin' => array(
             'pretty_version' => 'dev-master',
             'version' => 'dev-master',
-            'reference' => 'bb42c13b2384b5853b8e06a8b1b101af9898e0e6',
+            'reference' => 'd2cb3f673f8c135db6dcab8f0a7eeaf9b085c1b6',
             'type' => 'project',
             'install_path' => __DIR__ . '/../../',
             'aliases' => array(),