diff --git a/vendor/aliyuncs/oss-sdk-php/.coveralls.yml b/vendor/aliyuncs/oss-sdk-php/.coveralls.yml
new file mode 100644
index 000000000..850cc5974
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/.coveralls.yml
@@ -0,0 +1,2 @@
+coverage_clover: coverage.xml
+json_path: coverage.json
diff --git a/vendor/aliyuncs/oss-sdk-php/.gitignore b/vendor/aliyuncs/oss-sdk-php/.gitignore
new file mode 100644
index 000000000..7cdb514d8
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/.gitignore
@@ -0,0 +1,8 @@
+vendor
+composer.lock
+doc
+output
+.idea
+.buildpath
+.project
+.settings
diff --git a/vendor/aliyuncs/oss-sdk-php/.travis.yml b/vendor/aliyuncs/oss-sdk-php/.travis.yml
new file mode 100644
index 000000000..8c433e7fb
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/.travis.yml
@@ -0,0 +1,20 @@
+language: php
+php:
+ - 7.0
+ - 5.6
+ - 5.5
+ - 5.4
+ - 5.3
+install:
+ - composer self-update
+ - composer install --no-interaction
+script:
+ - php vendor/bin/phpunit
+after_success:
+ - php vendor/bin/coveralls -v
+env:
+ global:
+ - secure: SzmQ854lQmhV6ZkAG7lQNTY3CkazrXnDSb6VMwPU/sdaLGxPO159AW3fJS5d0sO/XN1P8x5WNkoA4i9soDlLBRibEEISNUM/2EMnpszsRymZ9o97PrS2IgORXTUL/OF+rpATzyNVB2p+2l9hBLiGf17exMSA5iOeY7W6E+VKPGi8TFykgbGUnLKU0h1hV3rzmtfGjOXcSpvYU/hxeZD/J/+6m5Gic9b/pNS+AbfTj7Y7Ru9tNsnyUP29V/vtEYtpQir3ZxQiSiUv9idybgGnJBOMYydJofb/mpFYHhYLSWqtMKGNLpeawmqs4z8S1Tvx5U5uzW5+h/mpzhvBaFlWGpm8t89BQxun5LVX5NiYCrV7TqaLitGp1cSpMjMDnrnSTNzk1exVz+rWZZcWS7yB9ULYA681GA8StXWk167qB7Y30iK1dFK3+2mDN2cEY+qLs8+bupDowQ4eOM+eqfhxX8F8+ouKcKomETsjiIwL+CUsIe6wjvnYFWb1YlRhbsI75bblHApflohnt6gVSJ78ZPqID+u2oUMjmIWXLTnRR2Y2tgEW8uqHeIoQ8BBntLdQDmv0BO4FpnGQIwrUUwQYeNzEM0DOr3hWZhyDR6Xvl+9H0l52xjANaSqpuTZfC3zmeFTG7kIjydvxNePRrony6XAawL9BvI7aKWuVF6YVjPM=
+ - secure: nEhsU8aUQqsAJeuger+boh51oTpeo4YNG7vUWbKxdwVDIrcLb+l7r7RvTlxU7mt8IZTWwicgri18mh+Wi04BwX4ulBA1SCs8jPbL51KEo5izoDGGtLSd2fuPHdslYSrwagrvq90EPnDT/7fHWn/TAoT+rueZzjNyCu5IGSgL3GnXaUThsJ82NMePL2YRdP4Q1qmtZPRFBOkOQ6F0heuV8fw8sLyTO3txaCQum9YneGxrWxOl/E8zB0qtlnPwLE8ogaHZMQh2/jThmTbI5UqwRTxV4f0qoD5eJYH+j0fslsSAjsg/HPnSuVcnccK3zSU+s2sV4dPCcISzECJvZEObwipfxOGhdqt5gMcxHhn8qVsbT97iIh106pG/BJCDgQd2EeVW8WfCi6cCuCKIMipvVkMypkmjQHWU1XaqPzILl7g5diW9Ctp2C4Akq5dYdrdu8IrnVK1ShtkQVaWU+S/Bht8VU5gYP7olPW/GdTz7sceU1NOIC4NPXqmWKbfavR98U5dkHMLMvzABYL1Q87h+KhPD1c14NUyw3YENUW7REiF/X5lERRm5H0kJ/1JqAa+AgeHQEGmPVuZV2s/na4b0S1479QRVmSM/6ZzXQpU+Y8jCRfETpUFA4S331369kirHgCqDlxyIntuEKrzivD02/O+5C3eJ0WHRz6QsN2/R4qg=
+ - secure: ZTvzNXEZP4efl+a/3VGMmdabfUQp83v5/lecMns039Ro7UuZYPdtbPtpPnpjaTI6Htd22A4Rva5BU/3JCQJAyQvpbKNn5sGou2SmfQu3o0SyhggSB7gWjYAf707aW1j4bHYfP8IjDS5NjuVk3AqXeNSUuLRUXRmwSOB0lSYiRhiTJY+pUdBl382Hx4NbhIU/gmOzRoJCs7coTip8IURXYEHPi5dnDWluajxI+TgNXFccSgEleeQDJajYgXmpLb2EhSj8piipOnVgaCEE5bh5fbp32024Qq38SGHKcbfnwj2IInpZpZESJknRKoqAlFjdOJhork82dBcvAr5JxCBZKx5IuwXcTjxkQ6tRtBeqhPLPFuX3MQ8WrtU+wniPM0RCH/VoFkUKO7JGQDwmoi2AKago4PsuDs4P6Y6CeuOVpcso731GwwMNhIJcyrJJivXprQNEGsEw+9wLjU1qNYs6IIA3S/gPzFrNbdX5Wf8vxt0vLpgYvBNtPnLMejMtknuyfVzf5iKuVVoGPDTEz+ajs06+jfoPfm/4sLTaLghuVH7Adm74OpF769JQNnQYKwJuu4bNlcbLJChulCEMBOx7myqo/9O6RCTuqzHaGmVWNot4RGqRFHgJGl/JJf0WpAVitbhbRH3kGoyKb6jFM74CJbPsE7OORlJLDC3cdD3C8Pk=
+ - secure: Qr5NR4CVzBKCQgRgMH0x772TPJ1+brx3UCvtRNu8fi4j3p8bz+HDMjBaBDSFmEB09nunLI55/8mj88/5GXmnpFs8+CPTkcW+QZOcxg3cxpI4SNmxoB12/ZawlFHAqSUaRRE7RUWVkY3KL8tIGjEZcFyUBQ1DVNX3OMpiKs3NLtHa7oUIknyBxdSokm4kpLhSXYe7WmO0vhuZbMZE0S1EISToiBS6AdhGUEbTLJ/vNsIDY07fu6+Vh3HxVbyUFPqUZGlkZpQ+2xMJ3kiqPBMrXtRF/IhhPjORDil6Ns9SQ8/AAlaCddvYvRaT4Pjv2/aX+t3l28qI1qmryPtWXpce5UXecWGYqdRpSJc6Y/pEt4m4FeeGoEFWnSPGIs7FRmeiis8q2rojGZ18i4vI/k4iHmqEBnTlMp3SWnRb9L1adJ8ZAWln8aC88gkQXm67w7+1CxLycerbYj9H1ugqHENuHcxv4uHUcZgEENX3EWatu8i9+K2IUuU/2zcmpu7qtsziYcoyW8DOOmYpJfXGMLtmF9+pqp/Tp6i0tltFSEfmY3N8o7xvv3enLvFHsjL+3ElFdd1blUPSrvZJHgA9M3lJ+QF1RJZCpJqgPlQ0XOZK1Bf4P46zpEj01wKaK4JQrkLPRXhbBOuIJn5O6WlFJyPX4+SaBfwTzb4AvM4aUg2TgTg=
diff --git a/vendor/aliyuncs/oss-sdk-php/CHANGELOG.md b/vendor/aliyuncs/oss-sdk-php/CHANGELOG.md
new file mode 100644
index 000000000..be8632314
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/CHANGELOG.md
@@ -0,0 +1,82 @@
+# ChangeLog - Aliyun OSS SDK for PHP
+
+## v2.2.4 / 2017-04-25
+
+* fix getObject to local file bug
+
+## v2.2.3 / 2017-04-14
+
+* fix md5 check
+
+## v2.2.2 / 2017-01-18
+
+* 解决在php7上运行连接数和内存bug
+
+## v2.2.1 / 2016-12-01
+
+* 禁止http curl自动填充Accept-Encoding
+
+## v2.2.0 / 2016-11-22
+
+* 修复PutObject/CompleteMultipartUpload的返回值问题(#26)
+
+## v2.1.0 / 2016-11-12
+
+* 增加[RTMP](https://help.aliyun.com/document_detail/44297.html)接口
+* 增加支持[图片服务](https://help.aliyun.com/document_detail/44686.html)
+
+## v2.0.7 / 2016-06-17
+
+* Support append object
+
+## v2.0.6
+
+* Trim access key id/secret and endpoint
+* Refine tests and setup travis CI
+
+## v2.0.5
+
+* 增加Add/Delete/Get BucketCname接口
+
+## v2.0.4
+
+* 增加Put/Get Object Acl接口
+
+## v2.0.3
+
+* 修复Util中的常量定义在低于5.6的PHP版本中报错的问题
+
+## v2.0.2
+
+* 修复multipart上传时无法指定Content-Type的问题
+
+## v2.0.1
+
+* 增加对ListObjects/ListMultipartUploads时特殊字符的处理
+* 提供接口获取OssException中的详细信息
+
+
+## 2015.11.25
+
+* **大版本升级,不再兼容以前接口,新版本对易用性做了很大的改进,建议用户迁移到新版本。**
+
+## 修改内容
+
+* 不再支持PHP 5.2版本
+
+### 新增内容
+
+* 引入命名空间
+* 接口命名修正,采用驼峰式命名
+* 接口入参修改,把常用参数从Options参数中提出来
+* 接口返回结果修改,对返回结果进行处理,用户可以直接得到容易处理的数据结构
+* OssClient的构造函数变更
+* 支持CNAME和IP格式的Endpoint地址
+* 重新整理sample文件组织结构,使用function组织功能点
+* 增加设置连接超时,请求超时的接口
+* 去掉Object Group相关的已经过时的接口
+* OssException中的message改为英文
+
+### 问题修复
+
+* object名称校验不完备
diff --git a/vendor/aliyuncs/oss-sdk-php/LICENSE.md b/vendor/aliyuncs/oss-sdk-php/LICENSE.md
new file mode 100644
index 000000000..3183de8c3
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/LICENSE.md
@@ -0,0 +1,21 @@
+#The MIT License (MIT)
+
+Copyright (c) ali-sdk and other contributors.
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+SOFTWARE.
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/README.md b/vendor/aliyuncs/oss-sdk-php/README.md
new file mode 100644
index 000000000..1549ddaf6
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/README.md
@@ -0,0 +1,152 @@
+# Aliyun OSS SDK for PHP
+
+[](https://packagist.org/packages/aliyuncs/oss-sdk-php)
+[](https://travis-ci.org/aliyun/aliyun-oss-php-sdk)
+[](https://coveralls.io/github/aliyun/aliyun-oss-php-sdk?branch=master)
+
+## 概述
+
+阿里云对象存储(Object Storage Service,简称OSS),是阿里云对外提供的海量、安全、低成本、高可靠的云存储服务。用户可以通过调用API,在任何应用、任何时间、任何地点上传和下载数据,也可以通过用户Web控制台对数据进行简单的管理。OSS适合存放任意文件类型,适合各种网站、开发企业及开发者使用。
+
+
+## 运行环境
+- PHP 5.3+
+- cURL extension
+
+提示:
+
+- Ubuntu下可以使用apt-get包管理器安装php的cURL扩展 `sudo apt-get install php5-curl`
+
+## 安装方法
+
+1. 如果您通过composer管理您的项目依赖,可以在你的项目根目录运行:
+
+ $ composer require aliyuncs/oss-sdk-php
+
+ 或者在你的`composer.json`中声明对Aliyun OSS SDK for PHP的依赖:
+
+ "require": {
+ "aliyuncs/oss-sdk-php": "~2.0"
+ }
+
+ 然后通过`composer install`安装依赖。composer安装完成后,在您的PHP代码中引入依赖即可:
+
+ require_once __DIR__ . '/vendor/autoload.php';
+
+2. 您也可以直接下载已经打包好的[phar文件][releases-page],然后在你
+ 的代码中引入这个文件即可:
+
+ require_once '/path/to/oss-sdk-php.phar';
+
+3. 下载SDK源码,在您的代码中引入SDK目录下的`autoload.php`文件:
+
+ require_once '/path/to/oss-sdk/autoload.php';
+
+## 快速使用
+
+### 常用类
+
+| 类名 | 解释 |
+|:------------------|:------------------------------------|
+|OSS\OssClient | OSS客户端类,用户通过OssClient的实例调用接口 |
+|OSS\Core\OssException | OSS异常类,用户在使用的过程中,只需要注意这个异常|
+
+### OssClient初始化
+
+SDK的OSS操作通过OssClient类完成的,下面代码创建一个OssClient对象:
+
+```php
+"; ;
+$accessKeySecret = "<您从OSS获得的AccessKeySecret>";
+$endpoint = "<您选定的OSS数据中心访问域名,例如oss-cn-hangzhou.aliyuncs.com>";
+try {
+ $ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint);
+} catch (OssException $e) {
+ print $e->getMessage();
+}
+```
+
+### 文件操作
+
+文件(又称对象,Object)是OSS中最基本的数据单元,您可以把它简单地理解为文件,用下面代码可以实现一个Object的上传:
+
+```php
+";
+$object = "<您使用的Object名字,注意命名规范>";
+$content = "Hello, OSS!"; // 上传的文件内容
+try {
+ $ossClient->putObject($bucket, $object, $content);
+} catch (OssException $e) {
+ print $e->getMessage();
+}
+```
+
+### 存储空间操作
+
+存储空间(又称Bucket)是一个用户用来管理所存储Object的存储空间,对于用户来说是一个管理Object的单元,所有的Object都必须隶属于某个Bucket。您可以按照下面的代码新建一个Bucket:
+
+```php
+";
+try {
+ $ossClient->createBucket($bucket);
+} catch (OssException $e) {
+ print $e->getMessage();
+}
+```
+
+### 返回结果处理
+
+OssClient提供的接口返回返回数据分为两种:
+
+* Put,Delete类接口,接口返回null,如果没有OssException,即可认为操作成功
+* Get,List类接口,接口返回对应的数据,如果没有OssException,即可认为操作成功,举个例子:
+
+```php
+listBuckets();
+$bucketList = $bucketListInfo->getBucketList();
+foreach($bucketList as $bucket) {
+ print($bucket->getLocation() . "\t" . $bucket->getName() . "\t" . $bucket->getCreatedate() . "\n");
+}
+```
+上面代码中的$bucketListInfo的数据类型是 `OSS\Model\BucketListInfo`
+
+
+### 运行Sample程序
+
+1. 修改 `samples/Config.php`, 补充配置信息
+2. 执行 `cd samples/ && php RunAll.php`
+
+### 运行单元测试
+
+1. 执行`composer install`下载依赖的库
+2. 设置环境变量
+
+ export OSS_ACCESS_KEY_ID=access-key-id
+ export OSS_ACCESS_KEY_SECRET=access-key-secret
+ export OSS_ENDPOINT=endpoint
+ export OSS_BUCKET=bucket-name
+
+3. 执行 `php vendor/bin/phpunit`
+
+## 贡献代码
+
+0. 开发流程参考:https://github.com/rockuw/oss-sdk-status#development-oss-members-only
+1. 提交代码后,确保travis CI是PASS的
+2. 每发布一个新的版本:
+ - 运行`build-phar.sh`生成相应的phar包(需要安装[phar-composer][phar-composer])
+ - 在[Release页面][releases-page]发布一个版本
+ - 将生成的phar包上传到相应的Release下面
+
+## 联系我们
+
+- [阿里云OSS官方网站](http://oss.aliyun.com)
+- [阿里云OSS官方论坛](http://bbs.aliyun.com)
+- [阿里云OSS官方文档中心](http://www.aliyun.com/product/oss#Docs)
+- 阿里云官方技术支持:[提交工单](https://workorder.console.aliyun.com/#/ticket/createIndex)
+
+[releases-page]: https://github.com/aliyun/aliyun-oss-php-sdk/releases
+[phar-composer]: https://github.com/clue/phar-composer
diff --git a/vendor/aliyuncs/oss-sdk-php/autoload.php b/vendor/aliyuncs/oss-sdk-php/autoload.php
new file mode 100644
index 000000000..ec132011c
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/autoload.php
@@ -0,0 +1,11 @@
+=5.3"
+ },
+ "require-dev" : {
+ "phpunit/phpunit": "~4.0",
+ "satooshi/php-coveralls": "~1.0"
+ },
+ "minimum-stability": "stable",
+ "autoload": {
+ "psr-4": {"OSS\\": "src/OSS"}
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/example.jpg b/vendor/aliyuncs/oss-sdk-php/example.jpg
new file mode 100644
index 000000000..ffd46a2f8
Binary files /dev/null and b/vendor/aliyuncs/oss-sdk-php/example.jpg differ
diff --git a/vendor/aliyuncs/oss-sdk-php/index.php b/vendor/aliyuncs/oss-sdk-php/index.php
new file mode 100644
index 000000000..cdc28bc13
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/index.php
@@ -0,0 +1,3 @@
+
+
+
+
+
+
+ ./src
+
+
+
+
+
+
+
+ ./tests
+ ./tests/OSS/Tests/BucketCnameTest.php
+
+
+
diff --git a/vendor/aliyuncs/oss-sdk-php/samples/Bucket.php b/vendor/aliyuncs/oss-sdk-php/samples/Bucket.php
new file mode 100644
index 000000000..bd16e6556
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/samples/Bucket.php
@@ -0,0 +1,167 @@
+createBucket($bucket, OssClient::OSS_ACL_TYPE_PUBLIC_READ_WRITE);
+Common::println("bucket $bucket created");
+
+// 判断Bucket是否存在
+$doesExist = $ossClient->doesBucketExist($bucket);
+Common::println("bucket $bucket exist? " . ($doesExist ? "yes" : "no"));
+
+// 获取Bucket列表
+$bucketListInfo = $ossClient->listBuckets();
+
+// 设置bucket的ACL
+$ossClient->putBucketAcl($bucket, OssClient::OSS_ACL_TYPE_PUBLIC_READ_WRITE);
+Common::println("bucket $bucket acl put");
+// 获取bucket的ACL
+$acl = $ossClient->getBucketAcl($bucket);
+Common::println("bucket $bucket acl get: " . $acl);
+
+
+//******************************* 完整用法参考下面函数 ****************************************************
+
+createBucket($ossClient, $bucket);
+doesBucketExist($ossClient, $bucket);
+deleteBucket($ossClient, $bucket);
+putBucketAcl($ossClient, $bucket);
+getBucketAcl($ossClient, $bucket);
+listBuckets($ossClient);
+
+/**
+ * 创建一个存储空间
+ * acl 指的是bucket的访问控制权限,有三种,私有读写,公共读私有写,公共读写。
+ * 私有读写就是只有bucket的拥有者或授权用户才有权限操作
+ * 三种权限分别对应 (OssClient::OSS_ACL_TYPE_PRIVATE,OssClient::OSS_ACL_TYPE_PUBLIC_READ, OssClient::OSS_ACL_TYPE_PUBLIC_READ_WRITE)
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 要创建的存储空间名称
+ * @return null
+ */
+function createBucket($ossClient, $bucket)
+{
+ try {
+ $ossClient->createBucket($bucket, OssClient::OSS_ACL_TYPE_PUBLIC_READ_WRITE);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+/**
+ * 判断Bucket是否存在
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ */
+function doesBucketExist($ossClient, $bucket)
+{
+ try {
+ $res = $ossClient->doesBucketExist($bucket);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ if ($res === true) {
+ print(__FUNCTION__ . ": OK" . "\n");
+ } else {
+ print(__FUNCTION__ . ": FAILED" . "\n");
+ }
+}
+
+/**
+ * 删除bucket,如果bucket不为空则bucket无法删除成功, 不为空表示bucket既没有object,也没有未完成的multipart上传时的parts
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 待删除的存储空间名称
+ * @return null
+ */
+function deleteBucket($ossClient, $bucket)
+{
+ try {
+ $ossClient->deleteBucket($bucket);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+/**
+ * 设置bucket的acl配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function putBucketAcl($ossClient, $bucket)
+{
+ $acl = OssClient::OSS_ACL_TYPE_PRIVATE;
+ try {
+ $ossClient->putBucketAcl($bucket, $acl);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+
+/**
+ * 获取bucket的acl配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function getBucketAcl($ossClient, $bucket)
+{
+ try {
+ $res = $ossClient->getBucketAcl($bucket);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+ print('acl: ' . $res);
+}
+
+
+/**
+ * 列出用户所有的Bucket
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @return null
+ */
+function listBuckets($ossClient)
+{
+ $bucketList = null;
+ try {
+ $bucketListInfo = $ossClient->listBuckets();
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+ $bucketList = $bucketListInfo->getBucketList();
+ foreach ($bucketList as $bucket) {
+ print($bucket->getLocation() . "\t" . $bucket->getName() . "\t" . $bucket->getCreatedate() . "\n");
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/samples/BucketCors.php b/vendor/aliyuncs/oss-sdk-php/samples/BucketCors.php
new file mode 100644
index 000000000..cc5c0b9c5
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/samples/BucketCors.php
@@ -0,0 +1,108 @@
+addAllowedHeader("x-oss-header");
+$rule->addAllowedOrigin("http://www.b.com");
+$rule->addAllowedMethod("POST");
+$rule->setMaxAgeSeconds(10);
+$corsConfig->addRule($rule);
+$ossClient->putBucketCors($bucket, $corsConfig);
+Common::println("bucket $bucket corsConfig created:" . $corsConfig->serializeToXml());
+
+// 获取cors配置
+$corsConfig = $ossClient->getBucketCors($bucket);
+Common::println("bucket $bucket corsConfig fetched:" . $corsConfig->serializeToXml());
+
+// 删除cors配置
+$ossClient->deleteBucketCors($bucket);
+Common::println("bucket $bucket corsConfig deleted");
+
+//******************************* 完整用法参考下面函数 *****************************************************
+
+putBucketCors($ossClient, $bucket);
+getBucketCors($ossClient, $bucket);
+deleteBucketCors($ossClient, $bucket);
+getBucketCors($ossClient, $bucket);
+
+/**
+ * 设置bucket的cors配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function putBucketCors($ossClient, $bucket)
+{
+ $corsConfig = new CorsConfig();
+ $rule = new CorsRule();
+ $rule->addAllowedHeader("x-oss-header");
+ $rule->addAllowedOrigin("http://www.b.com");
+ $rule->addAllowedMethod("POST");
+ $rule->setMaxAgeSeconds(10);
+ $corsConfig->addRule($rule);
+
+ try {
+ $ossClient->putBucketCors($bucket, $corsConfig);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+/**
+ * 获取并打印bucket的cors配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function getBucketCors($ossClient, $bucket)
+{
+ $corsConfig = null;
+ try {
+ $corsConfig = $ossClient->getBucketCors($bucket);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+ print($corsConfig->serializeToXml() . "\n");
+}
+
+/**
+ * 删除bucket的所有的cors配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function deleteBucketCors($ossClient, $bucket)
+{
+ try {
+ $ossClient->deleteBucketCors($bucket);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
diff --git a/vendor/aliyuncs/oss-sdk-php/samples/BucketLifecycle.php b/vendor/aliyuncs/oss-sdk-php/samples/BucketLifecycle.php
new file mode 100644
index 000000000..ec0c37f8f
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/samples/BucketLifecycle.php
@@ -0,0 +1,109 @@
+addRule($lifecycleRule);
+$ossClient->putBucketLifecycle($bucket, $lifecycleConfig);
+Common::println("bucket $bucket lifecycleConfig created:" . $lifecycleConfig->serializeToXml());
+
+//获取lifecycle规则
+$lifecycleConfig = $ossClient->getBucketLifecycle($bucket);
+Common::println("bucket $bucket lifecycleConfig fetched:" . $lifecycleConfig->serializeToXml());
+
+//删除bucket的lifecycle配置
+$ossClient->deleteBucketLifecycle($bucket);
+Common::println("bucket $bucket lifecycleConfig deleted");
+
+
+//***************************** 完整用法参考下面函数 ***********************************************
+
+putBucketLifecycle($ossClient, $bucket);
+getBucketLifecycle($ossClient, $bucket);
+deleteBucketLifecycle($ossClient, $bucket);
+getBucketLifecycle($ossClient, $bucket);
+
+/**
+ * 设置bucket的生命周期配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function putBucketLifecycle($ossClient, $bucket)
+{
+ $lifecycleConfig = new LifecycleConfig();
+ $actions = array();
+ $actions[] = new LifecycleAction(OssClient::OSS_LIFECYCLE_EXPIRATION, OssClient::OSS_LIFECYCLE_TIMING_DAYS, 3);
+ $lifecycleRule = new LifecycleRule("delete obsoleted files", "obsoleted/", "Enabled", $actions);
+ $lifecycleConfig->addRule($lifecycleRule);
+ $actions = array();
+ $actions[] = new LifecycleAction(OssClient::OSS_LIFECYCLE_EXPIRATION, OssClient::OSS_LIFECYCLE_TIMING_DATE, '2022-10-12T00:00:00.000Z');
+ $lifecycleRule = new LifecycleRule("delete temporary files", "temporary/", "Enabled", $actions);
+ $lifecycleConfig->addRule($lifecycleRule);
+ try {
+ $ossClient->putBucketLifecycle($bucket, $lifecycleConfig);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+/**
+ * 获取bucket的生命周期配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function getBucketLifecycle($ossClient, $bucket)
+{
+ $lifecycleConfig = null;
+ try {
+ $lifecycleConfig = $ossClient->getBucketLifecycle($bucket);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+ print($lifecycleConfig->serializeToXml() . "\n");
+}
+
+/**
+ * 删除bucket的生命周期配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function deleteBucketLifecycle($ossClient, $bucket)
+{
+ try {
+ $ossClient->deleteBucketLifecycle($bucket);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+
diff --git a/vendor/aliyuncs/oss-sdk-php/samples/BucketLogging.php b/vendor/aliyuncs/oss-sdk-php/samples/BucketLogging.php
new file mode 100644
index 000000000..406e1d472
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/samples/BucketLogging.php
@@ -0,0 +1,95 @@
+putBucketLogging($bucket, $bucket, "access.log", array());
+Common::println("bucket $bucket lifecycleConfig created");
+
+// 获取Bucket访问日志记录规则
+$loggingConfig = $ossClient->getBucketLogging($bucket, array());
+Common::println("bucket $bucket lifecycleConfig fetched:" . $loggingConfig->serializeToXml());
+
+// 删除Bucket访问日志记录规则
+$loggingConfig = $ossClient->getBucketLogging($bucket, array());
+Common::println("bucket $bucket lifecycleConfig deleted");
+
+//******************************* 完整用法参考下面函数 ****************************************************
+
+putBucketLogging($ossClient, $bucket);
+getBucketLogging($ossClient, $bucket);
+deleteBucketLogging($ossClient, $bucket);
+getBucketLogging($ossClient, $bucket);
+
+/**
+ * 设置bucket的Logging配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function putBucketLogging($ossClient, $bucket)
+{
+ $option = array();
+ //访问日志存放在本bucket下
+ $targetBucket = $bucket;
+ $targetPrefix = "access.log";
+
+ try {
+ $ossClient->putBucketLogging($bucket, $targetBucket, $targetPrefix, $option);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+/**
+ * 获取bucket的Logging配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function getBucketLogging($ossClient, $bucket)
+{
+ $loggingConfig = null;
+ $options = array();
+ try {
+ $loggingConfig = $ossClient->getBucketLogging($bucket, $options);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+ print($loggingConfig->serializeToXml() . "\n");
+}
+
+/**
+ * 删除bucket的Logging配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function deleteBucketLogging($ossClient, $bucket)
+{
+ try {
+ $ossClient->deleteBucketLogging($bucket);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/samples/BucketReferer.php b/vendor/aliyuncs/oss-sdk-php/samples/BucketReferer.php
new file mode 100644
index 000000000..3828df696
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/samples/BucketReferer.php
@@ -0,0 +1,101 @@
+setAllowEmptyReferer(true);
+$refererConfig->addReferer("www.aliiyun.com");
+$refererConfig->addReferer("www.aliiyuncs.com");
+$ossClient->putBucketReferer($bucket, $refererConfig);
+Common::println("bucket $bucket refererConfig created:" . $refererConfig->serializeToXml());
+//获取Referer白名单
+$refererConfig = $ossClient->getBucketReferer($bucket);
+Common::println("bucket $bucket refererConfig fetched:" . $refererConfig->serializeToXml());
+
+//删除referer白名单
+$refererConfig = new RefererConfig();
+$ossClient->putBucketReferer($bucket, $refererConfig);
+Common::println("bucket $bucket refererConfig deleted");
+
+
+//******************************* 完整用法参考下面函数 ****************************************************
+
+putBucketReferer($ossClient, $bucket);
+getBucketReferer($ossClient, $bucket);
+deleteBucketReferer($ossClient, $bucket);
+getBucketReferer($ossClient, $bucket);
+
+/**
+ * 设置bucket的防盗链配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function putBucketReferer($ossClient, $bucket)
+{
+ $refererConfig = new RefererConfig();
+ $refererConfig->setAllowEmptyReferer(true);
+ $refererConfig->addReferer("www.aliiyun.com");
+ $refererConfig->addReferer("www.aliiyuncs.com");
+ try {
+ $ossClient->putBucketReferer($bucket, $refererConfig);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+/**
+ * 获取bucket的防盗链配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function getBucketReferer($ossClient, $bucket)
+{
+ $refererConfig = null;
+ try {
+ $refererConfig = $ossClient->getBucketReferer($bucket);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+ print($refererConfig->serializeToXml() . "\n");
+}
+
+/**
+ * 删除bucket的防盗链配置
+ * Referer白名单不能直接清空,只能通过重新设置来覆盖之前的规则。
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function deleteBucketReferer($ossClient, $bucket)
+{
+ $refererConfig = new RefererConfig();
+ try {
+ $ossClient->putBucketReferer($bucket, $refererConfig);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/samples/BucketWebsite.php b/vendor/aliyuncs/oss-sdk-php/samples/BucketWebsite.php
new file mode 100644
index 000000000..54706f834
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/samples/BucketWebsite.php
@@ -0,0 +1,92 @@
+putBucketWebsite($bucket, $websiteConfig);
+Common::println("bucket $bucket websiteConfig created:" . $websiteConfig->serializeToXml());
+
+// 查看Bucket的静态网站托管状态
+$websiteConfig = $ossClient->getBucketWebsite($bucket);
+Common::println("bucket $bucket websiteConfig fetched:" . $websiteConfig->serializeToXml());
+
+// 删除Bucket的静态网站托管模式
+$ossClient->deleteBucketWebsite($bucket);
+Common::println("bucket $bucket websiteConfig deleted");
+
+//******************************* 完整用法参考下面函数 ****************************************************
+
+putBucketWebsite($ossClient, $bucket);
+getBucketWebsite($ossClient, $bucket);
+deleteBucketWebsite($ossClient, $bucket);
+getBucketWebsite($ossClient, $bucket);
+
+/**
+ * 设置bucket的静态网站托管模式配置
+ *
+ * @param $ossClient OssClient
+ * @param $bucket string 存储空间名称
+ * @return null
+ */
+function putBucketWebsite($ossClient, $bucket)
+{
+ $websiteConfig = new WebsiteConfig("index.html", "error.html");
+ try {
+ $ossClient->putBucketWebsite($bucket, $websiteConfig);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+/**
+ * 获取bucket的静态网站托管状态
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function getBucketWebsite($ossClient, $bucket)
+{
+ $websiteConfig = null;
+ try {
+ $websiteConfig = $ossClient->getBucketWebsite($bucket);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+ print($websiteConfig->serializeToXml() . "\n");
+}
+
+/**
+ * 删除bucket的静态网站托管模式配置
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function deleteBucketWebsite($ossClient, $bucket)
+{
+ try {
+ $ossClient->deleteBucketWebsite($bucket);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/samples/Callback.php b/vendor/aliyuncs/oss-sdk-php/samples/Callback.php
new file mode 100644
index 000000000..8612a1c54
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/samples/Callback.php
@@ -0,0 +1,83 @@
+ $url,
+ OssClient::OSS_CALLBACK_VAR => $var
+ );
+$result = $ossClient->putObject($bucket, "b.file", "random content", $options);
+Common::println($result['body']);
+Common::println($result['info']['http_code']);
+
+/**
+ * completeMultipartUpload 使用callback上传内容到oss文件
+ * callbackurl参数指定请求回调的服务器url
+ * callbackbodytype参数可为application/json或application/x-www-form-urlencoded, 可选参数,默认为application/x-www-form-urlencoded
+ * OSS_CALLBACK_VAR参数可以不设置
+ */
+$object = "multipart-callback-test.txt";
+$copiedObject = "multipart-callback-test.txt.copied";
+$ossClient->putObject($bucket, $copiedObject, file_get_contents(__FILE__));
+
+/**
+ * step 1. 初始化一个分块上传事件, 也就是初始化上传Multipart, 获取upload id
+ */
+$upload_id = $ossClient->initiateMultipartUpload($bucket, $object);
+
+/**
+ * step 2. uploadPartCopy
+ */
+$copyId = 1;
+$eTag = $ossClient->uploadPartCopy($bucket, $copiedObject, $bucket, $object, $copyId, $upload_id);
+$upload_parts[] = array(
+ 'PartNumber' => $copyId,
+ 'ETag' => $eTag,
+ );
+$listPartsInfo = $ossClient->listParts($bucket, $object, $upload_id);
+
+/**
+ * step 3.
+ */
+$json =
+ '{
+ "callbackUrl":"callback.oss-demo.com:23450",
+ "callbackHost":"oss-cn-hangzhou.aliyuncs.com",
+ "callbackBody":"{\"mimeType\":${mimeType},\"size\":${size},\"x:var1\":${x:var1},\"x:var2\":${x:var2}}",
+ "callbackBodyType":"application/json"
+ }';
+$var =
+ '{
+ "x:var1":"value1",
+ "x:var2":"值2"
+ }';
+$options = array(OssClient::OSS_CALLBACK => $json,
+ OssClient::OSS_CALLBACK_VAR => $var);
+
+$result = $ossClient->completeMultipartUpload($bucket, $object, $upload_id, $upload_parts, $options);
+Common::println($result['body']);
+Common::println($result['info']['http_code']);
diff --git a/vendor/aliyuncs/oss-sdk-php/samples/Common.php b/vendor/aliyuncs/oss-sdk-php/samples/Common.php
new file mode 100644
index 000000000..f419d1782
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/samples/Common.php
@@ -0,0 +1,84 @@
+getMessage() . "\n");
+ return null;
+ }
+ return $ossClient;
+ }
+
+ public static function getBucketName()
+ {
+ return self::bucket;
+ }
+
+ /**
+ * 工具方法,创建一个存储空间,如果发生异常直接exit
+ */
+ public static function createBucket()
+ {
+ $ossClient = self::getOssClient();
+ if (is_null($ossClient)) exit(1);
+ $bucket = self::getBucketName();
+ $acl = OssClient::OSS_ACL_TYPE_PUBLIC_READ;
+ try {
+ $ossClient->createBucket($bucket, $acl);
+ } catch (OssException $e) {
+
+ $message = $e->getMessage();
+ if (\OSS\Core\OssUtil::startsWith($message, 'http status: 403')) {
+ echo "Please Check your AccessKeyId and AccessKeySecret" . "\n";
+ exit(0);
+ } elseif (strpos($message, "BucketAlreadyExists") !== false) {
+ echo "Bucket already exists. Please check whether the bucket belongs to you, or it was visited with correct endpoint. " . "\n";
+ exit(0);
+ }
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+ }
+
+ public static function println($message)
+ {
+ if (!empty($message)) {
+ echo strval($message) . "\n";
+ }
+ }
+}
+
+Common::createBucket();
diff --git a/vendor/aliyuncs/oss-sdk-php/samples/Config.php b/vendor/aliyuncs/oss-sdk-php/samples/Config.php
new file mode 100644
index 000000000..35c0dc7c4
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/samples/Config.php
@@ -0,0 +1,15 @@
+uploadFile($bucketName, $object, "example.jpg");
+
+// 图片缩放
+$options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $download_file,
+ OssClient::OSS_PROCESS => "image/resize,m_fixed,h_100,w_100", );
+$ossClient->getObject($bucketName, $object, $options);
+printImage("imageResize",$download_file);
+
+// 图片裁剪
+$options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $download_file,
+ OssClient::OSS_PROCESS => "image/crop,w_100,h_100,x_100,y_100,r_1", );
+$ossClient->getObject($bucketName, $object, $options);
+printImage("iamgeCrop", $download_file);
+
+// 图片旋转
+$options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $download_file,
+ OssClient::OSS_PROCESS => "image/rotate,90", );
+$ossClient->getObject($bucketName, $object, $options);
+printImage("imageRotate", $download_file);
+
+// 图片锐化
+$options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $download_file,
+ OssClient::OSS_PROCESS => "image/sharpen,100", );
+$ossClient->getObject($bucketName, $object, $options);
+printImage("imageSharpen", $download_file);
+
+// 图片水印
+$options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $download_file,
+ OssClient::OSS_PROCESS => "image/watermark,text_SGVsbG8g5Zu-54mH5pyN5YqhIQ", );
+$ossClient->getObject($bucketName, $object, $options);
+printImage("imageWatermark", $download_file);
+
+// 图片格式转换
+$options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $download_file,
+ OssClient::OSS_PROCESS => "image/format,png", );
+$ossClient->getObject($bucketName, $object, $options);
+printImage("imageFormat", $download_file);
+
+// 获取图片信息
+$options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $download_file,
+ OssClient::OSS_PROCESS => "image/info", );
+$ossClient->getObject($bucketName, $object, $options);
+printImage("imageInfo", $download_file);
+
+
+/**
+ * 生成一个带签名的可用于浏览器直接打开的url, URL的有效期是3600秒
+ */
+ $timeout = 3600;
+$options = array(
+ OssClient::OSS_PROCESS => "image/resize,m_lfit,h_100,w_100",
+ );
+$signedUrl = $ossClient->signUrl($bucketName, $object, $timeout, "GET", $options);
+Common::println("rtmp url: \n" . $signedUrl);
+
+//最后删除上传的$object
+$ossClient->deleteObject($bucketName, $object);
+
+function printImage($func, $imageFile)
+{
+ $array = getimagesize($imageFile);
+ Common::println("$func, image width: " . $array[0]);
+ Common::println("$func, image height: " . $array[1]);
+ Common::println("$func, image type: " . ($array[2] === 2 ? 'jpg' : 'png'));
+ Common::println("$func, image size: " . ceil(filesize($imageFile)));
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/samples/LiveChannel.php b/vendor/aliyuncs/oss-sdk-php/samples/LiveChannel.php
new file mode 100644
index 000000000..2f7d3a8b9
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/samples/LiveChannel.php
@@ -0,0 +1,125 @@
+ 'live channel test',
+ 'type' => 'HLS',
+ 'fragDuration' => 10,
+ 'fragCount' => 5,
+ 'playListName' => 'hello.m3u8'
+ ));
+$info = $ossClient->putBucketLiveChannel($bucket, 'test_rtmp_live', $config);
+Common::println("bucket $bucket liveChannel created:\n" .
+"live channel name: ". $info->getName() . "\n" .
+"live channel description: ". $info->getDescription() . "\n" .
+"publishurls: ". $info->getPublishUrls()[0] . "\n" .
+"playurls: ". $info->getPlayUrls()[0] . "\n");
+
+/**
+ 对创建好的频道,可以使用listBucketLiveChannels来进行列举已达到管理的目的。
+ prefix可以按照前缀过滤list出来的频道。
+ max_keys表示迭代器内部一次list出来的频道的最大数量,这个值最大不能超过1000,不填写的话默认为100。
+ */
+$list = $ossClient->listBucketLiveChannels($bucket);
+Common::println("bucket $bucket listLiveChannel:\n" .
+"list live channel prefix: ". $list->getPrefix() . "\n" .
+"list live channel marker: ". $list->getMarker() . "\n" .
+"list live channel maxkey: ". $list->getMaxKeys() . "\n" .
+"list live channel IsTruncated: ". $list->getIsTruncated() . "\n" .
+"list live channel getNextMarker: ". $list->getNextMarker() . "\n");
+
+foreach($list->getChannelList() as $list)
+{
+ Common::println("bucket $bucket listLiveChannel:\n" .
+ "list live channel IsTruncated: ". $list->getName() . "\n" .
+ "list live channel Description: ". $list->getDescription() . "\n" .
+ "list live channel Status: ". $list->getStatus() . "\n" .
+ "list live channel getNextMarker: ". $list->getLastModified() . "\n");
+}
+/**
+ 创建直播频道之后拿到推流用的play_url(rtmp推流的url,如果Bucket不是公共读写权限那么还需要带上签名,见下文示例)和推流用的publish_url(推流产生的m3u8文件的url)
+ */
+$play_url = $ossClient->signRtmpUrl($bucket, "test_rtmp_live", 3600, array('params' => array('playlistName' => 'playlist.m3u8')));
+Common::println("bucket $bucket rtmp url: \n" . $play_url);
+$play_url = $ossClient->signRtmpUrl($bucket, "test_rtmp_live", 3600);
+Common::println("bucket $bucket rtmp url: \n" . $play_url);
+
+/**
+ 创建好直播频道,如果想把这个频道禁用掉(断掉正在推的流或者不再允许向一个地址推流),应该使用putLiveChannelStatus接口,将频道的status改成“Disabled”,如果要将一个禁用状态的频道启用,那么也是调用这个接口,将status改成“Enabled”
+ */
+$resp = $ossClient->putLiveChannelStatus($bucket, "test_rtmp_live", "enabled");
+
+/**
+ 创建好直播频道之后调用getLiveChannelInfo可以得到频道相关的信息
+ */
+$info = $ossClient->getLiveChannelInfo($bucket, 'test_rtmp_live');
+Common::println("bucket $bucket LiveChannelInfo:\n" .
+"live channel info description: ". $info->getDescription() . "\n" .
+"live channel info status: ". $info->getStatus() . "\n" .
+"live channel info type: ". $info->getType() . "\n" .
+"live channel info fragDuration: ". $info->getFragDuration() . "\n" .
+"live channel info fragCount: ". $info->getFragCount() . "\n" .
+"live channel info playListName: ". $info->getPlayListName() . "\n");
+
+/**
+ 如果想查看一个频道历史推流记录,可以调用getLiveChannelHistory。目前最多可以看到10次推流的记录
+ */
+$history = $ossClient->getLiveChannelHistory($bucket, "test_rtmp_live");
+if (count($history->getLiveRecordList()) != 0)
+{
+ foreach($history->getLiveRecordList() as $recordList)
+ {
+ Common::println("bucket $bucket liveChannelHistory:\n" .
+ "live channel history startTime: ". $recordList->getStartTime() . "\n" .
+ "live channel history endTime: ". $recordList->getEndTime() . "\n" .
+ "live channel history remoteAddr: ". $recordList->getRemoteAddr() . "\n");
+ }
+}
+
+/**
+ 对于正在推流的频道调用get_live_channel_stat可以获得流的状态信息。
+ 如果频道正在推流,那么stat_result中的所有字段都有意义。
+ 如果频道闲置或者处于“Disabled”状态,那么status为“Idle”或“Disabled”,其他字段无意义。
+ */
+$status = $ossClient->getLiveChannelStatus($bucket, "test_rtmp_live");
+Common::println("bucket $bucket listLiveChannel:\n" .
+"live channel status status: ". $status->getStatus() . "\n" .
+"live channel status ConnectedTime: ". $status->getConnectedTime() . "\n" .
+"live channel status VideoWidth: ". $status->getVideoWidth() . "\n" .
+"live channel status VideoHeight: ". $status->getVideoHeight() . "\n" .
+"live channel status VideoFrameRate: ". $status->getVideoFrameRate() . "\n" .
+"live channel status VideoBandwidth: ". $status->getVideoBandwidth() . "\n" .
+"live channel status VideoCodec: ". $status->getVideoCodec() . "\n" .
+"live channel status AudioBandwidth: ". $status->getAudioBandwidth() . "\n" .
+"live channel status AudioSampleRate: ". $status->getAudioSampleRate() . "\n" .
+"live channel status AdioCodec: ". $status->getAudioCodec() . "\n");
+
+/**
+ * 如果希望利用直播推流产生的ts文件生成一个点播列表,可以使用postVodPlaylist方法。
+ * 指定起始时间为当前时间减去60秒,结束时间为当前时间,这意味着将生成一个长度为60秒的点播视频。
+ * 播放列表指定为“vod_playlist.m3u8”,也就是说这个接口调用成功之后会在OSS上生成一个名叫“vod_playlist.m3u8”的播放列表文件。
+ */
+$current_time = time();
+$ossClient->postVodPlaylist($bucket,
+ "test_rtmp_live", "vod_playlist.m3u8",
+ array('StartTime' => $current_time - 60,
+ 'EndTime' => $current_time)
+);
+
+/**
+ * 如果一个直播频道已经不打算再使用了,那么可以调用delete_live_channel来删除频道。
+ */
+$ossClient->deleteBucketLiveChannel($bucket, "test_rtmp_live");
diff --git a/vendor/aliyuncs/oss-sdk-php/samples/MultipartUpload.php b/vendor/aliyuncs/oss-sdk-php/samples/MultipartUpload.php
new file mode 100644
index 000000000..e8d69a3ee
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/samples/MultipartUpload.php
@@ -0,0 +1,182 @@
+multiuploadFile($bucket, "file.php", __FILE__, array());
+Common::println("local file " . __FILE__ . " is uploaded to the bucket $bucket, file.php");
+
+
+// 上传本地目录到bucket内的targetdir子目录中
+$ossClient->uploadDir($bucket, "targetdir", __DIR__);
+Common::println("local dir " . __DIR__ . " is uploaded to the bucket $bucket, targetdir/");
+
+
+// 列出当前未完成的分片上传
+$listMultipartUploadInfo = $ossClient->listMultipartUploads($bucket, array());
+
+
+//******************************* 完整用法参考下面函数 ****************************************************
+
+multiuploadFile($ossClient, $bucket);
+putObjectByRawApis($ossClient, $bucket);
+uploadDir($ossClient, $bucket);
+listMultipartUploads($ossClient, $bucket);
+
+/**
+ * 通过multipart上传文件
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function multiuploadFile($ossClient, $bucket)
+{
+ $object = "test/multipart-test.txt";
+ $file = __FILE__;
+ $options = array();
+
+ try {
+ $ossClient->multiuploadFile($bucket, $object, $file, $options);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+/**
+ * 使用基本的api分阶段进行分片上传
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @throws OssException
+ */
+function putObjectByRawApis($ossClient, $bucket)
+{
+ $object = "test/multipart-test.txt";
+ /**
+ * step 1. 初始化一个分块上传事件, 也就是初始化上传Multipart, 获取upload id
+ */
+ try {
+ $uploadId = $ossClient->initiateMultipartUpload($bucket, $object);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": initiateMultipartUpload FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": initiateMultipartUpload OK" . "\n");
+ /*
+ * step 2. 上传分片
+ */
+ $partSize = 10 * 1024 * 1024;
+ $uploadFile = __FILE__;
+ $uploadFileSize = filesize($uploadFile);
+ $pieces = $ossClient->generateMultiuploadParts($uploadFileSize, $partSize);
+ $responseUploadPart = array();
+ $uploadPosition = 0;
+ $isCheckMd5 = true;
+ foreach ($pieces as $i => $piece) {
+ $fromPos = $uploadPosition + (integer)$piece[$ossClient::OSS_SEEK_TO];
+ $toPos = (integer)$piece[$ossClient::OSS_LENGTH] + $fromPos - 1;
+ $upOptions = array(
+ $ossClient::OSS_FILE_UPLOAD => $uploadFile,
+ $ossClient::OSS_PART_NUM => ($i + 1),
+ $ossClient::OSS_SEEK_TO => $fromPos,
+ $ossClient::OSS_LENGTH => $toPos - $fromPos + 1,
+ $ossClient::OSS_CHECK_MD5 => $isCheckMd5,
+ );
+ if ($isCheckMd5) {
+ $contentMd5 = OssUtil::getMd5SumForFile($uploadFile, $fromPos, $toPos);
+ $upOptions[$ossClient::OSS_CONTENT_MD5] = $contentMd5;
+ }
+ //2. 将每一分片上传到OSS
+ try {
+ $responseUploadPart[] = $ossClient->uploadPart($bucket, $object, $uploadId, $upOptions);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": initiateMultipartUpload, uploadPart - part#{$i} FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ printf(__FUNCTION__ . ": initiateMultipartUpload, uploadPart - part#{$i} OK\n");
+ }
+ $uploadParts = array();
+ foreach ($responseUploadPart as $i => $eTag) {
+ $uploadParts[] = array(
+ 'PartNumber' => ($i + 1),
+ 'ETag' => $eTag,
+ );
+ }
+ /**
+ * step 3. 完成上传
+ */
+ try {
+ $ossClient->completeMultipartUpload($bucket, $object, $uploadId, $uploadParts);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": completeMultipartUpload FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ printf(__FUNCTION__ . ": completeMultipartUpload OK\n");
+}
+
+/**
+ * 按照目录上传文件
+ *
+ * @param OssClient $ossClient OssClient
+ * @param string $bucket 存储空间名称
+ *
+ */
+function uploadDir($ossClient, $bucket)
+{
+ $localDirectory = ".";
+ $prefix = "samples/codes";
+ try {
+ $ossClient->uploadDir($bucket, $prefix, $localDirectory);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ printf(__FUNCTION__ . ": completeMultipartUpload OK\n");
+}
+
+/**
+ * 获取当前未完成的分片上传列表
+ *
+ * @param $ossClient OssClient
+ * @param $bucket string
+ */
+function listMultipartUploads($ossClient, $bucket)
+{
+ $options = array(
+ 'max-uploads' => 100,
+ 'key-marker' => '',
+ 'prefix' => '',
+ 'upload-id-marker' => ''
+ );
+ try {
+ $listMultipartUploadInfo = $ossClient->listMultipartUploads($bucket, $options);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": listMultipartUploads FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ printf(__FUNCTION__ . ": listMultipartUploads OK\n");
+ $listUploadInfo = $listMultipartUploadInfo->getUploads();
+ var_dump($listUploadInfo);
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/samples/Object.php b/vendor/aliyuncs/oss-sdk-php/samples/Object.php
new file mode 100644
index 000000000..68e1ed37d
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/samples/Object.php
@@ -0,0 +1,451 @@
+putObject($bucket, "b.file", "hi, oss");
+Common::println("b.file is created");
+Common::println($result['x-oss-request-id']);
+Common::println($result['etag']);
+Common::println($result['content-md5']);
+Common::println($result['body']);
+
+// 上传本地文件
+$result = $ossClient->uploadFile($bucket, "c.file", __FILE__);
+Common::println("c.file is created");
+Common::println("b.file is created");
+Common::println($result['x-oss-request-id']);
+Common::println($result['etag']);
+Common::println($result['content-md5']);
+Common::println($result['body']);
+
+// 下载object到本地变量
+$content = $ossClient->getObject($bucket, "b.file");
+Common::println("b.file is fetched, the content is: " . $content);
+
+
+// 下载object到本地文件
+$options = array(
+ OssClient::OSS_FILE_DOWNLOAD => "./c.file.localcopy",
+);
+$ossClient->getObject($bucket, "c.file", $options);
+Common::println("b.file is fetched to the local file: c.file.localcopy");
+Common::println("b.file is created");
+
+// 拷贝object
+$result = $ossClient->copyObject($bucket, "c.file", $bucket, "c.file.copy");
+Common::println("lastModifiedTime: " . $result[0]);
+Common::println("ETag: " . $result[1]);
+
+// 判断object是否存在
+$doesExist = $ossClient->doesObjectExist($bucket, "c.file.copy");
+Common::println("file c.file.copy exist? " . ($doesExist ? "yes" : "no"));
+
+// 删除object
+$result = $ossClient->deleteObject($bucket, "c.file.copy");
+Common::println("c.file.copy is deleted");
+Common::println("b.file is created");
+Common::println($result['x-oss-request-id']);
+
+// 判断object是否存在
+$doesExist = $ossClient->doesObjectExist($bucket, "c.file.copy");
+Common::println("file c.file.copy exist? " . ($doesExist ? "yes" : "no"));
+
+// 批量删除object
+$result = $ossClient->deleteObjects($bucket, array("b.file", "c.file"));
+foreach($result as $object)
+ Common::println($object);
+
+sleep(2);
+unlink("c.file.localcopy");
+
+//******************************* 完整用法参考下面函数 ****************************************************
+
+listObjects($ossClient, $bucket);
+listAllObjects($ossClient, $bucket);
+createObjectDir($ossClient, $bucket);
+putObject($ossClient, $bucket);
+uploadFile($ossClient, $bucket);
+getObject($ossClient, $bucket);
+getObjectToLocalFile($ossClient, $bucket);
+copyObject($ossClient, $bucket);
+modifyMetaForObject($ossClient, $bucket);
+getObjectMeta($ossClient, $bucket);
+deleteObject($ossClient, $bucket);
+deleteObjects($ossClient, $bucket);
+doesObjectExist($ossClient, $bucket);
+
+/**
+ * 创建虚拟目录
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function createObjectDir($ossClient, $bucket)
+{
+ try {
+ $ossClient->createObjectDir($bucket, "dir");
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+/**
+ * 把本地变量的内容到文件
+ *
+ * 简单上传,上传指定变量的内存值作为object的内容
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function putObject($ossClient, $bucket)
+{
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+ $content = file_get_contents(__FILE__);
+ $options = array();
+ try {
+ $ossClient->putObject($bucket, $object, $content, $options);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+
+/**
+ * 上传指定的本地文件内容
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function uploadFile($ossClient, $bucket)
+{
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+ $filePath = __FILE__;
+ $options = array();
+
+ try {
+ $ossClient->uploadFile($bucket, $object, $filePath, $options);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+/**
+ * 列出Bucket内所有目录和文件, 注意如果符合条件的文件数目超过设置的max-keys, 用户需要使用返回的nextMarker作为入参,通过
+ * 循环调用ListObjects得到所有的文件,具体操作见下面的 listAllObjects 示例
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function listObjects($ossClient, $bucket)
+{
+ $prefix = 'oss-php-sdk-test/';
+ $delimiter = '/';
+ $nextMarker = '';
+ $maxkeys = 1000;
+ $options = array(
+ 'delimiter' => $delimiter,
+ 'prefix' => $prefix,
+ 'max-keys' => $maxkeys,
+ 'marker' => $nextMarker,
+ );
+ try {
+ $listObjectInfo = $ossClient->listObjects($bucket, $options);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+ $objectList = $listObjectInfo->getObjectList(); // 文件列表
+ $prefixList = $listObjectInfo->getPrefixList(); // 目录列表
+ if (!empty($objectList)) {
+ print("objectList:\n");
+ foreach ($objectList as $objectInfo) {
+ print($objectInfo->getKey() . "\n");
+ }
+ }
+ if (!empty($prefixList)) {
+ print("prefixList: \n");
+ foreach ($prefixList as $prefixInfo) {
+ print($prefixInfo->getPrefix() . "\n");
+ }
+ }
+}
+
+/**
+ * 列出Bucket内所有目录和文件, 根据返回的nextMarker循环得到所有Objects
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function listAllObjects($ossClient, $bucket)
+{
+ //构造dir下的文件和虚拟目录
+ for ($i = 0; $i < 100; $i += 1) {
+ $ossClient->putObject($bucket, "dir/obj" . strval($i), "hi");
+ $ossClient->createObjectDir($bucket, "dir/obj" . strval($i));
+ }
+
+ $prefix = 'dir/';
+ $delimiter = '/';
+ $nextMarker = '';
+ $maxkeys = 30;
+
+ while (true) {
+ $options = array(
+ 'delimiter' => $delimiter,
+ 'prefix' => $prefix,
+ 'max-keys' => $maxkeys,
+ 'marker' => $nextMarker,
+ );
+ var_dump($options);
+ try {
+ $listObjectInfo = $ossClient->listObjects($bucket, $options);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ // 得到nextMarker,从上一次listObjects读到的最后一个文件的下一个文件开始继续获取文件列表
+ $nextMarker = $listObjectInfo->getNextMarker();
+ $listObject = $listObjectInfo->getObjectList();
+ $listPrefix = $listObjectInfo->getPrefixList();
+ var_dump(count($listObject));
+ var_dump(count($listPrefix));
+ if ($nextMarker === '') {
+ break;
+ }
+ }
+}
+
+/**
+ * 获取object的内容
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function getObject($ossClient, $bucket)
+{
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+ $options = array();
+ try {
+ $content = $ossClient->getObject($bucket, $object, $options);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+ if (file_get_contents(__FILE__) === $content) {
+ print(__FUNCTION__ . ": FileContent checked OK" . "\n");
+ } else {
+ print(__FUNCTION__ . ": FileContent checked FAILED" . "\n");
+ }
+}
+
+/**
+ * get_object_to_local_file
+ *
+ * 获取object
+ * 将object下载到指定的文件
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function getObjectToLocalFile($ossClient, $bucket)
+{
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+ $localfile = "upload-test-object-name.txt";
+ $options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $localfile,
+ );
+
+ try {
+ $ossClient->getObject($bucket, $object, $options);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK, please check localfile: 'upload-test-object-name.txt'" . "\n");
+ if (file_get_contents($localfile) === file_get_contents(__FILE__)) {
+ print(__FUNCTION__ . ": FileContent checked OK" . "\n");
+ } else {
+ print(__FUNCTION__ . ": FileContent checked FAILED" . "\n");
+ }
+ if (file_exists($localfile)) {
+ unlink($localfile);
+ }
+}
+
+/**
+ * 拷贝object
+ * 当目的object和源object完全相同时,表示修改object的meta信息
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function copyObject($ossClient, $bucket)
+{
+ $fromBucket = $bucket;
+ $fromObject = "oss-php-sdk-test/upload-test-object-name.txt";
+ $toBucket = $bucket;
+ $toObject = $fromObject . '.copy';
+ $options = array();
+
+ try {
+ $ossClient->copyObject($fromBucket, $fromObject, $toBucket, $toObject, $options);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+/**
+ * 修改Object Meta
+ * 利用copyObject接口的特性:当目的object和源object完全相同时,表示修改object的meta信息
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function modifyMetaForObject($ossClient, $bucket)
+{
+ $fromBucket = $bucket;
+ $fromObject = "oss-php-sdk-test/upload-test-object-name.txt";
+ $toBucket = $bucket;
+ $toObject = $fromObject;
+ $copyOptions = array(
+ OssClient::OSS_HEADERS => array(
+ 'Cache-Control' => 'max-age=60',
+ 'Content-Disposition' => 'attachment; filename="xxxxxx"',
+ ),
+ );
+ try {
+ $ossClient->copyObject($fromBucket, $fromObject, $toBucket, $toObject, $copyOptions);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+/**
+ * 获取object meta, 也就是getObjectMeta接口
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function getObjectMeta($ossClient, $bucket)
+{
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+ try {
+ $objectMeta = $ossClient->getObjectMeta($bucket, $object);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+ if (isset($objectMeta[strtolower('Content-Disposition')]) &&
+ 'attachment; filename="xxxxxx"' === $objectMeta[strtolower('Content-Disposition')]
+ ) {
+ print(__FUNCTION__ . ": ObjectMeta checked OK" . "\n");
+ } else {
+ print(__FUNCTION__ . ": ObjectMeta checked FAILED" . "\n");
+ }
+}
+
+/**
+ * 删除object
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function deleteObject($ossClient, $bucket)
+{
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+ try {
+ $ossClient->deleteObject($bucket, $object);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+
+/**
+ * 批量删除object
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function deleteObjects($ossClient, $bucket)
+{
+ $objects = array();
+ $objects[] = "oss-php-sdk-test/upload-test-object-name.txt";
+ $objects[] = "oss-php-sdk-test/upload-test-object-name.txt.copy";
+ try {
+ $ossClient->deleteObjects($bucket, $objects);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+}
+
+/**
+ * 判断object是否存在
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ */
+function doesObjectExist($ossClient, $bucket)
+{
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+ try {
+ $exist = $ossClient->doesObjectExist($bucket, $object);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+ var_dump($exist);
+}
+
diff --git a/vendor/aliyuncs/oss-sdk-php/samples/RunAll.php b/vendor/aliyuncs/oss-sdk-php/samples/RunAll.php
new file mode 100644
index 000000000..a4d6d9b9c
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/samples/RunAll.php
@@ -0,0 +1,13 @@
+uploadFile($bucket, "a.file", __FILE__);
+
+// 生成GetObject的签名url,用户可以使用这个url直接在浏览器下载
+$signedUrl = $ossClient->signUrl($bucket, "a.file", 3600);
+Common::println($signedUrl);
+
+// 生成用于putObject的签名URL,用户可以直接用put方法使用这个url上传文件到 "a.file"
+$signedUrl = $ossClient->signUrl($bucket, "a.file", "3600", "PUT");
+Common::println($signedUrl);
+
+// 生成从本地文件上传PutObject的签名url, 用户可以直接使用这个url把本地文件上传到 "a.file"
+$signedUrl = $ossClient->signUrl($bucket, "a.file", 3600, "PUT", array('Content-Type' => 'txt'));
+Common::println($signedUrl);
+
+//******************************* 完整用法参考下面函数 ****************************************************
+
+getSignedUrlForPuttingObject($ossClient, $bucket);
+getSignedUrlForPuttingObjectFromFile($ossClient, $bucket);
+getSignedUrlForGettingObject($ossClient, $bucket);
+
+/**
+ * 生成GetObject的签名url,主要用于私有权限下的读访问控制
+ *
+ * @param $ossClient OssClient OssClient实例
+ * @param $bucket string 存储空间名称
+ * @return null
+ */
+function getSignedUrlForGettingObject($ossClient, $bucket)
+{
+ $object = "test/test-signature-test-upload-and-download.txt";
+ $timeout = 3600;
+ try {
+ $signedUrl = $ossClient->signUrl($bucket, $object, $timeout);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": signedUrl: " . $signedUrl . "\n");
+ /**
+ * 可以类似的代码来访问签名的URL,也可以输入到浏览器中去访问
+ */
+ $request = new RequestCore($signedUrl);
+ $request->set_method('GET');
+ $request->add_header('Content-Type', '');
+ $request->send_request();
+ $res = new ResponseCore($request->get_response_header(), $request->get_response_body(), $request->get_response_code());
+ if ($res->isOK()) {
+ print(__FUNCTION__ . ": OK" . "\n");
+ } else {
+ print(__FUNCTION__ . ": FAILED" . "\n");
+ };
+}
+
+/**
+ * 生成PutObject的签名url,主要用于私有权限下的写访问控制
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @return null
+ * @throws OssException
+ */
+function getSignedUrlForPuttingObject($ossClient, $bucket)
+{
+ $object = "test/test-signature-test-upload-and-download.txt";
+ $timeout = 3600;
+ $options = NULL;
+ try {
+ $signedUrl = $ossClient->signUrl($bucket, $object, $timeout, "PUT");
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": signedUrl: " . $signedUrl . "\n");
+ $content = file_get_contents(__FILE__);
+
+ $request = new RequestCore($signedUrl);
+ $request->set_method('PUT');
+ $request->add_header('Content-Type', '');
+ $request->add_header('Content-Length', strlen($content));
+ $request->set_body($content);
+ $request->send_request();
+ $res = new ResponseCore($request->get_response_header(),
+ $request->get_response_body(), $request->get_response_code());
+ if ($res->isOK()) {
+ print(__FUNCTION__ . ": OK" . "\n");
+ } else {
+ print(__FUNCTION__ . ": FAILED" . "\n");
+ };
+}
+
+/**
+ * 生成PutObject的签名url,主要用于私有权限下的写访问控制, 用户可以利用生成的signedUrl
+ * 从文件上传文件
+ *
+ * @param OssClient $ossClient OssClient实例
+ * @param string $bucket 存储空间名称
+ * @throws OssException
+ */
+function getSignedUrlForPuttingObjectFromFile($ossClient, $bucket)
+{
+ $file = __FILE__;
+ $object = "test/test-signature-test-upload-and-download.txt";
+ $timeout = 3600;
+ $options = array('Content-Type' => 'txt');
+ try {
+ $signedUrl = $ossClient->signUrl($bucket, $object, $timeout, "PUT", $options);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": signedUrl: " . $signedUrl . "\n");
+
+ $request = new RequestCore($signedUrl);
+ $request->set_method('PUT');
+ $request->add_header('Content-Type', 'txt');
+ $request->set_read_file($file);
+ $request->set_read_stream_size(filesize($file));
+ $request->send_request();
+ $res = new ResponseCore($request->get_response_header(),
+ $request->get_response_body(), $request->get_response_code());
+ if ($res->isOK()) {
+ print(__FUNCTION__ . ": OK" . "\n");
+ } else {
+ print(__FUNCTION__ . ": FAILED" . "\n");
+ };
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Core/MimeTypes.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Core/MimeTypes.php
new file mode 100644
index 000000000..e9b88ffa8
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Core/MimeTypes.php
@@ -0,0 +1,262 @@
+ 1) {
+ $ext = strtolower(end($parts));
+ if (isset(self::$mime_types[$ext])) {
+ return self::$mime_types[$ext];
+ }
+ }
+
+ return null;
+ }
+
+ private static $mime_types = array(
+ 'xlsx' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
+ 'xltx' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.template',
+ 'potx' => 'application/vnd.openxmlformats-officedocument.presentationml.template',
+ 'ppsx' => 'application/vnd.openxmlformats-officedocument.presentationml.slideshow',
+ 'pptx' => 'application/vnd.openxmlformats-officedocument.presentationml.presentation',
+ 'sldx' => 'application/vnd.openxmlformats-officedocument.presentationml.slide',
+ 'docx' => 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
+ 'dotx' => 'application/vnd.openxmlformats-officedocument.wordprocessingml.template',
+ 'xlam' => 'application/vnd.ms-excel.addin.macroEnabled.12',
+ 'xlsb' => 'application/vnd.ms-excel.sheet.binary.macroEnabled.12',
+ 'apk' => 'application/vnd.android.package-archive',
+ 'hqx' => 'application/mac-binhex40',
+ 'cpt' => 'application/mac-compactpro',
+ 'doc' => 'application/msword',
+ 'ogg' => 'audio/ogg',
+ 'pdf' => 'application/pdf',
+ 'rtf' => 'text/rtf',
+ 'mif' => 'application/vnd.mif',
+ 'xls' => 'application/vnd.ms-excel',
+ 'ppt' => 'application/vnd.ms-powerpoint',
+ 'odc' => 'application/vnd.oasis.opendocument.chart',
+ 'odb' => 'application/vnd.oasis.opendocument.database',
+ 'odf' => 'application/vnd.oasis.opendocument.formula',
+ 'odg' => 'application/vnd.oasis.opendocument.graphics',
+ 'otg' => 'application/vnd.oasis.opendocument.graphics-template',
+ 'odi' => 'application/vnd.oasis.opendocument.image',
+ 'odp' => 'application/vnd.oasis.opendocument.presentation',
+ 'otp' => 'application/vnd.oasis.opendocument.presentation-template',
+ 'ods' => 'application/vnd.oasis.opendocument.spreadsheet',
+ 'ots' => 'application/vnd.oasis.opendocument.spreadsheet-template',
+ 'odt' => 'application/vnd.oasis.opendocument.text',
+ 'odm' => 'application/vnd.oasis.opendocument.text-master',
+ 'ott' => 'application/vnd.oasis.opendocument.text-template',
+ 'oth' => 'application/vnd.oasis.opendocument.text-web',
+ 'sxw' => 'application/vnd.sun.xml.writer',
+ 'stw' => 'application/vnd.sun.xml.writer.template',
+ 'sxc' => 'application/vnd.sun.xml.calc',
+ 'stc' => 'application/vnd.sun.xml.calc.template',
+ 'sxd' => 'application/vnd.sun.xml.draw',
+ 'std' => 'application/vnd.sun.xml.draw.template',
+ 'sxi' => 'application/vnd.sun.xml.impress',
+ 'sti' => 'application/vnd.sun.xml.impress.template',
+ 'sxg' => 'application/vnd.sun.xml.writer.global',
+ 'sxm' => 'application/vnd.sun.xml.math',
+ 'sis' => 'application/vnd.symbian.install',
+ 'wbxml' => 'application/vnd.wap.wbxml',
+ 'wmlc' => 'application/vnd.wap.wmlc',
+ 'wmlsc' => 'application/vnd.wap.wmlscriptc',
+ 'bcpio' => 'application/x-bcpio',
+ 'torrent' => 'application/x-bittorrent',
+ 'bz2' => 'application/x-bzip2',
+ 'vcd' => 'application/x-cdlink',
+ 'pgn' => 'application/x-chess-pgn',
+ 'cpio' => 'application/x-cpio',
+ 'csh' => 'application/x-csh',
+ 'dvi' => 'application/x-dvi',
+ 'spl' => 'application/x-futuresplash',
+ 'gtar' => 'application/x-gtar',
+ 'hdf' => 'application/x-hdf',
+ 'jar' => 'application/java-archive',
+ 'jnlp' => 'application/x-java-jnlp-file',
+ 'js' => 'application/javascript',
+ 'json' => 'application/json',
+ 'ksp' => 'application/x-kspread',
+ 'chrt' => 'application/x-kchart',
+ 'kil' => 'application/x-killustrator',
+ 'latex' => 'application/x-latex',
+ 'rpm' => 'application/x-rpm',
+ 'sh' => 'application/x-sh',
+ 'shar' => 'application/x-shar',
+ 'swf' => 'application/x-shockwave-flash',
+ 'sit' => 'application/x-stuffit',
+ 'sv4cpio' => 'application/x-sv4cpio',
+ 'sv4crc' => 'application/x-sv4crc',
+ 'tar' => 'application/x-tar',
+ 'tcl' => 'application/x-tcl',
+ 'tex' => 'application/x-tex',
+ 'man' => 'application/x-troff-man',
+ 'me' => 'application/x-troff-me',
+ 'ms' => 'application/x-troff-ms',
+ 'ustar' => 'application/x-ustar',
+ 'src' => 'application/x-wais-source',
+ 'zip' => 'application/zip',
+ 'm3u' => 'audio/x-mpegurl',
+ 'ra' => 'audio/x-pn-realaudio',
+ 'wav' => 'audio/x-wav',
+ 'wma' => 'audio/x-ms-wma',
+ 'wax' => 'audio/x-ms-wax',
+ 'pdb' => 'chemical/x-pdb',
+ 'xyz' => 'chemical/x-xyz',
+ 'bmp' => 'image/bmp',
+ 'gif' => 'image/gif',
+ 'ief' => 'image/ief',
+ 'png' => 'image/png',
+ 'wbmp' => 'image/vnd.wap.wbmp',
+ 'ras' => 'image/x-cmu-raster',
+ 'pnm' => 'image/x-portable-anymap',
+ 'pbm' => 'image/x-portable-bitmap',
+ 'pgm' => 'image/x-portable-graymap',
+ 'ppm' => 'image/x-portable-pixmap',
+ 'rgb' => 'image/x-rgb',
+ 'xbm' => 'image/x-xbitmap',
+ 'xpm' => 'image/x-xpixmap',
+ 'xwd' => 'image/x-xwindowdump',
+ 'css' => 'text/css',
+ 'rtx' => 'text/richtext',
+ 'tsv' => 'text/tab-separated-values',
+ 'jad' => 'text/vnd.sun.j2me.app-descriptor',
+ 'wml' => 'text/vnd.wap.wml',
+ 'wmls' => 'text/vnd.wap.wmlscript',
+ 'etx' => 'text/x-setext',
+ 'mxu' => 'video/vnd.mpegurl',
+ 'flv' => 'video/x-flv',
+ 'wm' => 'video/x-ms-wm',
+ 'wmv' => 'video/x-ms-wmv',
+ 'wmx' => 'video/x-ms-wmx',
+ 'wvx' => 'video/x-ms-wvx',
+ 'avi' => 'video/x-msvideo',
+ 'movie' => 'video/x-sgi-movie',
+ 'ice' => 'x-conference/x-cooltalk',
+ '3gp' => 'video/3gpp',
+ 'ai' => 'application/postscript',
+ 'aif' => 'audio/x-aiff',
+ 'aifc' => 'audio/x-aiff',
+ 'aiff' => 'audio/x-aiff',
+ 'asc' => 'text/plain',
+ 'atom' => 'application/atom+xml',
+ 'au' => 'audio/basic',
+ 'bin' => 'application/octet-stream',
+ 'cdf' => 'application/x-netcdf',
+ 'cgm' => 'image/cgm',
+ 'class' => 'application/octet-stream',
+ 'dcr' => 'application/x-director',
+ 'dif' => 'video/x-dv',
+ 'dir' => 'application/x-director',
+ 'djv' => 'image/vnd.djvu',
+ 'djvu' => 'image/vnd.djvu',
+ 'dll' => 'application/octet-stream',
+ 'dmg' => 'application/octet-stream',
+ 'dms' => 'application/octet-stream',
+ 'dtd' => 'application/xml-dtd',
+ 'dv' => 'video/x-dv',
+ 'dxr' => 'application/x-director',
+ 'eps' => 'application/postscript',
+ 'exe' => 'application/octet-stream',
+ 'ez' => 'application/andrew-inset',
+ 'gram' => 'application/srgs',
+ 'grxml' => 'application/srgs+xml',
+ 'gz' => 'application/x-gzip',
+ 'htm' => 'text/html',
+ 'html' => 'text/html',
+ 'ico' => 'image/x-icon',
+ 'ics' => 'text/calendar',
+ 'ifb' => 'text/calendar',
+ 'iges' => 'model/iges',
+ 'igs' => 'model/iges',
+ 'jp2' => 'image/jp2',
+ 'jpe' => 'image/jpeg',
+ 'jpeg' => 'image/jpeg',
+ 'jpg' => 'image/jpeg',
+ 'kar' => 'audio/midi',
+ 'lha' => 'application/octet-stream',
+ 'lzh' => 'application/octet-stream',
+ 'm4a' => 'audio/mp4a-latm',
+ 'm4p' => 'audio/mp4a-latm',
+ 'm4u' => 'video/vnd.mpegurl',
+ 'm4v' => 'video/x-m4v',
+ 'mac' => 'image/x-macpaint',
+ 'mathml' => 'application/mathml+xml',
+ 'mesh' => 'model/mesh',
+ 'mid' => 'audio/midi',
+ 'midi' => 'audio/midi',
+ 'mov' => 'video/quicktime',
+ 'mp2' => 'audio/mpeg',
+ 'mp3' => 'audio/mpeg',
+ 'mp4' => 'video/mp4',
+ 'mpe' => 'video/mpeg',
+ 'mpeg' => 'video/mpeg',
+ 'mpg' => 'video/mpeg',
+ 'mpga' => 'audio/mpeg',
+ 'msh' => 'model/mesh',
+ 'nc' => 'application/x-netcdf',
+ 'oda' => 'application/oda',
+ 'ogv' => 'video/ogv',
+ 'pct' => 'image/pict',
+ 'pic' => 'image/pict',
+ 'pict' => 'image/pict',
+ 'pnt' => 'image/x-macpaint',
+ 'pntg' => 'image/x-macpaint',
+ 'ps' => 'application/postscript',
+ 'qt' => 'video/quicktime',
+ 'qti' => 'image/x-quicktime',
+ 'qtif' => 'image/x-quicktime',
+ 'ram' => 'audio/x-pn-realaudio',
+ 'rdf' => 'application/rdf+xml',
+ 'rm' => 'application/vnd.rn-realmedia',
+ 'roff' => 'application/x-troff',
+ 'sgm' => 'text/sgml',
+ 'sgml' => 'text/sgml',
+ 'silo' => 'model/mesh',
+ 'skd' => 'application/x-koan',
+ 'skm' => 'application/x-koan',
+ 'skp' => 'application/x-koan',
+ 'skt' => 'application/x-koan',
+ 'smi' => 'application/smil',
+ 'smil' => 'application/smil',
+ 'snd' => 'audio/basic',
+ 'so' => 'application/octet-stream',
+ 'svg' => 'image/svg+xml',
+ 't' => 'application/x-troff',
+ 'texi' => 'application/x-texinfo',
+ 'texinfo' => 'application/x-texinfo',
+ 'tif' => 'image/tiff',
+ 'tiff' => 'image/tiff',
+ 'tr' => 'application/x-troff',
+ 'txt' => 'text/plain',
+ 'vrml' => 'model/vrml',
+ 'vxml' => 'application/voicexml+xml',
+ 'webm' => 'video/webm',
+ 'webp' => 'image/webp',
+ 'wrl' => 'model/vrml',
+ 'xht' => 'application/xhtml+xml',
+ 'xhtml' => 'application/xhtml+xml',
+ 'xml' => 'application/xml',
+ 'xsl' => 'application/xml',
+ 'xslt' => 'application/xslt+xml',
+ 'xul' => 'application/vnd.mozilla.xul+xml',
+ );
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Core/OssException.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Core/OssException.php
new file mode 100644
index 000000000..b0e9e8b0d
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Core/OssException.php
@@ -0,0 +1,54 @@
+details = $details;
+ } else {
+ $message = $details;
+ parent::__construct($message);
+ }
+ }
+
+ public function getHTTPStatus()
+ {
+ return isset($this->details['status']) ? $this->details['status'] : '';
+ }
+
+ public function getRequestId()
+ {
+ return isset($this->details['request-id']) ? $this->details['request-id'] : '';
+ }
+
+ public function getErrorCode()
+ {
+ return isset($this->details['code']) ? $this->details['code'] : '';
+ }
+
+ public function getErrorMessage()
+ {
+ return isset($this->details['message']) ? $this->details['message'] : '';
+ }
+
+ public function getDetails()
+ {
+ return isset($this->details['body']) ? $this->details['body'] : '';
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Core/OssUtil.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Core/OssUtil.php
new file mode 100644
index 000000000..b70680ee0
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Core/OssUtil.php
@@ -0,0 +1,448 @@
+ $value) {
+ if (is_string($key) && !is_array($value)) {
+ $temp[] = rawurlencode($key) . '=' . rawurlencode($value);
+ }
+ }
+ return implode('&', $temp);
+ }
+
+ /**
+ * 转义字符替换
+ *
+ * @param string $subject
+ * @return string
+ */
+ public static function sReplace($subject)
+ {
+ $search = array('<', '>', '&', '\'', '"');
+ $replace = array('<', '>', '&', ''', '"');
+ return str_replace($search, $replace, $subject);
+ }
+
+ /**
+ * 检查是否是中文编码
+ *
+ * @param $str
+ * @return int
+ */
+ public static function chkChinese($str)
+ {
+ return preg_match('/[\x80-\xff]./', $str);
+ }
+
+ /**
+ * 检测是否GB2312编码
+ *
+ * @param string $str
+ * @return boolean false UTF-8编码 TRUE GB2312编码
+ */
+ public static function isGb2312($str)
+ {
+ for ($i = 0; $i < strlen($str); $i++) {
+ $v = ord($str[$i]);
+ if ($v > 127) {
+ if (($v >= 228) && ($v <= 233)) {
+ if (($i + 2) >= (strlen($str) - 1)) return true; // not enough characters
+ $v1 = ord($str[$i + 1]);
+ $v2 = ord($str[$i + 2]);
+ if (($v1 >= 128) && ($v1 <= 191) && ($v2 >= 128) && ($v2 <= 191))
+ return false;
+ else
+ return true;
+ }
+ }
+ }
+ return false;
+ }
+
+ /**
+ * 检测是否GBK编码
+ *
+ * @param string $str
+ * @param boolean $gbk
+ * @return boolean
+ */
+ public static function checkChar($str, $gbk = true)
+ {
+ for ($i = 0; $i < strlen($str); $i++) {
+ $v = ord($str[$i]);
+ if ($v > 127) {
+ if (($v >= 228) && ($v <= 233)) {
+ if (($i + 2) >= (strlen($str) - 1)) return $gbk ? true : FALSE; // not enough characters
+ $v1 = ord($str[$i + 1]);
+ $v2 = ord($str[$i + 2]);
+ if ($gbk) {
+ return (($v1 >= 128) && ($v1 <= 191) && ($v2 >= 128) && ($v2 <= 191)) ? FALSE : TRUE;//GBK
+ } else {
+ return (($v1 >= 128) && ($v1 <= 191) && ($v2 >= 128) && ($v2 <= 191)) ? TRUE : FALSE;
+ }
+ }
+ }
+ }
+ return $gbk ? TRUE : FALSE;
+ }
+
+ /**
+ * 检验bucket名称是否合法
+ * bucket的命名规范:
+ * 1. 只能包括小写字母,数字
+ * 2. 必须以小写字母或者数字开头
+ * 3. 长度必须在3-63字节之间
+ *
+ * @param string $bucket Bucket名称
+ * @return boolean
+ */
+ public static function validateBucket($bucket)
+ {
+ $pattern = '/^[a-z0-9][a-z0-9-]{2,62}$/';
+ if (!preg_match($pattern, $bucket)) {
+ return false;
+ }
+ return true;
+ }
+
+ /**
+ * 检验object名称是否合法
+ * object命名规范:
+ * 1. 规则长度必须在1-1023字节之间
+ * 2. 使用UTF-8编码
+ * 3. 不能以 "/" "\\"开头
+ *
+ * @param string $object Object名称
+ * @return boolean
+ */
+ public static function validateObject($object)
+ {
+ $pattern = '/^.{1,1023}$/';
+ if (empty($object) || !preg_match($pattern, $object) ||
+ self::startsWith($object, '/') || self::startsWith($object, '\\')
+ ) {
+ return false;
+ }
+ return true;
+ }
+
+
+ /**
+ * 判断字符串$str是不是以$findMe开始
+ *
+ * @param string $str
+ * @param string $findMe
+ * @return bool
+ */
+ public static function startsWith($str, $findMe)
+ {
+ if (strpos($str, $findMe) === 0) {
+ return true;
+ } else {
+ return false;
+ }
+ }
+
+ /**
+ * 检验$options
+ *
+ * @param array $options
+ * @throws OssException
+ * @return boolean
+ */
+ public static function validateOptions($options)
+ {
+ //$options
+ if ($options != NULL && !is_array($options)) {
+ throw new OssException ($options . ':' . 'option must be array');
+ }
+ }
+
+ /**
+ * 检查上传文件的内容是否合法
+ *
+ * @param $content string
+ * @throws OssException
+ */
+ public static function validateContent($content)
+ {
+ if (empty($content)) {
+ throw new OssException("http body content is invalid");
+ }
+ }
+
+ /**
+ * 校验BUCKET/OBJECT/OBJECT GROUP是否为空
+ *
+ * @param string $name
+ * @param string $errMsg
+ * @throws OssException
+ * @return void
+ */
+ public static function throwOssExceptionWithMessageIfEmpty($name, $errMsg)
+ {
+ if (empty($name)) {
+ throw new OssException($errMsg);
+ }
+ }
+
+ /**
+ * 仅供测试使用的接口,请勿使用
+ *
+ * @param $filename
+ * @param $size
+ */
+ public static function generateFile($filename, $size)
+ {
+ if (file_exists($filename) && $size == filesize($filename)) {
+ echo $filename . " already exists, no need to create again. ";
+ return;
+ }
+ $part_size = 1 * 1024 * 1024;
+ $fp = fopen($filename, "w");
+ $characters = << 0) {
+ if ($size < $part_size) {
+ $write_size = $size;
+ } else {
+ $write_size = $part_size;
+ }
+ $size -= $write_size;
+ $a = $characters[rand(0, $charactersLength - 1)];
+ $content = str_repeat($a, $write_size);
+ $flag = fwrite($fp, $content);
+ if (!$flag) {
+ echo "write to " . $filename . " failed. ";
+ break;
+ }
+ }
+ } else {
+ echo "open " . $filename . " failed. ";
+ }
+ fclose($fp);
+ }
+
+ /**
+ * 得到文件的md5编码
+ *
+ * @param $filename
+ * @param $from_pos
+ * @param $to_pos
+ * @return string
+ */
+ public static function getMd5SumForFile($filename, $from_pos, $to_pos)
+ {
+ $content_md5 = "";
+ if (($to_pos - $from_pos) > self::OSS_MAX_PART_SIZE) {
+ return $content_md5;
+ }
+ $filesize = filesize($filename);
+ if ($from_pos >= $filesize || $to_pos >= $filesize || $from_pos < 0 || $to_pos < 0) {
+ return $content_md5;
+ }
+
+ $total_length = $to_pos - $from_pos + 1;
+ $buffer = 8192;
+ $left_length = $total_length;
+ if (!file_exists($filename)) {
+ return $content_md5;
+ }
+
+ if (false === $fh = fopen($filename, 'rb')) {
+ return $content_md5;
+ }
+
+ fseek($fh, $from_pos);
+ $data = '';
+ while (!feof($fh)) {
+ if ($left_length >= $buffer) {
+ $read_length = $buffer;
+ } else {
+ $read_length = $left_length;
+ }
+ if ($read_length <= 0) {
+ break;
+ } else {
+ $data .= fread($fh, $read_length);
+ $left_length = $left_length - $read_length;
+ }
+ }
+ fclose($fh);
+ $content_md5 = base64_encode(md5($data, true));
+ return $content_md5;
+ }
+
+ /**
+ * 检测是否windows系统,因为windows系统默认编码为GBK
+ *
+ * @return bool
+ */
+ public static function isWin()
+ {
+ return strtoupper(substr(PHP_OS, 0, 3)) == "WIN";
+ }
+
+ /**
+ * 主要是由于windows系统编码是gbk,遇到中文时候,如果不进行转换处理会出现找不到文件的问题
+ *
+ * @param $file_path
+ * @return string
+ */
+ public static function encodePath($file_path)
+ {
+ if (self::chkChinese($file_path) && self::isWin()) {
+ $file_path = iconv('utf-8', 'gbk', $file_path);
+ }
+ return $file_path;
+ }
+
+ /**
+ * 判断用户输入的endpoint是否是 xxx.xxx.xxx.xxx:port 或者 xxx.xxx.xxx.xxx的ip格式
+ *
+ * @param string $endpoint 需要做判断的endpoint
+ * @return boolean
+ */
+ public static function isIPFormat($endpoint)
+ {
+ $ip_array = explode(":", $endpoint);
+ $hostname = $ip_array[0];
+ $ret = filter_var($hostname, FILTER_VALIDATE_IP);
+ if (!$ret) {
+ return false;
+ } else {
+ return true;
+ }
+ }
+
+ /**
+ * 生成DeleteMultiObjects接口的xml消息
+ *
+ * @param string[] $objects
+ * @param bool $quiet
+ * @return string
+ */
+ public static function createDeleteObjectsXmlBody($objects, $quiet)
+ {
+ $xml = new \SimpleXMLElement(' ');
+ $xml->addChild('Quiet', $quiet);
+ foreach ($objects as $object) {
+ $sub_object = $xml->addChild('Object');
+ $object = OssUtil::sReplace($object);
+ $sub_object->addChild('Key', $object);
+ }
+ return $xml->asXML();
+ }
+
+ /**
+ * 生成CompleteMultipartUpload接口的xml消息
+ *
+ * @param array[] $listParts
+ * @return string
+ */
+ public static function createCompleteMultipartUploadXmlBody($listParts)
+ {
+ $xml = new \SimpleXMLElement(' ');
+ foreach ($listParts as $node) {
+ $part = $xml->addChild('Part');
+ $part->addChild('PartNumber', $node['PartNumber']);
+ $part->addChild('ETag', $node['ETag']);
+ }
+ return $xml->asXML();
+ }
+
+ /**
+ * 读取目录
+ *
+ * @param string $dir
+ * @param string $exclude
+ * @param bool $recursive
+ * @return string[]
+ */
+ public static function readDir($dir, $exclude = ".|..|.svn|.git", $recursive = false)
+ {
+ $file_list_array = array();
+ $base_path = $dir;
+ $exclude_array = explode("|", $exclude);
+ $exclude_array = array_unique(array_merge($exclude_array, array('.', '..')));
+
+ if ($recursive) {
+ foreach (new \RecursiveIteratorIterator(new \RecursiveDirectoryIterator($dir)) as $new_file) {
+ if ($new_file->isDir()) continue;
+ $object = str_replace($base_path, '', $new_file);
+ if (!in_array(strtolower($object), $exclude_array)) {
+ $object = ltrim($object, '/');
+ if (is_file($new_file)) {
+ $key = md5($new_file . $object, false);
+ $file_list_array[$key] = array('path' => $new_file, 'file' => $object,);
+ }
+ }
+ }
+ } else if ($handle = opendir($dir)) {
+ while (false !== ($file = readdir($handle))) {
+ if (!in_array(strtolower($file), $exclude_array)) {
+ $new_file = $dir . '/' . $file;
+ $object = $file;
+ $object = ltrim($object, '/');
+ if (is_file($new_file)) {
+ $key = md5($new_file . $object, false);
+ $file_list_array[$key] = array('path' => $new_file, 'file' => $object,);
+ }
+ }
+ }
+ closedir($handle);
+ }
+ return $file_list_array;
+ }
+
+ /**
+ * Decode key based on the encoding type
+ *
+ * @param string $key
+ * @param string $encoding
+ * @return string
+ */
+ public static function decodeKey($key, $encoding)
+ {
+ if ($encoding == "") {
+ return $key;
+ }
+
+ if ($encoding == "url") {
+ return rawurldecode($key);
+ } else {
+ throw new OssException("Unrecognized encoding type: " . $encoding);
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Http/LICENSE b/vendor/aliyuncs/oss-sdk-php/src/OSS/Http/LICENSE
new file mode 100644
index 000000000..49b38bd62
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Http/LICENSE
@@ -0,0 +1,25 @@
+Copyright (c) 2006-2010 Ryan Parman, Foleeo Inc., and contributors. All rights reserved.
+
+Redistribution and use in source and binary forms, with or without modification, are
+permitted provided that the following conditions are met:
+
+ * Redistributions of source code must retain the above copyright notice, this list of
+ conditions and the following disclaimer.
+
+ * Redistributions in binary form must reproduce the above copyright notice, this list
+ of conditions and the following disclaimer in the documentation and/or other materials
+ provided with the distribution.
+
+ * Neither the name of Ryan Parman, Foleeo Inc. nor the names of its contributors may be used to
+ endorse or promote products derived from this software without specific prior written
+ permission.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS
+OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
+AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS
+AND CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+POSSIBILITY OF SUCH DAMAGE.
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Http/RequestCore.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Http/RequestCore.php
new file mode 100644
index 000000000..8ed41fce3
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Http/RequestCore.php
@@ -0,0 +1,897 @@
+).
+ */
+ public $request_class = 'OSS\Http\RequestCore';
+
+ /**
+ * The default class to use for HTTP Responses (defaults to ).
+ */
+ public $response_class = 'OSS\Http\ResponseCore';
+
+ /**
+ * Default useragent string to use.
+ */
+ public $useragent = 'RequestCore/1.4.3';
+
+ /**
+ * File to read from while streaming up.
+ */
+ public $read_file = null;
+
+ /**
+ * The resource to read from while streaming up.
+ */
+ public $read_stream = null;
+
+ /**
+ * The size of the stream to read from.
+ */
+ public $read_stream_size = null;
+
+ /**
+ * The length already read from the stream.
+ */
+ public $read_stream_read = 0;
+
+ /**
+ * File to write to while streaming down.
+ */
+ public $write_file = null;
+
+ /**
+ * The resource to write to while streaming down.
+ */
+ public $write_stream = null;
+
+ /**
+ * Stores the intended starting seek position.
+ */
+ public $seek_position = null;
+
+ /**
+ * The location of the cacert.pem file to use.
+ */
+ public $cacert_location = false;
+
+ /**
+ * The state of SSL certificate verification.
+ */
+ public $ssl_verification = true;
+
+ /**
+ * The user-defined callback function to call when a stream is read from.
+ */
+ public $registered_streaming_read_callback = null;
+
+ /**
+ * The user-defined callback function to call when a stream is written to.
+ */
+ public $registered_streaming_write_callback = null;
+
+ /**
+ * 请求超时时间, 默认是5184000秒,6天
+ *
+ * @var int
+ */
+ public $timeout = 5184000;
+
+ /**
+ * 连接超时时间,默认是10秒
+ *
+ * @var int
+ */
+ public $connect_timeout = 10;
+
+ /*%******************************************************************************************%*/
+ // CONSTANTS
+
+ /**
+ * GET HTTP Method
+ */
+ const HTTP_GET = 'GET';
+
+ /**
+ * POST HTTP Method
+ */
+ const HTTP_POST = 'POST';
+
+ /**
+ * PUT HTTP Method
+ */
+ const HTTP_PUT = 'PUT';
+
+ /**
+ * DELETE HTTP Method
+ */
+ const HTTP_DELETE = 'DELETE';
+
+ /**
+ * HEAD HTTP Method
+ */
+ const HTTP_HEAD = 'HEAD';
+
+
+ /*%******************************************************************************************%*/
+ // CONSTRUCTOR/DESTRUCTOR
+
+ /**
+ * Constructs a new instance of this class.
+ *
+ * @param string $url (Optional) The URL to request or service endpoint to query.
+ * @param string $proxy (Optional) The faux-url to use for proxy settings. Takes the following format: `proxy://user:pass@hostname:port`
+ * @param array $helpers (Optional) An associative array of classnames to use for request, and response functionality. Gets passed in automatically by the calling class.
+ * @return $this A reference to the current instance.
+ */
+ public function __construct($url = null, $proxy = null, $helpers = null)
+ {
+ // Set some default values.
+ $this->request_url = $url;
+ $this->method = self::HTTP_GET;
+ $this->request_headers = array();
+ $this->request_body = '';
+
+ // Set a new Request class if one was set.
+ if (isset($helpers['request']) && !empty($helpers['request'])) {
+ $this->request_class = $helpers['request'];
+ }
+
+ // Set a new Request class if one was set.
+ if (isset($helpers['response']) && !empty($helpers['response'])) {
+ $this->response_class = $helpers['response'];
+ }
+
+ if ($proxy) {
+ $this->set_proxy($proxy);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Destructs the instance. Closes opened file handles.
+ *
+ * @return $this A reference to the current instance.
+ */
+ public function __destruct()
+ {
+ if (isset($this->read_file) && isset($this->read_stream)) {
+ fclose($this->read_stream);
+ }
+
+ if (isset($this->write_file) && isset($this->write_stream)) {
+ fclose($this->write_stream);
+ }
+
+ return $this;
+ }
+
+
+ /*%******************************************************************************************%*/
+ // REQUEST METHODS
+
+ /**
+ * Sets the credentials to use for authentication.
+ *
+ * @param string $user (Required) The username to authenticate with.
+ * @param string $pass (Required) The password to authenticate with.
+ * @return $this A reference to the current instance.
+ */
+ public function set_credentials($user, $pass)
+ {
+ $this->username = $user;
+ $this->password = $pass;
+ return $this;
+ }
+
+ /**
+ * Adds a custom HTTP header to the cURL request.
+ *
+ * @param string $key (Required) The custom HTTP header to set.
+ * @param mixed $value (Required) The value to assign to the custom HTTP header.
+ * @return $this A reference to the current instance.
+ */
+ public function add_header($key, $value)
+ {
+ $this->request_headers[$key] = $value;
+ return $this;
+ }
+
+ /**
+ * Removes an HTTP header from the cURL request.
+ *
+ * @param string $key (Required) The custom HTTP header to set.
+ * @return $this A reference to the current instance.
+ */
+ public function remove_header($key)
+ {
+ if (isset($this->request_headers[$key])) {
+ unset($this->request_headers[$key]);
+ }
+ return $this;
+ }
+
+ /**
+ * Set the method type for the request.
+ *
+ * @param string $method (Required) One of the following constants: , , , , .
+ * @return $this A reference to the current instance.
+ */
+ public function set_method($method)
+ {
+ $this->method = strtoupper($method);
+ return $this;
+ }
+
+ /**
+ * Sets a custom useragent string for the class.
+ *
+ * @param string $ua (Required) The useragent string to use.
+ * @return $this A reference to the current instance.
+ */
+ public function set_useragent($ua)
+ {
+ $this->useragent = $ua;
+ return $this;
+ }
+
+ /**
+ * Set the body to send in the request.
+ *
+ * @param string $body (Required) The textual content to send along in the body of the request.
+ * @return $this A reference to the current instance.
+ */
+ public function set_body($body)
+ {
+ $this->request_body = $body;
+ return $this;
+ }
+
+ /**
+ * Set the URL to make the request to.
+ *
+ * @param string $url (Required) The URL to make the request to.
+ * @return $this A reference to the current instance.
+ */
+ public function set_request_url($url)
+ {
+ $this->request_url = $url;
+ return $this;
+ }
+
+ /**
+ * Set additional CURLOPT settings. These will merge with the default settings, and override if
+ * there is a duplicate.
+ *
+ * @param array $curlopts (Optional) A set of key-value pairs that set `CURLOPT` options. These will merge with the existing CURLOPTs, and ones passed here will override the defaults. Keys should be the `CURLOPT_*` constants, not strings.
+ * @return $this A reference to the current instance.
+ */
+ public function set_curlopts($curlopts)
+ {
+ $this->curlopts = $curlopts;
+ return $this;
+ }
+
+ /**
+ * Sets the length in bytes to read from the stream while streaming up.
+ *
+ * @param integer $size (Required) The length in bytes to read from the stream.
+ * @return $this A reference to the current instance.
+ */
+ public function set_read_stream_size($size)
+ {
+ $this->read_stream_size = $size;
+
+ return $this;
+ }
+
+ /**
+ * Sets the resource to read from while streaming up. Reads the stream from its current position until
+ * EOF or `$size` bytes have been read. If `$size` is not given it will be determined by and
+ * .
+ *
+ * @param resource $resource (Required) The readable resource to read from.
+ * @param integer $size (Optional) The size of the stream to read.
+ * @return $this A reference to the current instance.
+ */
+ public function set_read_stream($resource, $size = null)
+ {
+ if (!isset($size) || $size < 0) {
+ $stats = fstat($resource);
+
+ if ($stats && $stats['size'] >= 0) {
+ $position = ftell($resource);
+
+ if ($position !== false && $position >= 0) {
+ $size = $stats['size'] - $position;
+ }
+ }
+ }
+
+ $this->read_stream = $resource;
+
+ return $this->set_read_stream_size($size);
+ }
+
+ /**
+ * Sets the file to read from while streaming up.
+ *
+ * @param string $location (Required) The readable location to read from.
+ * @return $this A reference to the current instance.
+ */
+ public function set_read_file($location)
+ {
+ $this->read_file = $location;
+ $read_file_handle = fopen($location, 'r');
+
+ return $this->set_read_stream($read_file_handle);
+ }
+
+ /**
+ * Sets the resource to write to while streaming down.
+ *
+ * @param resource $resource (Required) The writeable resource to write to.
+ * @return $this A reference to the current instance.
+ */
+ public function set_write_stream($resource)
+ {
+ $this->write_stream = $resource;
+
+ return $this;
+ }
+
+ /**
+ * Sets the file to write to while streaming down.
+ *
+ * @param string $location (Required) The writeable location to write to.
+ * @return $this A reference to the current instance.
+ */
+ public function set_write_file($location)
+ {
+ $this->write_file = $location;
+ }
+
+ /**
+ * Set the proxy to use for making requests.
+ *
+ * @param string $proxy (Required) The faux-url to use for proxy settings. Takes the following format: `proxy://user:pass@hostname:port`
+ * @return $this A reference to the current instance.
+ */
+ public function set_proxy($proxy)
+ {
+ $proxy = parse_url($proxy);
+ $proxy['user'] = isset($proxy['user']) ? $proxy['user'] : null;
+ $proxy['pass'] = isset($proxy['pass']) ? $proxy['pass'] : null;
+ $proxy['port'] = isset($proxy['port']) ? $proxy['port'] : null;
+ $this->proxy = $proxy;
+ return $this;
+ }
+
+ /**
+ * Set the intended starting seek position.
+ *
+ * @param integer $position (Required) The byte-position of the stream to begin reading from.
+ * @return $this A reference to the current instance.
+ */
+ public function set_seek_position($position)
+ {
+ $this->seek_position = isset($position) ? (integer)$position : null;
+
+ return $this;
+ }
+
+ /**
+ * A callback function that is invoked by cURL for streaming up.
+ *
+ * @param resource $curl_handle (Required) The cURL handle for the request.
+ * @param resource $header_content (Required) The header callback result.
+ * @return headers from a stream.
+ */
+ public function streaming_header_callback($curl_handle, $header_content)
+ {
+ $code = curl_getinfo($curl_handle, CURLINFO_HTTP_CODE);
+
+ if (isset($this->write_file) && intval($code) / 100 == 2 && !isset($this->write_file_handle))
+ {
+ $this->write_file_handle = fopen($this->write_file, 'w');
+ $this->set_write_stream($this->write_file_handle);
+ }
+
+ $this->response_raw_headers .= $header_content;
+ return strlen($header_content);
+ }
+
+
+ /**
+ * Register a callback function to execute whenever a data stream is read from using
+ * .
+ *
+ * The user-defined callback function should accept three arguments:
+ *
+ *
+ * $curl_handle
- resource
- Required - The cURL handle resource that represents the in-progress transfer.
+ * $file_handle
- resource
- Required - The file handle resource that represents the file on the local file system.
+ * $length
- integer
- Required - The length in kilobytes of the data chunk that was transferred.
+ *
+ *
+ * @param string|array|function $callback (Required) The callback function is called by , so you can pass the following values:
+ * The name of a global function to execute, passed as a string.
+ * A method to execute, passed as array('ClassName', 'MethodName')
.
+ * An anonymous function (PHP 5.3+).
+ * @return $this A reference to the current instance.
+ */
+ public function register_streaming_read_callback($callback)
+ {
+ $this->registered_streaming_read_callback = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Register a callback function to execute whenever a data stream is written to using
+ * .
+ *
+ * The user-defined callback function should accept two arguments:
+ *
+ *
+ * $curl_handle
- resource
- Required - The cURL handle resource that represents the in-progress transfer.
+ * $length
- integer
- Required - The length in kilobytes of the data chunk that was transferred.
+ *
+ *
+ * @param string|array|function $callback (Required) The callback function is called by , so you can pass the following values:
+ * The name of a global function to execute, passed as a string.
+ * A method to execute, passed as array('ClassName', 'MethodName')
.
+ * An anonymous function (PHP 5.3+).
+ * @return $this A reference to the current instance.
+ */
+ public function register_streaming_write_callback($callback)
+ {
+ $this->registered_streaming_write_callback = $callback;
+
+ return $this;
+ }
+
+
+ /*%******************************************************************************************%*/
+ // PREPARE, SEND, AND PROCESS REQUEST
+
+ /**
+ * A callback function that is invoked by cURL for streaming up.
+ *
+ * @param resource $curl_handle (Required) The cURL handle for the request.
+ * @param resource $file_handle (Required) The open file handle resource.
+ * @param integer $length (Required) The maximum number of bytes to read.
+ * @return binary Binary data from a stream.
+ */
+ public function streaming_read_callback($curl_handle, $file_handle, $length)
+ {
+ // Once we've sent as much as we're supposed to send...
+ if ($this->read_stream_read >= $this->read_stream_size) {
+ // Send EOF
+ return '';
+ }
+
+ // If we're at the beginning of an upload and need to seek...
+ if ($this->read_stream_read == 0 && isset($this->seek_position) && $this->seek_position !== ftell($this->read_stream)) {
+ if (fseek($this->read_stream, $this->seek_position) !== 0) {
+ throw new RequestCore_Exception('The stream does not support seeking and is either not at the requested position or the position is unknown.');
+ }
+ }
+
+ $read = fread($this->read_stream, min($this->read_stream_size - $this->read_stream_read, $length)); // Remaining upload data or cURL's requested chunk size
+ $this->read_stream_read += strlen($read);
+
+ $out = $read === false ? '' : $read;
+
+ // Execute callback function
+ if ($this->registered_streaming_read_callback) {
+ call_user_func($this->registered_streaming_read_callback, $curl_handle, $file_handle, $out);
+ }
+
+ return $out;
+ }
+
+ /**
+ * A callback function that is invoked by cURL for streaming down.
+ *
+ * @param resource $curl_handle (Required) The cURL handle for the request.
+ * @param binary $data (Required) The data to write.
+ * @return integer The number of bytes written.
+ */
+ public function streaming_write_callback($curl_handle, $data)
+ {
+ $code = curl_getinfo($curl_handle, CURLINFO_HTTP_CODE);
+
+ if (intval($code) / 100 != 2)
+ {
+ $this->response_error_body .= $data;
+ return strlen($data);
+ }
+
+ $length = strlen($data);
+ $written_total = 0;
+ $written_last = 0;
+
+ while ($written_total < $length) {
+ $written_last = fwrite($this->write_stream, substr($data, $written_total));
+
+ if ($written_last === false) {
+ return $written_total;
+ }
+
+ $written_total += $written_last;
+ }
+
+ // Execute callback function
+ if ($this->registered_streaming_write_callback) {
+ call_user_func($this->registered_streaming_write_callback, $curl_handle, $written_total);
+ }
+
+ return $written_total;
+ }
+
+ /**
+ * Prepares and adds the details of the cURL request. This can be passed along to a
+ * function.
+ *
+ * @return resource The handle for the cURL object.
+ *
+ */
+ public function prep_request()
+ {
+ $curl_handle = curl_init();
+
+ // Set default options.
+ curl_setopt($curl_handle, CURLOPT_URL, $this->request_url);
+ curl_setopt($curl_handle, CURLOPT_FILETIME, true);
+ curl_setopt($curl_handle, CURLOPT_FRESH_CONNECT, false);
+// curl_setopt($curl_handle, CURLOPT_CLOSEPOLICY, CURLCLOSEPOLICY_LEAST_RECENTLY_USED);
+ curl_setopt($curl_handle, CURLOPT_MAXREDIRS, 5);
+ curl_setopt($curl_handle, CURLOPT_HEADER, true);
+ curl_setopt($curl_handle, CURLOPT_RETURNTRANSFER, true);
+ curl_setopt($curl_handle, CURLOPT_TIMEOUT, $this->timeout);
+ curl_setopt($curl_handle, CURLOPT_CONNECTTIMEOUT, $this->connect_timeout);
+ curl_setopt($curl_handle, CURLOPT_NOSIGNAL, true);
+ curl_setopt($curl_handle, CURLOPT_REFERER, $this->request_url);
+ curl_setopt($curl_handle, CURLOPT_USERAGENT, $this->useragent);
+ curl_setopt($curl_handle, CURLOPT_HEADERFUNCTION, array($this, 'streaming_header_callback'));
+ curl_setopt($curl_handle, CURLOPT_READFUNCTION, array($this, 'streaming_read_callback'));
+
+ // Verification of the SSL cert
+ if ($this->ssl_verification) {
+ curl_setopt($curl_handle, CURLOPT_SSL_VERIFYPEER, true);
+ curl_setopt($curl_handle, CURLOPT_SSL_VERIFYHOST, 2);
+ } else {
+ curl_setopt($curl_handle, CURLOPT_SSL_VERIFYPEER, false);
+ curl_setopt($curl_handle, CURLOPT_SSL_VERIFYHOST, false);
+ }
+
+ // chmod the file as 0755
+ if ($this->cacert_location === true) {
+ curl_setopt($curl_handle, CURLOPT_CAINFO, dirname(__FILE__) . '/cacert.pem');
+ } elseif (is_string($this->cacert_location)) {
+ curl_setopt($curl_handle, CURLOPT_CAINFO, $this->cacert_location);
+ }
+
+ // Debug mode
+ if ($this->debug_mode) {
+ curl_setopt($curl_handle, CURLOPT_VERBOSE, true);
+ }
+
+ // Handle open_basedir & safe mode
+ if (!ini_get('safe_mode') && !ini_get('open_basedir')) {
+ curl_setopt($curl_handle, CURLOPT_FOLLOWLOCATION, true);
+ }
+
+ // Enable a proxy connection if requested.
+ if ($this->proxy) {
+ curl_setopt($curl_handle, CURLOPT_HTTPPROXYTUNNEL, true);
+
+ $host = $this->proxy['host'];
+ $host .= ($this->proxy['port']) ? ':' . $this->proxy['port'] : '';
+ curl_setopt($curl_handle, CURLOPT_PROXY, $host);
+
+ if (isset($this->proxy['user']) && isset($this->proxy['pass'])) {
+ curl_setopt($curl_handle, CURLOPT_PROXYUSERPWD, $this->proxy['user'] . ':' . $this->proxy['pass']);
+ }
+ }
+
+ // Set credentials for HTTP Basic/Digest Authentication.
+ if ($this->username && $this->password) {
+ curl_setopt($curl_handle, CURLOPT_HTTPAUTH, CURLAUTH_ANY);
+ curl_setopt($curl_handle, CURLOPT_USERPWD, $this->username . ':' . $this->password);
+ }
+
+ // Handle the encoding if we can.
+ if (extension_loaded('zlib')) {
+ curl_setopt($curl_handle, CURLOPT_ENCODING, '');
+ }
+
+ // Process custom headers
+ if (isset($this->request_headers) && count($this->request_headers)) {
+ $temp_headers = array();
+
+ foreach ($this->request_headers as $k => $v) {
+ $temp_headers[] = $k . ': ' . $v;
+ }
+
+ curl_setopt($curl_handle, CURLOPT_HTTPHEADER, $temp_headers);
+ }
+
+ switch ($this->method) {
+ case self::HTTP_PUT:
+ //unset($this->read_stream);
+ curl_setopt($curl_handle, CURLOPT_CUSTOMREQUEST, 'PUT');
+ if (isset($this->read_stream)) {
+ if (!isset($this->read_stream_size) || $this->read_stream_size < 0) {
+ throw new RequestCore_Exception('The stream size for the streaming upload cannot be determined.');
+ }
+ curl_setopt($curl_handle, CURLOPT_INFILESIZE, $this->read_stream_size);
+ curl_setopt($curl_handle, CURLOPT_UPLOAD, true);
+ } else {
+ curl_setopt($curl_handle, CURLOPT_POSTFIELDS, $this->request_body);
+ }
+ break;
+
+ case self::HTTP_POST:
+ curl_setopt($curl_handle, CURLOPT_CUSTOMREQUEST, 'POST');
+ if (isset($this->read_stream)) {
+ if (!isset($this->read_stream_size) || $this->read_stream_size < 0) {
+ throw new RequestCore_Exception('The stream size for the streaming upload cannot be determined.');
+ }
+ curl_setopt($curl_handle, CURLOPT_INFILESIZE, $this->read_stream_size);
+ curl_setopt($curl_handle, CURLOPT_UPLOAD, true);
+ } else {
+ curl_setopt($curl_handle, CURLOPT_POSTFIELDS, $this->request_body);
+ }
+ break;
+
+ case self::HTTP_HEAD:
+ curl_setopt($curl_handle, CURLOPT_CUSTOMREQUEST, self::HTTP_HEAD);
+ curl_setopt($curl_handle, CURLOPT_NOBODY, 1);
+ break;
+
+ default: // Assumed GET
+ curl_setopt($curl_handle, CURLOPT_CUSTOMREQUEST, $this->method);
+ if (isset($this->write_stream) || isset($this->write_file)) {
+ curl_setopt($curl_handle, CURLOPT_WRITEFUNCTION, array($this, 'streaming_write_callback'));
+ curl_setopt($curl_handle, CURLOPT_HEADER, false);
+ } else {
+ curl_setopt($curl_handle, CURLOPT_POSTFIELDS, $this->request_body);
+ }
+ break;
+ }
+
+ // Merge in the CURLOPTs
+ if (isset($this->curlopts) && sizeof($this->curlopts) > 0) {
+ foreach ($this->curlopts as $k => $v) {
+ curl_setopt($curl_handle, $k, $v);
+ }
+ }
+
+ return $curl_handle;
+ }
+
+ /**
+ * Take the post-processed cURL data and break it down into useful header/body/info chunks. Uses the
+ * data stored in the `curl_handle` and `response` properties unless replacement data is passed in via
+ * parameters.
+ *
+ * @param resource $curl_handle (Optional) The reference to the already executed cURL request.
+ * @param string $response (Optional) The actual response content itself that needs to be parsed.
+ * @return ResponseCore A object containing a parsed HTTP response.
+ */
+ public function process_response($curl_handle = null, $response = null)
+ {
+ // Accept a custom one if it's passed.
+ if ($curl_handle && $response) {
+ $this->response = $response;
+ }
+
+ // As long as this came back as a valid resource...
+ if (is_resource($curl_handle)) {
+ // Determine what's what.
+ $header_size = curl_getinfo($curl_handle, CURLINFO_HEADER_SIZE);
+ $this->response_headers = substr($this->response, 0, $header_size);
+ $this->response_body = substr($this->response, $header_size);
+ $this->response_code = curl_getinfo($curl_handle, CURLINFO_HTTP_CODE);
+ $this->response_info = curl_getinfo($curl_handle);
+
+ if (intval($this->response_code) / 100 != 2 && isset($this->write_file))
+ {
+ $this->response_headers = $this->response_raw_headers;
+ $this->response_body = $this->response_error_body;
+ }
+
+ // Parse out the headers
+ $this->response_headers = explode("\r\n\r\n", trim($this->response_headers));
+ $this->response_headers = array_pop($this->response_headers);
+ $this->response_headers = explode("\r\n", $this->response_headers);
+ array_shift($this->response_headers);
+
+ // Loop through and split up the headers.
+ $header_assoc = array();
+ foreach ($this->response_headers as $header) {
+ $kv = explode(': ', $header);
+ $header_assoc[strtolower($kv[0])] = isset($kv[1]) ? $kv[1] : '';
+ }
+
+ // Reset the headers to the appropriate property.
+ $this->response_headers = $header_assoc;
+ $this->response_headers['info'] = $this->response_info;
+ $this->response_headers['info']['method'] = $this->method;
+
+ if ($curl_handle && $response) {
+ return new ResponseCore($this->response_headers, $this->response_body, $this->response_code);
+ }
+ }
+
+ // Return false
+ return false;
+ }
+
+ /**
+ * Sends the request, calling necessary utility functions to update built-in properties.
+ *
+ * @param boolean $parse (Optional) Whether to parse the response with ResponseCore or not.
+ * @return string The resulting unparsed data from the request.
+ */
+ public function send_request($parse = false)
+ {
+ set_time_limit(0);
+
+ $curl_handle = $this->prep_request();
+ $this->response = curl_exec($curl_handle);
+
+ if ($this->response === false) {
+ throw new RequestCore_Exception('cURL resource: ' . (string)$curl_handle . '; cURL error: ' . curl_error($curl_handle) . ' (' . curl_errno($curl_handle) . ')');
+ }
+
+ $parsed_response = $this->process_response($curl_handle, $this->response);
+
+ curl_close($curl_handle);
+
+ if ($parse) {
+ return $parsed_response;
+ }
+
+ return $this->response;
+ }
+
+ /*%******************************************************************************************%*/
+ // RESPONSE METHODS
+
+ /**
+ * Get the HTTP response headers from the request.
+ *
+ * @param string $header (Optional) A specific header value to return. Defaults to all headers.
+ * @return string|array All or selected header values.
+ */
+ public function get_response_header($header = null)
+ {
+ if ($header) {
+ return $this->response_headers[strtolower($header)];
+ }
+ return $this->response_headers;
+ }
+
+ /**
+ * Get the HTTP response body from the request.
+ *
+ * @return string The response body.
+ */
+ public function get_response_body()
+ {
+ return $this->response_body;
+ }
+
+ /**
+ * Get the HTTP response code from the request.
+ *
+ * @return string The HTTP response code.
+ */
+ public function get_response_code()
+ {
+ return $this->response_code;
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Http/RequestCore_Exception.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Http/RequestCore_Exception.php
new file mode 100644
index 000000000..cb4e83c65
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Http/RequestCore_Exception.php
@@ -0,0 +1,8 @@
+).
+ * @param string $body (Required) XML-formatted response from AWS.
+ * @param integer $status (Optional) HTTP response status code from the request.
+ * @return Mixed Contains an `header` property (HTTP headers as an associative array), a or `body` property, and an `status` code.
+ */
+ public function __construct($header, $body, $status = null)
+ {
+ $this->header = $header;
+ $this->body = $body;
+ $this->status = $status;
+
+ return $this;
+ }
+
+ /**
+ * Did we receive the status code we expected?
+ *
+ * @param integer|array $codes (Optional) The status code(s) to expect. Pass an for a single acceptable value, or an of integers for multiple acceptable values.
+ * @return boolean Whether we received the expected status code or not.
+ */
+ public function isOK($codes = array(200, 201, 204, 206))
+ {
+ if (is_array($codes)) {
+ return in_array($this->status, $codes);
+ }
+
+ return $this->status === $codes;
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/BucketInfo.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/BucketInfo.php
new file mode 100644
index 000000000..9b89674f9
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/BucketInfo.php
@@ -0,0 +1,78 @@
+location = $location;
+ $this->name = $name;
+ $this->createDate = $createDate;
+ }
+
+ /**
+ * 得到bucket所在的region
+ *
+ * @return string
+ */
+ public function getLocation()
+ {
+ return $this->location;
+ }
+
+ /**
+ * 得到bucket的名称
+ *
+ * @return string
+ */
+ public function getName()
+ {
+ return $this->name;
+ }
+
+ /**
+ * 得到bucket的创建时间
+ *
+ * @return string
+ */
+ public function getCreateDate()
+ {
+ return $this->createDate;
+ }
+
+ /**
+ * bucket所在的region
+ *
+ * @var string
+ */
+ private $location;
+ /**
+ * bucket的名称
+ *
+ * @var string
+ */
+ private $name;
+
+ /**
+ * bucket的创建事件
+ *
+ * @var string
+ */
+ private $createDate;
+
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/BucketListInfo.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/BucketListInfo.php
new file mode 100644
index 000000000..910717f92
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/BucketListInfo.php
@@ -0,0 +1,39 @@
+bucketList = $bucketList;
+ }
+
+ /**
+ * 得到BucketInfo列表
+ *
+ * @return BucketInfo[]
+ */
+ public function getBucketList()
+ {
+ return $this->bucketList;
+ }
+
+ /**
+ * BucketInfo信息列表
+ *
+ * @var array
+ */
+ private $bucketList = array();
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/CnameConfig.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/CnameConfig.php
new file mode 100644
index 000000000..f3597d2f0
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/CnameConfig.php
@@ -0,0 +1,99 @@
+cnameList = array();
+ }
+
+ /**
+ * @return array
+ * @example
+ * array(2) {
+ * [0]=>
+ * array(3) {
+ * ["Domain"]=>
+ * string(11) "www.foo.com"
+ * ["Status"]=>
+ * string(7) "enabled"
+ * ["LastModified"]=>
+ * string(8) "20150101"
+ * }
+ * [1]=>
+ * array(3) {
+ * ["Domain"]=>
+ * string(7) "bar.com"
+ * ["Status"]=>
+ * string(8) "disabled"
+ * ["LastModified"]=>
+ * string(8) "20160101"
+ * }
+ * }
+ */
+ public function getCnames()
+ {
+ return $this->cnameList;
+ }
+
+
+ public function addCname($cname)
+ {
+ if (count($this->cnameList) >= self::OSS_MAX_RULES) {
+ throw new OssException(
+ "num of cname in the config exceeds self::OSS_MAX_RULES: " . strval(self::OSS_MAX_RULES));
+ }
+ $this->cnameList[] = array('Domain' => $cname);
+ }
+
+ public function parseFromXml($strXml)
+ {
+ $xml = simplexml_load_string($strXml);
+ if (!isset($xml->Cname)) return;
+ foreach ($xml->Cname as $entry) {
+ $cname = array();
+ foreach ($entry as $key => $value) {
+ $cname[strval($key)] = strval($value);
+ }
+ $this->cnameList[] = $cname;
+ }
+ }
+
+ public function serializeToXml()
+ {
+ $strXml = <<
+
+
+EOF;
+ $xml = new \SimpleXMLElement($strXml);
+ foreach ($this->cnameList as $cname) {
+ $node = $xml->addChild('Cname');
+ foreach ($cname as $key => $value) {
+ $node->addChild($key, $value);
+ }
+ }
+ return $xml->asXML();
+ }
+
+ public function __toString()
+ {
+ return $this->serializeToXml();
+ }
+
+ const OSS_MAX_RULES = 10;
+
+ private $cnameList = array();
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/CorsConfig.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/CorsConfig.php
new file mode 100644
index 000000000..c44c10a1a
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/CorsConfig.php
@@ -0,0 +1,113 @@
+rules = array();
+ }
+
+ /**
+ * 得到CorsRule列表
+ *
+ * @return CorsRule[]
+ */
+ public function getRules()
+ {
+ return $this->rules;
+ }
+
+
+ /**
+ * 添加一条CorsRule
+ *
+ * @param CorsRule $rule
+ * @throws OssException
+ */
+ public function addRule($rule)
+ {
+ if (count($this->rules) >= self::OSS_MAX_RULES) {
+ throw new OssException("num of rules in the config exceeds self::OSS_MAX_RULES: " . strval(self::OSS_MAX_RULES));
+ }
+ $this->rules[] = $rule;
+ }
+
+ /**
+ * 从xml数据中解析出CorsConfig
+ *
+ * @param string $strXml
+ * @throws OssException
+ * @return null
+ */
+ public function parseFromXml($strXml)
+ {
+ $xml = simplexml_load_string($strXml);
+ if (!isset($xml->CORSRule)) return;
+ foreach ($xml->CORSRule as $rule) {
+ $corsRule = new CorsRule();
+ foreach ($rule as $key => $value) {
+ if ($key === self::OSS_CORS_ALLOWED_HEADER) {
+ $corsRule->addAllowedHeader(strval($value));
+ } elseif ($key === self::OSS_CORS_ALLOWED_METHOD) {
+ $corsRule->addAllowedMethod(strval($value));
+ } elseif ($key === self::OSS_CORS_ALLOWED_ORIGIN) {
+ $corsRule->addAllowedOrigin(strval($value));
+ } elseif ($key === self::OSS_CORS_EXPOSE_HEADER) {
+ $corsRule->addExposeHeader(strval($value));
+ } elseif ($key === self::OSS_CORS_MAX_AGE_SECONDS) {
+ $corsRule->setMaxAgeSeconds(strval($value));
+ }
+ }
+ $this->addRule($corsRule);
+ }
+ return;
+ }
+
+ /**
+ * 生成xml字符串
+ *
+ * @return string
+ */
+ public function serializeToXml()
+ {
+ $xml = new \SimpleXMLElement(' ');
+ foreach ($this->rules as $rule) {
+ $xmlRule = $xml->addChild('CORSRule');
+ $rule->appendToXml($xmlRule);
+ }
+ return $xml->asXML();
+ }
+
+ public function __toString()
+ {
+ return $this->serializeToXml();
+ }
+
+ const OSS_CORS_ALLOWED_ORIGIN = 'AllowedOrigin';
+ const OSS_CORS_ALLOWED_METHOD = 'AllowedMethod';
+ const OSS_CORS_ALLOWED_HEADER = 'AllowedHeader';
+ const OSS_CORS_EXPOSE_HEADER = 'ExposeHeader';
+ const OSS_CORS_MAX_AGE_SECONDS = 'MaxAgeSeconds';
+ const OSS_MAX_RULES = 10;
+
+ /**
+ * orsRule列表
+ *
+ * @var CorsRule[]
+ */
+ private $rules = array();
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/CorsRule.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/CorsRule.php
new file mode 100644
index 000000000..2cbe1c17b
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/CorsRule.php
@@ -0,0 +1,150 @@
+allowedOrigins[] = $allowedOrigin;
+ }
+ }
+
+ /**
+ * Rule中增加一条allowedMethod
+ *
+ * @param string $allowedMethod
+ */
+ public function addAllowedMethod($allowedMethod)
+ {
+ if (!empty($allowedMethod)) {
+ $this->allowedMethods[] = $allowedMethod;
+ }
+ }
+
+ /**
+ * Rule中增加一条allowedHeader
+ *
+ * @param string $allowedHeader
+ */
+ public function addAllowedHeader($allowedHeader)
+ {
+ if (!empty($allowedHeader)) {
+ $this->allowedHeaders[] = $allowedHeader;
+ }
+ }
+
+ /**
+ * Rule中增加一条exposeHeader
+ *
+ * @param string $exposeHeader
+ */
+ public function addExposeHeader($exposeHeader)
+ {
+ if (!empty($exposeHeader)) {
+ $this->exposeHeaders[] = $exposeHeader;
+ }
+ }
+
+ /**
+ * @return int
+ */
+ public function getMaxAgeSeconds()
+ {
+ return $this->maxAgeSeconds;
+ }
+
+ /**
+ * @param int $maxAgeSeconds
+ */
+ public function setMaxAgeSeconds($maxAgeSeconds)
+ {
+ $this->maxAgeSeconds = $maxAgeSeconds;
+ }
+
+ /**
+ * 得到AllowedHeaders列表
+ *
+ * @return string[]
+ */
+ public function getAllowedHeaders()
+ {
+ return $this->allowedHeaders;
+ }
+
+ /**
+ * 得到AllowedOrigins列表
+ *
+ * @return string[]
+ */
+ public function getAllowedOrigins()
+ {
+ return $this->allowedOrigins;
+ }
+
+ /**
+ * 得到AllowedMethods列表
+ *
+ * @return string[]
+ */
+ public function getAllowedMethods()
+ {
+ return $this->allowedMethods;
+ }
+
+ /**
+ * 得到ExposeHeaders列表
+ *
+ * @return string[]
+ */
+ public function getExposeHeaders()
+ {
+ return $this->exposeHeaders;
+ }
+
+ /**
+ * 根据提供的xmlRule, 把this按照一定的规则插入到$xmlRule中
+ *
+ * @param \SimpleXMLElement $xmlRule
+ * @throws OssException
+ */
+ public function appendToXml(&$xmlRule)
+ {
+ if (!isset($this->maxAgeSeconds)) {
+ throw new OssException("maxAgeSeconds is not set in the Rule");
+ }
+ foreach ($this->allowedOrigins as $allowedOrigin) {
+ $xmlRule->addChild(CorsConfig::OSS_CORS_ALLOWED_ORIGIN, $allowedOrigin);
+ }
+ foreach ($this->allowedMethods as $allowedMethod) {
+ $xmlRule->addChild(CorsConfig::OSS_CORS_ALLOWED_METHOD, $allowedMethod);
+ }
+ foreach ($this->allowedHeaders as $allowedHeader) {
+ $xmlRule->addChild(CorsConfig::OSS_CORS_ALLOWED_HEADER, $allowedHeader);
+ }
+ foreach ($this->exposeHeaders as $exposeHeader) {
+ $xmlRule->addChild(CorsConfig::OSS_CORS_EXPOSE_HEADER, $exposeHeader);
+ }
+ $xmlRule->addChild(CorsConfig::OSS_CORS_MAX_AGE_SECONDS, strval($this->maxAgeSeconds));
+ }
+
+ private $allowedHeaders = array();
+ private $allowedOrigins = array();
+ private $allowedMethods = array();
+ private $exposeHeaders = array();
+ private $maxAgeSeconds = null;
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/GetLiveChannelHistory.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/GetLiveChannelHistory.php
new file mode 100644
index 000000000..6643444aa
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/GetLiveChannelHistory.php
@@ -0,0 +1,34 @@
+liveRecordList;
+ }
+
+ public function parseFromXml($strXml)
+ {
+ $xml = simplexml_load_string($strXml);
+
+ if (isset($xml->LiveRecord)) {
+ foreach ($xml->LiveRecord as $record) {
+ $liveRecord = new LiveChannelHistory();
+ $liveRecord->parseFromXmlNode($record);
+ $this->liveRecordList[] = $liveRecord;
+ }
+ }
+ }
+
+ public function serializeToXml()
+ {
+ throw new OssException("Not implemented.");
+ }
+
+ private $liveRecordList = array();
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/GetLiveChannelInfo.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/GetLiveChannelInfo.php
new file mode 100644
index 000000000..0b5edfc4d
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/GetLiveChannelInfo.php
@@ -0,0 +1,68 @@
+description;
+ }
+
+ public function getStatus()
+ {
+ return $this->status;
+ }
+
+ public function getType()
+ {
+ return $this->type;
+ }
+
+ public function getFragDuration()
+ {
+ return $this->fragDuration;
+ }
+
+ public function getFragCount()
+ {
+ return $this->fragCount;
+ }
+
+ public function getPlayListName()
+ {
+ return $this->playlistName;
+ }
+
+ public function parseFromXml($strXml)
+ {
+ $xml = simplexml_load_string($strXml);
+
+ $this->description = strval($xml->Description);
+ $this->status = strval($xml->Status);
+
+ if (isset($xml->Target)) {
+ foreach ($xml->Target as $target) {
+ $this->type = strval($target->Type);
+ $this->fragDuration = strval($target->FragDuration);
+ $this->fragCount = strval($target->FragCount);
+ $this->playlistName = strval($target->PlaylistName);
+ }
+ }
+ }
+
+ public function serializeToXml()
+ {
+ throw new OssException("Not implemented.");
+ }
+
+ private $description;
+ private $status;
+ private $type;
+ private $fragDuration;
+ private $fragCount;
+ private $playlistName;
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/GetLiveChannelStatus.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/GetLiveChannelStatus.php
new file mode 100644
index 000000000..2ee7a68b2
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/GetLiveChannelStatus.php
@@ -0,0 +1,107 @@
+status;
+ }
+
+ public function getConnectedTime()
+ {
+ return $this->connectedTime;
+ }
+
+ public function getRemoteAddr()
+ {
+ return $this->remoteAddr;
+ }
+
+ public function getVideoWidth()
+ {
+ return $this->videoWidth;
+ }
+ public function getVideoHeight()
+ {
+ return $this->videoHeight;
+ }
+ public function getVideoFrameRate()
+ {
+ return $this->videoFrameRate;
+ }
+ public function getVideoBandwidth()
+ {
+ return $this->videoBandwidth;
+ }
+ public function getVideoCodec()
+ {
+ return $this->videoCodec;
+ }
+
+ public function getAudioBandwidth()
+ {
+ return $this->audioBandwidth;
+ }
+ public function getAudioSampleRate()
+ {
+ return $this->audioSampleRate;
+ }
+ public function getAudioCodec()
+ {
+ return $this->audioCodec;
+ }
+
+
+ public function parseFromXml($strXml)
+ {
+ $xml = simplexml_load_string($strXml);
+ $this->status = strval($xml->Status);
+ $this->connectedTime = strval($xml->ConnectedTime);
+ $this->remoteAddr = strval($xml->RemoteAddr);
+
+ if (isset($xml->Video)) {
+ foreach ($xml->Video as $video) {
+ $this->videoWidth = intval($video->Width);
+ $this->videoHeight = intval($video->Height);
+ $this->videoFrameRate = intval($video->FrameRate);
+ $this->videoBandwidth = intval($video->Bandwidth);
+ $this->videoCodec = strval($video->Codec);
+ }
+ }
+
+ if (isset($xml->Video)) {
+ foreach ($xml->Audio as $audio) {
+ $this->audioBandwidth = intval($audio->Bandwidth);
+ $this->audioSampleRate = intval($audio->SampleRate);
+ $this->audioCodec = strval($audio->Codec);
+ }
+ }
+
+ }
+
+ public function serializeToXml()
+ {
+ throw new OssException("Not implemented.");
+ }
+
+ private $status;
+ private $connectedTime;
+ private $remoteAddr;
+
+ private $videoWidth;
+ private $videoHeight;
+ private $videoFrameRate;
+ private $videoBandwidth;
+ private $videoCodec;
+
+ private $audioBandwidth;
+ private $audioSampleRate;
+ private $audioCodec;
+
+
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LifecycleAction.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LifecycleAction.php
new file mode 100644
index 000000000..5abd825d0
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LifecycleAction.php
@@ -0,0 +1,88 @@
+action = $action;
+ $this->timeSpec = $timeSpec;
+ $this->timeValue = $timeValue;
+ }
+
+ /**
+ * @return LifecycleAction
+ */
+ public function getAction()
+ {
+ return $this->action;
+ }
+
+ /**
+ * @param string $action
+ */
+ public function setAction($action)
+ {
+ $this->action = $action;
+ }
+
+ /**
+ * @return string
+ */
+ public function getTimeSpec()
+ {
+ return $this->timeSpec;
+ }
+
+ /**
+ * @param string $timeSpec
+ */
+ public function setTimeSpec($timeSpec)
+ {
+ $this->timeSpec = $timeSpec;
+ }
+
+ /**
+ * @return string
+ */
+ public function getTimeValue()
+ {
+ return $this->timeValue;
+ }
+
+ /**
+ * @param string $timeValue
+ */
+ public function setTimeValue($timeValue)
+ {
+ $this->timeValue = $timeValue;
+ }
+
+ /**
+ * appendToXml 把actions插入到xml中
+ *
+ * @param \SimpleXMLElement $xmlRule
+ */
+ public function appendToXml(&$xmlRule)
+ {
+ $xmlAction = $xmlRule->addChild($this->action);
+ $xmlAction->addChild($this->timeSpec, $this->timeValue);
+ }
+
+ private $action;
+ private $timeSpec;
+ private $timeValue;
+
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LifecycleConfig.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LifecycleConfig.php
new file mode 100644
index 000000000..fc4f5755a
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LifecycleConfig.php
@@ -0,0 +1,107 @@
+rules = array();
+ $xml = simplexml_load_string($strXml);
+ if (!isset($xml->Rule)) return;
+ $this->rules = array();
+ foreach ($xml->Rule as $rule) {
+ $id = strval($rule->ID);
+ $prefix = strval($rule->Prefix);
+ $status = strval($rule->Status);
+ $actions = array();
+ foreach ($rule as $key => $value) {
+ if ($key === 'ID' || $key === 'Prefix' || $key === 'Status') continue;
+ $action = $key;
+ $timeSpec = null;
+ $timeValue = null;
+ foreach ($value as $timeSpecKey => $timeValueValue) {
+ $timeSpec = $timeSpecKey;
+ $timeValue = strval($timeValueValue);
+ }
+ $actions[] = new LifecycleAction($action, $timeSpec, $timeValue);
+ }
+ $this->rules[] = new LifecycleRule($id, $prefix, $status, $actions);
+ }
+ return;
+ }
+
+
+ /**
+ * 生成xml字符串
+ *
+ * @return string
+ */
+ public function serializeToXml()
+ {
+
+ $xml = new \SimpleXMLElement(' ');
+ foreach ($this->rules as $rule) {
+ $xmlRule = $xml->addChild('Rule');
+ $rule->appendToXml($xmlRule);
+ }
+ return $xml->asXML();
+ }
+
+ /**
+ *
+ * 添加LifecycleRule
+ *
+ * @param LifecycleRule $lifecycleRule
+ * @throws OssException
+ */
+ public function addRule($lifecycleRule)
+ {
+ if (!isset($lifecycleRule)) {
+ throw new OssException("lifecycleRule is null");
+ }
+ $this->rules[] = $lifecycleRule;
+ }
+
+ /**
+ * 将配置转换成字符串,便于用户查看
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return $this->serializeToXml();
+ }
+
+ /**
+ * 得到所有的生命周期规则
+ *
+ * @return LifecycleRule[]
+ */
+ public function getRules()
+ {
+ return $this->rules;
+ }
+
+ /**
+ * @var LifecycleRule[]
+ */
+ private $rules;
+}
+
+
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LifecycleRule.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LifecycleRule.php
new file mode 100644
index 000000000..ec615b9af
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LifecycleRule.php
@@ -0,0 +1,126 @@
+id;
+ }
+
+ /**
+ * @param string $id 规则ID
+ */
+ public function setId($id)
+ {
+ $this->id = $id;
+ }
+
+ /**
+ * 得到文件前缀
+ *
+ * @return string
+ */
+ public function getPrefix()
+ {
+ return $this->prefix;
+ }
+
+ /**
+ * 设置文件前缀
+ *
+ * @param string $prefix 文件前缀
+ */
+ public function setPrefix($prefix)
+ {
+ $this->prefix = $prefix;
+ }
+
+ /**
+ * Lifecycle规则的状态
+ *
+ * @return string
+ */
+ public function getStatus()
+ {
+ return $this->status;
+ }
+
+ /**
+ * 设置Lifecycle规则状态
+ *
+ * @param string $status
+ */
+ public function setStatus($status)
+ {
+ $this->status = $status;
+ }
+
+ /**
+ *
+ * @return LifecycleAction[]
+ */
+ public function getActions()
+ {
+ return $this->actions;
+ }
+
+ /**
+ * @param LifecycleAction[] $actions
+ */
+ public function setActions($actions)
+ {
+ $this->actions = $actions;
+ }
+
+
+ /**
+ * LifecycleRule constructor.
+ *
+ * @param string $id 规则ID
+ * @param string $prefix 文件前缀
+ * @param string $status 规则状态,可选[self::LIFECYCLE_STATUS_ENABLED, self::LIFECYCLE_STATUS_DISABLED]
+ * @param LifecycleAction[] $actions
+ */
+ public function __construct($id, $prefix, $status, $actions)
+ {
+ $this->id = $id;
+ $this->prefix = $prefix;
+ $this->status = $status;
+ $this->actions = $actions;
+ }
+
+ /**
+ * @param \SimpleXMLElement $xmlRule
+ */
+ public function appendToXml(&$xmlRule)
+ {
+ $xmlRule->addChild('ID', $this->id);
+ $xmlRule->addChild('Prefix', $this->prefix);
+ $xmlRule->addChild('Status', $this->status);
+ foreach ($this->actions as $action) {
+ $action->appendToXml($xmlRule);
+ }
+ }
+
+ private $id;
+ private $prefix;
+ private $status;
+ private $actions = array();
+
+ const LIFECYCLE_STATUS_ENABLED = 'Enabled';
+ const LIFECYCLE_STATUS_DISABLED = 'Disabled';
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ListMultipartUploadInfo.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ListMultipartUploadInfo.php
new file mode 100644
index 000000000..105d005b2
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ListMultipartUploadInfo.php
@@ -0,0 +1,134 @@
+bucket = $bucket;
+ $this->keyMarker = $keyMarker;
+ $this->uploadIdMarker = $uploadIdMarker;
+ $this->nextKeyMarker = $nextKeyMarker;
+ $this->nextUploadIdMarker = $nextUploadIdMarker;
+ $this->delimiter = $delimiter;
+ $this->prefix = $prefix;
+ $this->maxUploads = $maxUploads;
+ $this->isTruncated = $isTruncated;
+ $this->uploads = $uploads;
+ }
+
+ /**
+ * 得到bucket名称
+ *
+ * @return string
+ */
+ public function getBucket()
+ {
+ return $this->bucket;
+ }
+
+ /**
+ * @return string
+ */
+ public function getKeyMarker()
+ {
+ return $this->keyMarker;
+ }
+
+ /**
+ *
+ * @return string
+ */
+ public function getUploadIdMarker()
+ {
+ return $this->uploadIdMarker;
+ }
+
+ /**
+ * @return string
+ */
+ public function getNextKeyMarker()
+ {
+ return $this->nextKeyMarker;
+ }
+
+ /**
+ * @return string
+ */
+ public function getNextUploadIdMarker()
+ {
+ return $this->nextUploadIdMarker;
+ }
+
+ /**
+ * @return string
+ */
+ public function getDelimiter()
+ {
+ return $this->delimiter;
+ }
+
+ /**
+ * @return string
+ */
+ public function getPrefix()
+ {
+ return $this->prefix;
+ }
+
+ /**
+ * @return int
+ */
+ public function getMaxUploads()
+ {
+ return $this->maxUploads;
+ }
+
+ /**
+ * @return string
+ */
+ public function getIsTruncated()
+ {
+ return $this->isTruncated;
+ }
+
+ /**
+ * @return UploadInfo[]
+ */
+ public function getUploads()
+ {
+ return $this->uploads;
+ }
+
+ private $bucket = "";
+ private $keyMarker = "";
+ private $uploadIdMarker = "";
+ private $nextKeyMarker = "";
+ private $nextUploadIdMarker = "";
+ private $delimiter = "";
+ private $prefix = "";
+ private $maxUploads = 0;
+ private $isTruncated = "false";
+ private $uploads = array();
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ListPartsInfo.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ListPartsInfo.php
new file mode 100644
index 000000000..f1d10ee9e
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ListPartsInfo.php
@@ -0,0 +1,97 @@
+bucket = $bucket;
+ $this->key = $key;
+ $this->uploadId = $uploadId;
+ $this->nextPartNumberMarker = $nextPartNumberMarker;
+ $this->maxParts = $maxParts;
+ $this->isTruncated = $isTruncated;
+ $this->listPart = $listPart;
+ }
+
+ /**
+ * @return string
+ */
+ public function getBucket()
+ {
+ return $this->bucket;
+ }
+
+ /**
+ * @return string
+ */
+ public function getKey()
+ {
+ return $this->key;
+ }
+
+ /**
+ * @return string
+ */
+ public function getUploadId()
+ {
+ return $this->uploadId;
+ }
+
+ /**
+ * @return int
+ */
+ public function getNextPartNumberMarker()
+ {
+ return $this->nextPartNumberMarker;
+ }
+
+ /**
+ * @return int
+ */
+ public function getMaxParts()
+ {
+ return $this->maxParts;
+ }
+
+ /**
+ * @return string
+ */
+ public function getIsTruncated()
+ {
+ return $this->isTruncated;
+ }
+
+ /**
+ * @return array
+ */
+ public function getListPart()
+ {
+ return $this->listPart;
+ }
+
+ private $bucket = "";
+ private $key = "";
+ private $uploadId = "";
+ private $nextPartNumberMarker = 0;
+ private $maxParts = 0;
+ private $isTruncated = "";
+ private $listPart = array();
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelConfig.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelConfig.php
new file mode 100644
index 000000000..dadedc911
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelConfig.php
@@ -0,0 +1,121 @@
+description = $option['description'];
+ }
+ if (isset($option['status'])) {
+ $this->status = $option['status'];
+ }
+ if (isset($option['type'])) {
+ $this->type = $option['type'];
+ }
+ if (isset($option['fragDuration'])) {
+ $this->fragDuration = $option['fragDuration'];
+ }
+ if (isset($option['fragCount'])) {
+ $this->fragCount = $option['fragCount'];
+ }
+ if (isset($option['playListName'])) {
+ $this->playListName = $option['playListName'];
+ }
+ }
+
+ public function getDescription()
+ {
+ return $this->description;
+ }
+
+ public function getStatus()
+ {
+ return $this->status;
+ }
+
+ public function getType()
+ {
+ return $this->type;
+ }
+
+ public function getFragDuration()
+ {
+ return $this->fragDuration;
+ }
+
+ public function getFragCount()
+ {
+ return $this->fragCount;
+ }
+
+ public function getPlayListName()
+ {
+ return $this->playListName;
+ }
+
+ public function parseFromXml($strXml)
+ {
+ $xml = simplexml_load_string($strXml);
+ $this->description = strval($xml->Description);
+ $this->status = strval($xml->Status);
+ $target = $xml->Target;
+ $this->type = strval($target->Type);
+ $this->fragDuration = intval($target->FragDuration);
+ $this->fragCount = intval($target->FragCount);
+ $this->playListName = strval($target->PlayListName);
+ }
+
+ public function serializeToXml()
+ {
+ $strXml = <<
+
+
+EOF;
+ $xml = new \SimpleXMLElement($strXml);
+ if (isset($this->description)) {
+ $xml->addChild('Description', $this->description);
+ }
+
+ if (isset($this->status)) {
+ $xml->addChild('Status', $this->status);
+ }
+
+ $node = $xml->addChild('Target');
+ $node->addChild('Type', $this->type);
+
+ if (isset($this->fragDuration)) {
+ $node->addChild('FragDuration', $this->fragDuration);
+ }
+
+ if (isset($this->fragCount)) {
+ $node->addChild('FragCount', $this->fragCount);
+ }
+
+ if (isset($this->playListName)) {
+ $node->addChild('PlayListName', $this->playListName);
+ }
+
+ return $xml->asXML();
+ }
+
+ public function __toString()
+ {
+ return $this->serializeToXml();
+ }
+
+ private $description;
+ private $status = "enabled";
+ private $type;
+ private $fragDuration = 5;
+ private $fragCount = 3;
+ private $playListName = "playlist.m3u8";
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelHistory.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelHistory.php
new file mode 100644
index 000000000..1c1fd4dbc
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelHistory.php
@@ -0,0 +1,59 @@
+startTime;
+ }
+
+ public function getEndTime()
+ {
+ return $this->endTime;
+ }
+
+ public function getRemoteAddr()
+ {
+ return $this->remoteAddr;
+ }
+
+ public function parseFromXmlNode($xml)
+ {
+ if (isset($xml->StartTime)) {
+ $this->startTime = strval($xml->StartTime);
+ }
+
+ if (isset($xml->EndTime)) {
+ $this->endTime = strval($xml->EndTime);
+ }
+
+ if (isset($xml->RemoteAddr)) {
+ $this->remoteAddr = strval($xml->RemoteAddr);
+ }
+ }
+
+ public function parseFromXml($strXml)
+ {
+ $xml = simplexml_load_string($strXml);
+ $this->parseFromXmlNode($xml);
+ }
+
+ public function serializeToXml()
+ {
+ throw new OssException("Not implemented.");
+ }
+
+ private $startTime;
+ private $endTime;
+ private $remoteAddr;
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelInfo.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelInfo.php
new file mode 100644
index 000000000..c63ec54d6
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelInfo.php
@@ -0,0 +1,107 @@
+name = $name;
+ $this->description = $description;
+ $this->publishUrls = array();
+ $this->playUrls = array();
+ }
+
+ public function getName()
+ {
+ return $this->name;
+ }
+
+ public function setName($name)
+ {
+ $this->name = $name;
+ }
+
+ public function getPublishUrls()
+ {
+ return $this->publishUrls;
+ }
+
+ public function getPlayUrls()
+ {
+ return $this->playUrls;
+ }
+
+ public function getStatus()
+ {
+ return $this->status;
+ }
+
+ public function getLastModified()
+ {
+ return $this->lastModified;
+ }
+
+ public function getDescription()
+ {
+ return $this->description;
+ }
+
+ public function setDescription($description)
+ {
+ $this->description = $description;
+ }
+
+ public function parseFromXmlNode($xml)
+ {
+ if (isset($xml->Name)) {
+ $this->name = strval($xml->Name);
+ }
+
+ if (isset($xml->Description)) {
+ $this->description = strval($xml->Description);
+ }
+
+ if (isset($xml->Status)) {
+ $this->status = strval($xml->Status);
+ }
+
+ if (isset($xml->LastModified)) {
+ $this->lastModified = strval($xml->LastModified);
+ }
+
+ if (isset($xml->PublishUrls)) {
+ foreach ($xml->PublishUrls as $url) {
+ $this->publishUrls[] = strval($url->Url);
+ }
+ }
+
+ if (isset($xml->PlayUrls)) {
+ foreach ($xml->PlayUrls as $url) {
+ $this->playUrls[] = strval($url->Url);
+ }
+ }
+ }
+
+ public function parseFromXml($strXml)
+ {
+ $xml = simplexml_load_string($strXml);
+ $this->parseFromXmlNode($xml);
+ }
+
+ public function serializeToXml()
+ {
+ throw new OssException("Not implemented.");
+ }
+
+ private $name;
+ private $description;
+ private $publishUrls;
+ private $playUrls;
+ private $status;
+ private $lastModified;
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelListInfo.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelListInfo.php
new file mode 100644
index 000000000..bb5093aa8
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LiveChannelListInfo.php
@@ -0,0 +1,107 @@
+bucket;
+ }
+
+ public function setBucketName($name)
+ {
+ $this->bucket = $name;
+ }
+
+ /**
+ * @return string
+ */
+ public function getPrefix()
+ {
+ return $this->prefix;
+ }
+
+ /**
+ * @return string
+ */
+ public function getMarker()
+ {
+ return $this->marker;
+ }
+
+ /**
+ * @return int
+ */
+ public function getMaxKeys()
+ {
+ return $this->maxKeys;
+ }
+
+ /**
+ * @return mixed
+ */
+ public function getIsTruncated()
+ {
+ return $this->isTruncated;
+ }
+
+ /**
+ * @return LiveChannelInfo[]
+ */
+ public function getChannelList()
+ {
+ return $this->channelList;
+ }
+
+ /**
+ * @return string
+ */
+ public function getNextMarker()
+ {
+ return $this->nextMarker;
+ }
+
+ public function parseFromXml($strXml)
+ {
+ $xml = simplexml_load_string($strXml);
+
+ $this->prefix = strval($xml->Prefix);
+ $this->marker = strval($xml->Marker);
+ $this->maxKeys = intval($xml->MaxKeys);
+ $this->isTruncated = (strval($xml->IsTruncated) == 'true');
+ $this->nextMarker = strval($xml->NextMarker);
+
+ if (isset($xml->LiveChannel)) {
+ foreach ($xml->LiveChannel as $chan) {
+ $channel = new LiveChannelInfo();
+ $channel->parseFromXmlNode($chan);
+ $this->channelList[] = $channel;
+ }
+ }
+ }
+
+ public function serializeToXml()
+ {
+ throw new OssException("Not implemented.");
+ }
+
+ private $bucket = '';
+ private $prefix = '';
+ private $marker = '';
+ private $nextMarker = '';
+ private $maxKeys = 100;
+ private $isTruncated = 'false';
+ private $channelList = array();
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LoggingConfig.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LoggingConfig.php
new file mode 100644
index 000000000..978421a25
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/LoggingConfig.php
@@ -0,0 +1,86 @@
+targetBucket = $targetBucket;
+ $this->targetPrefix = $targetPrefix;
+ }
+
+ /**
+ * @param $strXml
+ * @return null
+ */
+ public function parseFromXml($strXml)
+ {
+ $xml = simplexml_load_string($strXml);
+ if (!isset($xml->LoggingEnabled)) return;
+ foreach ($xml->LoggingEnabled as $status) {
+ foreach ($status as $key => $value) {
+ if ($key === 'TargetBucket') {
+ $this->targetBucket = strval($value);
+ } elseif ($key === 'TargetPrefix') {
+ $this->targetPrefix = strval($value);
+ }
+ }
+ break;
+ }
+ }
+
+ /**
+ * 序列化成xml字符串
+ *
+ */
+ public function serializeToXml()
+ {
+ $xml = new \SimpleXMLElement(' ');
+ if (isset($this->targetBucket) && isset($this->targetPrefix)) {
+ $loggingEnabled = $xml->addChild('LoggingEnabled');
+ $loggingEnabled->addChild('TargetBucket', $this->targetBucket);
+ $loggingEnabled->addChild('TargetPrefix', $this->targetPrefix);
+ }
+ return $xml->asXML();
+ }
+
+ /**
+ * @return string
+ */
+ public function __toString()
+ {
+ return $this->serializeToXml();
+ }
+
+ /**
+ * @return string
+ */
+ public function getTargetBucket()
+ {
+ return $this->targetBucket;
+ }
+
+ /**
+ * @return string
+ */
+ public function getTargetPrefix()
+ {
+ return $this->targetPrefix;
+ }
+
+ private $targetBucket = "";
+ private $targetPrefix = "";
+
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ObjectInfo.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ObjectInfo.php
new file mode 100644
index 000000000..2ae6c99bd
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ObjectInfo.php
@@ -0,0 +1,93 @@
+key = $key;
+ $this->lastModified = $lastModified;
+ $this->eTag = $eTag;
+ $this->type = $type;
+ $this->size = $size;
+ $this->storageClass = $storageClass;
+ }
+
+ /**
+ * @return string
+ */
+ public function getKey()
+ {
+ return $this->key;
+ }
+
+ /**
+ * @return string
+ */
+ public function getLastModified()
+ {
+ return $this->lastModified;
+ }
+
+ /**
+ * @return string
+ */
+ public function getETag()
+ {
+ return $this->eTag;
+ }
+
+ /**
+ * @return string
+ */
+ public function getType()
+ {
+ return $this->type;
+ }
+
+ /**
+ * @return int
+ */
+ public function getSize()
+ {
+ return $this->size;
+ }
+
+ /**
+ * @return string
+ */
+ public function getStorageClass()
+ {
+ return $this->storageClass;
+ }
+
+ private $key = "";
+ private $lastModified = "";
+ private $eTag = "";
+ private $type = "";
+ private $size = 0;
+ private $storageClass = "";
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ObjectListInfo.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ObjectListInfo.php
new file mode 100644
index 000000000..dbe7c7a76
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/ObjectListInfo.php
@@ -0,0 +1,126 @@
+bucketName = $bucketName;
+ $this->prefix = $prefix;
+ $this->marker = $marker;
+ $this->nextMarker = $nextMarker;
+ $this->maxKeys = $maxKeys;
+ $this->delimiter = $delimiter;
+ $this->isTruncated = $isTruncated;
+ $this->objectList = $objectList;
+ $this->prefixList = $prefixList;
+ }
+
+ /**
+ * @return string
+ */
+ public function getBucketName()
+ {
+ return $this->bucketName;
+ }
+
+ /**
+ * @return string
+ */
+ public function getPrefix()
+ {
+ return $this->prefix;
+ }
+
+ /**
+ * @return string
+ */
+ public function getMarker()
+ {
+ return $this->marker;
+ }
+
+ /**
+ * @return int
+ */
+ public function getMaxKeys()
+ {
+ return $this->maxKeys;
+ }
+
+ /**
+ * @return string
+ */
+ public function getDelimiter()
+ {
+ return $this->delimiter;
+ }
+
+ /**
+ * @return mixed
+ */
+ public function getIsTruncated()
+ {
+ return $this->isTruncated;
+ }
+
+ /**
+ * 返回ListObjects接口返回数据中的ObjectInfo列表
+ *
+ * @return ObjectInfo[]
+ */
+ public function getObjectList()
+ {
+ return $this->objectList;
+ }
+
+ /**
+ * 返回ListObjects接口返回数据中的PrefixInfo列表
+ *
+ * @return PrefixInfo[]
+ */
+ public function getPrefixList()
+ {
+ return $this->prefixList;
+ }
+
+ /**
+ * @return string
+ */
+ public function getNextMarker()
+ {
+ return $this->nextMarker;
+ }
+
+ private $bucketName = "";
+ private $prefix = "";
+ private $marker = "";
+ private $nextMarker = "";
+ private $maxKeys = 0;
+ private $delimiter = "";
+ private $isTruncated = null;
+ private $objectList = array();
+ private $prefixList = array();
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/PartInfo.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/PartInfo.php
new file mode 100644
index 000000000..439a84d31
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/PartInfo.php
@@ -0,0 +1,63 @@
+partNumber = $partNumber;
+ $this->lastModified = $lastModified;
+ $this->eTag = $eTag;
+ $this->size = $size;
+ }
+
+ /**
+ * @return int
+ */
+ public function getPartNumber()
+ {
+ return $this->partNumber;
+ }
+
+ /**
+ * @return string
+ */
+ public function getLastModified()
+ {
+ return $this->lastModified;
+ }
+
+ /**
+ * @return string
+ */
+ public function getETag()
+ {
+ return $this->eTag;
+ }
+
+ /**
+ * @return int
+ */
+ public function getSize()
+ {
+ return $this->size;
+ }
+
+ private $partNumber = 0;
+ private $lastModified = "";
+ private $eTag = "";
+ private $size = 0;
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/PrefixInfo.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/PrefixInfo.php
new file mode 100644
index 000000000..e61eac449
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/PrefixInfo.php
@@ -0,0 +1,36 @@
+prefix = $prefix;
+ }
+
+ /**
+ * @return string
+ */
+ public function getPrefix()
+ {
+ return $this->prefix;
+ }
+
+ private $prefix;
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/RefererConfig.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/RefererConfig.php
new file mode 100644
index 000000000..1d7d975c5
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/RefererConfig.php
@@ -0,0 +1,93 @@
+AllowEmptyReferer)) return;
+ if (!isset($xml->RefererList)) return;
+ $this->allowEmptyReferer =
+ (strval($xml->AllowEmptyReferer) === 'TRUE' || strval($xml->AllowEmptyReferer) === 'true') ? true : false;
+
+ foreach ($xml->RefererList->Referer as $key => $refer) {
+ $this->refererList[] = strval($refer);
+ }
+ }
+
+
+ /**
+ * 把RefererConfig序列化成xml
+ *
+ * @return string
+ */
+ public function serializeToXml()
+ {
+ $xml = new \SimpleXMLElement(' ');
+ if ($this->allowEmptyReferer) {
+ $xml->addChild('AllowEmptyReferer', 'true');
+ } else {
+ $xml->addChild('AllowEmptyReferer', 'false');
+ }
+ $refererList = $xml->addChild('RefererList');
+ foreach ($this->refererList as $referer) {
+ $refererList->addChild('Referer', $referer);
+ }
+ return $xml->asXML();
+ }
+
+ /**
+ * @return string
+ */
+ function __toString()
+ {
+ return $this->serializeToXml();
+ }
+
+ /**
+ * @param boolean $allowEmptyReferer
+ */
+ public function setAllowEmptyReferer($allowEmptyReferer)
+ {
+ $this->allowEmptyReferer = $allowEmptyReferer;
+ }
+
+ /**
+ * @param string $referer
+ */
+ public function addReferer($referer)
+ {
+ $this->refererList[] = $referer;
+ }
+
+ /**
+ * @return boolean
+ */
+ public function isAllowEmptyReferer()
+ {
+ return $this->allowEmptyReferer;
+ }
+
+ /**
+ * @return array
+ */
+ public function getRefererList()
+ {
+ return $this->refererList;
+ }
+
+ private $allowEmptyReferer = true;
+ private $refererList = array();
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/UploadInfo.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/UploadInfo.php
new file mode 100644
index 000000000..8eaa3639f
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/UploadInfo.php
@@ -0,0 +1,55 @@
+key = $key;
+ $this->uploadId = $uploadId;
+ $this->initiated = $initiated;
+ }
+
+ /**
+ * @return string
+ */
+ public function getKey()
+ {
+ return $this->key;
+ }
+
+ /**
+ * @return string
+ */
+ public function getUploadId()
+ {
+ return $this->uploadId;
+ }
+
+ /**
+ * @return string
+ */
+ public function getInitiated()
+ {
+ return $this->initiated;
+ }
+
+ private $key = "";
+ private $uploadId = "";
+ private $initiated = "";
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/WebsiteConfig.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/WebsiteConfig.php
new file mode 100644
index 000000000..8ea08a030
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/WebsiteConfig.php
@@ -0,0 +1,76 @@
+indexDocument = $indexDocument;
+ $this->errorDocument = $errorDocument;
+ }
+
+ /**
+ * @param string $strXml
+ * @return null
+ */
+ public function parseFromXml($strXml)
+ {
+ $xml = simplexml_load_string($strXml);
+ if (isset($xml->IndexDocument) && isset($xml->IndexDocument->Suffix)) {
+ $this->indexDocument = strval($xml->IndexDocument->Suffix);
+ }
+ if (isset($xml->ErrorDocument) && isset($xml->ErrorDocument->Key)) {
+ $this->errorDocument = strval($xml->ErrorDocument->Key);
+ }
+ }
+
+ /**
+ * 把WebsiteConfig序列化成xml
+ *
+ * @return string
+ * @throws OssException
+ */
+ public function serializeToXml()
+ {
+ $xml = new \SimpleXMLElement(' ');
+ $index_document_part = $xml->addChild('IndexDocument');
+ $error_document_part = $xml->addChild('ErrorDocument');
+ $index_document_part->addChild('Suffix', $this->indexDocument);
+ $error_document_part->addChild('Key', $this->errorDocument);
+ return $xml->asXML();
+ }
+
+ /**
+ * @return string
+ */
+ public function getIndexDocument()
+ {
+ return $this->indexDocument;
+ }
+
+ /**
+ * @return string
+ */
+ public function getErrorDocument()
+ {
+ return $this->errorDocument;
+ }
+
+ private $indexDocument = "";
+ private $errorDocument = "";
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/XmlConfig.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/XmlConfig.php
new file mode 100644
index 000000000..d353a2221
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Model/XmlConfig.php
@@ -0,0 +1,27 @@
+hostname = $this->checkEndpoint($endpoint, $isCName);
+ $this->accessKeyId = $accessKeyId;
+ $this->accessKeySecret = $accessKeySecret;
+ $this->securityToken = $securityToken;
+ self::checkEnv();
+ }
+
+ /**
+ * 列举用户所有的Bucket[GetService], Endpoint类型为cname不能进行此操作
+ *
+ * @param array $options
+ * @throws OssException
+ * @return BucketListInfo
+ */
+ public function listBuckets($options = NULL)
+ {
+ if ($this->hostType === self::OSS_HOST_TYPE_CNAME) {
+ throw new OssException("operation is not permitted with CName host");
+ }
+ $this->precheckOptions($options);
+ $options[self::OSS_BUCKET] = '';
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = '/';
+ $response = $this->auth($options);
+ $result = new ListBucketsResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 创建bucket,默认创建的bucket的ACL是OssClient::OSS_ACL_TYPE_PRIVATE
+ *
+ * @param string $bucket
+ * @param string $acl
+ * @param array $options
+ * @return null
+ */
+ public function createBucket($bucket, $acl = self::OSS_ACL_TYPE_PRIVATE, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_HEADERS] = array(self::OSS_ACL => $acl);
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 删除bucket
+ * 如果Bucket不为空(Bucket中有Object,或者有分块上传的碎片),则Bucket无法删除,
+ * 必须删除Bucket中的所有Object以及碎片后,Bucket才能成功删除。
+ *
+ * @param string $bucket
+ * @param array $options
+ * @return null
+ */
+ public function deleteBucket($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_DELETE;
+ $options[self::OSS_OBJECT] = '/';
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 判断bucket是否存在
+ *
+ * @param string $bucket
+ * @return bool
+ * @throws OssException
+ */
+ public function doesBucketExist($bucket)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'acl';
+ $response = $this->auth($options);
+ $result = new ExistResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取bucket的ACL配置情况
+ *
+ * @param string $bucket
+ * @param array $options
+ * @throws OssException
+ * @return string
+ */
+ public function getBucketAcl($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'acl';
+ $response = $this->auth($options);
+ $result = new AclResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 设置bucket的ACL配置情况
+ *
+ * @param string $bucket bucket名称
+ * @param string $acl 读写权限,可选值 ['private', 'public-read', 'public-read-write']
+ * @param array $options 可以为空
+ * @throws OssException
+ * @return null
+ */
+ public function putBucketAcl($bucket, $acl, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_HEADERS] = array(self::OSS_ACL => $acl);
+ $options[self::OSS_SUB_RESOURCE] = 'acl';
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取object的ACL属性
+ *
+ * @param string $bucket
+ * @param string $object
+ * @throws OssException
+ * @return string
+ */
+ public function getObjectAcl($bucket, $object)
+ {
+ $options = array();
+ $this->precheckCommon($bucket, $object, $options, true);
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_OBJECT] = $object;
+ $options[self::OSS_SUB_RESOURCE] = 'acl';
+ $response = $this->auth($options);
+ $result = new AclResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 设置object的ACL属性
+ *
+ * @param string $bucket bucket名称
+ * @param string $object object名称
+ * @param string $acl 读写权限,可选值 ['default', 'private', 'public-read', 'public-read-write']
+ * @throws OssException
+ * @return null
+ */
+ public function putObjectAcl($bucket, $object, $acl)
+ {
+ $this->precheckCommon($bucket, $object, $options, true);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_OBJECT] = $object;
+ $options[self::OSS_HEADERS] = array(self::OSS_OBJECT_ACL => $acl);
+ $options[self::OSS_SUB_RESOURCE] = 'acl';
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取Bucket的访问日志配置情况
+ *
+ * @param string $bucket bucket名称
+ * @param array $options 可以为空
+ * @throws OssException
+ * @return LoggingConfig
+ */
+ public function getBucketLogging($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'logging';
+ $response = $this->auth($options);
+ $result = new GetLoggingResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 开启Bucket访问日志记录功能,只有Bucket的所有者才能更改
+ *
+ * @param string $bucket bucket名称
+ * @param string $targetBucket 日志文件存放的bucket
+ * @param string $targetPrefix 日志的文件前缀
+ * @param array $options 可以为空
+ * @throws OssException
+ * @return null
+ */
+ public function putBucketLogging($bucket, $targetBucket, $targetPrefix, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $this->precheckBucket($targetBucket, 'targetbucket is not allowed empty');
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'logging';
+ $options[self::OSS_CONTENT_TYPE] = 'application/xml';
+
+ $loggingConfig = new LoggingConfig($targetBucket, $targetPrefix);
+ $options[self::OSS_CONTENT] = $loggingConfig->serializeToXml();
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 关闭bucket访问日志记录功能
+ *
+ * @param string $bucket bucket名称
+ * @param array $options 可以为空
+ * @throws OssException
+ * @return null
+ */
+ public function deleteBucketLogging($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_DELETE;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'logging';
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 将bucket设置成静态网站托管模式
+ *
+ * @param string $bucket bucket名称
+ * @param WebsiteConfig $websiteConfig
+ * @param array $options 可以为空
+ * @throws OssException
+ * @return null
+ */
+ public function putBucketWebsite($bucket, $websiteConfig, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'website';
+ $options[self::OSS_CONTENT_TYPE] = 'application/xml';
+ $options[self::OSS_CONTENT] = $websiteConfig->serializeToXml();
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取bucket的静态网站托管状态
+ *
+ * @param string $bucket bucket名称
+ * @param array $options
+ * @throws OssException
+ * @return WebsiteConfig
+ */
+ public function getBucketWebsite($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'website';
+ $response = $this->auth($options);
+ $result = new GetWebsiteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 关闭bucket的静态网站托管模式
+ *
+ * @param string $bucket bucket名称
+ * @param array $options
+ * @throws OssException
+ * @return null
+ */
+ public function deleteBucketWebsite($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_DELETE;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'website';
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 在指定的bucket上设定一个跨域资源共享(CORS)的规则,如果原规则存在则覆盖原规则
+ *
+ * @param string $bucket bucket名称
+ * @param CorsConfig $corsConfig 跨域资源共享配置,具体规则参见SDK文档
+ * @param array $options array
+ * @throws OssException
+ * @return null
+ */
+ public function putBucketCors($bucket, $corsConfig, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'cors';
+ $options[self::OSS_CONTENT_TYPE] = 'application/xml';
+ $options[self::OSS_CONTENT] = $corsConfig->serializeToXml();
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取Bucket的CORS配置情况
+ *
+ * @param string $bucket bucket名称
+ * @param array $options 可以为空
+ * @throws OssException
+ * @return CorsConfig
+ */
+ public function getBucketCors($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'cors';
+ $response = $this->auth($options);
+ $result = new GetCorsResult($response, __FUNCTION__);
+ return $result->getData();
+ }
+
+ /**
+ * 关闭指定Bucket对应的CORS功能并清空所有规则
+ *
+ * @param string $bucket bucket名称
+ * @param array $options
+ * @throws OssException
+ * @return null
+ */
+ public function deleteBucketCors($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_DELETE;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'cors';
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 为指定Bucket增加CNAME绑定
+ *
+ * @param string $bucket bucket名称
+ * @param string $cname
+ * @param array $options
+ * @throws OssException
+ * @return null
+ */
+ public function addBucketCname($bucket, $cname, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_POST;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'cname';
+ $options[self::OSS_CONTENT_TYPE] = 'application/xml';
+ $cnameConfig = new CnameConfig();
+ $cnameConfig->addCname($cname);
+ $options[self::OSS_CONTENT] = $cnameConfig->serializeToXml();
+ $options[self::OSS_COMP] = 'add';
+
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取指定Bucket已绑定的CNAME列表
+ *
+ * @param string $bucket bucket名称
+ * @param array $options
+ * @throws OssException
+ * @return CnameConfig
+ */
+ public function getBucketCname($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'cname';
+ $response = $this->auth($options);
+ $result = new GetCnameResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 解除指定Bucket的CNAME绑定
+ *
+ * @param string $bucket bucket名称
+ * @param CnameConfig $cnameConfig
+ * @param array $options
+ * @throws OssException
+ * @return null
+ */
+ public function deleteBucketCname($bucket, $cname, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_POST;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'cname';
+ $options[self::OSS_CONTENT_TYPE] = 'application/xml';
+ $cnameConfig = new CnameConfig();
+ $cnameConfig->addCname($cname);
+ $options[self::OSS_CONTENT] = $cnameConfig->serializeToXml();
+ $options[self::OSS_COMP] = 'delete';
+
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 为指定Bucket创建LiveChannel
+ *
+ * @param string $bucket bucket名称
+ * @param string channelName $channelName
+ * @param LiveChannelConfig $channelConfig
+ * @param array $options
+ * @throws OssException
+ * @return LiveChannelInfo
+ */
+ public function putBucketLiveChannel($bucket, $channelName, $channelConfig, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_OBJECT] = $channelName;
+ $options[self::OSS_SUB_RESOURCE] = 'live';
+ $options[self::OSS_CONTENT_TYPE] = 'application/xml';
+ $options[self::OSS_CONTENT] = $channelConfig->serializeToXml();
+
+ $response = $this->auth($options);
+ $result = new PutLiveChannelResult($response);
+ $info = $result->getData();
+ $info->setName($channelName);
+ $info->setDescription($channelConfig->getDescription());
+
+ return $info;
+ }
+
+ /**
+ * 设置LiveChannel的status
+ *
+ * @param string $bucket bucket名称
+ * @param string channelName $channelName
+ * @param string channelStatus $channelStatus 为enabled或disabled
+ * @param array $options
+ * @throws OssException
+ * @return null
+ */
+ public function putLiveChannelStatus($bucket, $channelName, $channelStatus, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_OBJECT] = $channelName;
+ $options[self::OSS_SUB_RESOURCE] = 'live';
+ $options[self::OSS_LIVE_CHANNEL_STATUS] = $channelStatus;
+
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取LiveChannel信息
+ *
+ * @param string $bucket bucket名称
+ * @param string channelName $channelName
+ * @param array $options
+ * @throws OssException
+ * @return GetLiveChannelInfo
+ */
+ public function getLiveChannelInfo($bucket, $channelName, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = $channelName;
+ $options[self::OSS_SUB_RESOURCE] = 'live';
+
+ $response = $this->auth($options);
+ $result = new GetLiveChannelInfoResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取LiveChannel状态信息
+ *
+ * @param string $bucket bucket名称
+ * @param string channelName $channelName
+ * @param array $options
+ * @throws OssException
+ * @return GetLiveChannelStatus
+ */
+ public function getLiveChannelStatus($bucket, $channelName, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = $channelName;
+ $options[self::OSS_SUB_RESOURCE] = 'live';
+ $options[self::OSS_COMP] = 'stat';
+
+ $response = $this->auth($options);
+ $result = new GetLiveChannelStatusResult($response);
+ return $result->getData();
+ }
+
+ /**
+ *获取LiveChannel推流记录
+ *
+ * @param string $bucket bucket名称
+ * @param string channelName $channelName
+ * @param array $options
+ * @throws OssException
+ * @return GetLiveChannelHistory
+ */
+ public function getLiveChannelHistory($bucket, $channelName, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = $channelName;
+ $options[self::OSS_SUB_RESOURCE] = 'live';
+ $options[self::OSS_COMP] = 'history';
+
+ $response = $this->auth($options);
+ $result = new GetLiveChannelHistoryResult($response);
+ return $result->getData();
+ }
+
+ /**
+ *获取指定Bucket下的live channel列表
+ *
+ * @param string $bucket bucket名称
+ * @param array $options
+ * @throws OssException
+ * @return LiveChannelListInfo
+ */
+ public function listBucketLiveChannels($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'live';
+ $options[self::OSS_QUERY_STRING] = array(
+ 'prefix' => isset($options['prefix']) ? $options['prefix'] : '',
+ 'marker' => isset($options['marker']) ? $options['marker'] : '',
+ 'max-keys' => isset($options['max-keys']) ? $options['max-keys'] : '',
+ );
+ $response = $this->auth($options);
+ $result = new ListLiveChannelResult($response);
+ $list = $result->getData();
+ $list->setBucketName($bucket);
+
+ return $list;
+ }
+
+ /**
+ * 为指定LiveChannel生成播放列表
+ *
+ * @param string $bucket bucket名称
+ * @param string channelName $channelName
+ * @param string $playlistName 指定生成的点播播放列表的名称,必须以“.m3u8”结尾
+ * @param array $setTime startTime和EndTime以unix时间戳格式给定,跨度不能超过一天
+ * @throws OssException
+ * @return null
+ */
+ public function postVodPlaylist($bucket, $channelName, $playlistName, $setTime)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_POST;
+ $options[self::OSS_OBJECT] = $channelName . '/' . $playlistName;
+ $options[self::OSS_SUB_RESOURCE] = 'vod';
+ $options[self::OSS_LIVE_CHANNEL_END_TIME] = $setTime['EndTime'];
+ $options[self::OSS_LIVE_CHANNEL_START_TIME] = $setTime['StartTime'];
+
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 删除指定Bucket的LiveChannel
+ *
+ * @param string $bucket bucket名称
+ * @param string channelName $channelName
+ * @param array $options
+ * @throws OssException
+ * @return null
+ */
+ public function deleteBucketLiveChannel($bucket, $channelName, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_DELETE;
+ $options[self::OSS_OBJECT] = $channelName;
+ $options[self::OSS_SUB_RESOURCE] = 'live';
+
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 生成带签名的推流地址
+ *
+ * @param string $bucket bucket名称
+ * @param string channelName $channelName
+ * @param int timeout 设置超时时间,单位为秒
+ * @param array $options
+ * @throws OssException
+ * @return 推流地址
+ */
+ public function signRtmpUrl($bucket, $channelName, $timeout = 60, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $channelName, $options, false);
+ $expires = time() + $timeout;
+ $proto = 'rtmp://';
+ $hostname = $this->generateHostname($bucket);
+ $cano_params = '';
+ $query_items = array();
+ $params = isset($options['params']) ? $options['params'] : array();
+ uksort($params, 'strnatcasecmp');
+ foreach ($params as $key => $value) {
+ $cano_params = $cano_params . $key . ':' . $value . "\n";
+ $query_items[] = rawurlencode($key) . '=' . rawurlencode($value);
+ }
+ $resource = '/' . $bucket . '/' . $channelName;
+
+ $string_to_sign = $expires . "\n" . $cano_params . $resource;
+ $signature = base64_encode(hash_hmac('sha1', $string_to_sign, $this->accessKeySecret, true));
+
+ $query_items[] = 'OSSAccessKeyId=' . rawurlencode($this->accessKeyId);
+ $query_items[] = 'Expires=' . rawurlencode($expires);
+ $query_items[] = 'Signature=' . rawurlencode($signature);
+
+ return $proto . $hostname . '/live/' . $channelName . '?' . implode('&', $query_items);
+ }
+
+ /**
+ * 检验跨域资源请求, 发送跨域请求之前会发送一个preflight请求(OPTIONS)并带上特定的来源域,
+ * HTTP方法和header信息等给OSS以决定是否发送真正的请求。 OSS可以通过putBucketCors接口
+ * 来开启Bucket的CORS支持,开启CORS功能之后,OSS在收到浏览器preflight请求时会根据设定的
+ * 规则评估是否允许本次请求
+ *
+ * @param string $bucket bucket名称
+ * @param string $object object名称
+ * @param string $origin 请求来源域
+ * @param string $request_method 表明实际请求中会使用的HTTP方法
+ * @param string $request_headers 表明实际请求中会使用的除了简单头部之外的headers
+ * @param array $options
+ * @return array
+ * @throws OssException
+ * @link http://help.aliyun.com/document_detail/oss/api-reference/cors/OptionObject.html
+ */
+ public function optionsObject($bucket, $object, $origin, $request_method, $request_headers, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_OPTIONS;
+ $options[self::OSS_OBJECT] = $object;
+ $options[self::OSS_HEADERS] = array(
+ self::OSS_OPTIONS_ORIGIN => $origin,
+ self::OSS_OPTIONS_REQUEST_HEADERS => $request_headers,
+ self::OSS_OPTIONS_REQUEST_METHOD => $request_method
+ );
+ $response = $this->auth($options);
+ $result = new HeaderResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 设置Bucket的Lifecycle配置
+ *
+ * @param string $bucket bucket名称
+ * @param LifecycleConfig $lifecycleConfig Lifecycle配置类
+ * @param array $options
+ * @throws OssException
+ * @return null
+ */
+ public function putBucketLifecycle($bucket, $lifecycleConfig, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'lifecycle';
+ $options[self::OSS_CONTENT_TYPE] = 'application/xml';
+ $options[self::OSS_CONTENT] = $lifecycleConfig->serializeToXml();
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取Bucket的Lifecycle配置情况
+ *
+ * @param string $bucket bucket名称
+ * @param array $options
+ * @throws OssException
+ * @return LifecycleConfig
+ */
+ public function getBucketLifecycle($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'lifecycle';
+ $response = $this->auth($options);
+ $result = new GetLifecycleResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 删除指定Bucket的生命周期配置
+ *
+ * @param string $bucket bucket名称
+ * @param array $options
+ * @throws OssException
+ * @return null
+ */
+ public function deleteBucketLifecycle($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_DELETE;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'lifecycle';
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 设置一个bucket的referer访问白名单和是否允许referer字段为空的请求访问
+ * Bucket Referer防盗链具体见OSS防盗链
+ *
+ * @param string $bucket bucket名称
+ * @param RefererConfig $refererConfig
+ * @param array $options
+ * @return ResponseCore
+ * @throws null
+ */
+ public function putBucketReferer($bucket, $refererConfig, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'referer';
+ $options[self::OSS_CONTENT_TYPE] = 'application/xml';
+ $options[self::OSS_CONTENT] = $refererConfig->serializeToXml();
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取Bucket的Referer配置情况
+ * Bucket Referer防盗链具体见OSS防盗链
+ *
+ * @param string $bucket bucket名称
+ * @param array $options
+ * @throws OssException
+ * @return RefererConfig
+ */
+ public function getBucketReferer($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'referer';
+ $response = $this->auth($options);
+ $result = new GetRefererResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取bucket下的object列表
+ *
+ * @param string $bucket
+ * @param array $options
+ * 其中options中的参数如下
+ * $options = array(
+ * 'max-keys' => max-keys用于限定此次返回object的最大数,如果不设定,默认为100,max-keys取值不能大于1000。
+ * 'prefix' => 限定返回的object key必须以prefix作为前缀。注意使用prefix查询时,返回的key中仍会包含prefix。
+ * 'delimiter' => 是一个用于对Object名字进行分组的字符。所有名字包含指定的前缀且第一次出现delimiter字符之间的object作为一组元素
+ * 'marker' => 用户设定结果从marker之后按字母排序的第一个开始返回。
+ *)
+ * 其中 prefix,marker用来实现分页显示效果,参数的长度必须小于256字节。
+ * @throws OssException
+ * @return ObjectListInfo
+ */
+ public function listObjects($bucket, $options = NULL)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_HEADERS] = array(
+ self::OSS_DELIMITER => isset($options[self::OSS_DELIMITER]) ? $options[self::OSS_DELIMITER] : '/',
+ self::OSS_PREFIX => isset($options[self::OSS_PREFIX]) ? $options[self::OSS_PREFIX] : '',
+ self::OSS_MAX_KEYS => isset($options[self::OSS_MAX_KEYS]) ? $options[self::OSS_MAX_KEYS] : self::OSS_MAX_KEYS_VALUE,
+ self::OSS_MARKER => isset($options[self::OSS_MARKER]) ? $options[self::OSS_MARKER] : '',
+ );
+ $query = isset($options[self::OSS_QUERY_STRING]) ? $options[self::OSS_QUERY_STRING] : array();
+ $options[self::OSS_QUERY_STRING] = array_merge(
+ $query,
+ array(self::OSS_ENCODING_TYPE => self::OSS_ENCODING_TYPE_URL)
+ );
+
+ $response = $this->auth($options);
+ $result = new ListObjectsResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 创建虚拟目录 (本函数会在object名称后增加'/', 所以创建目录的object名称不需要'/'结尾,否则,目录名称会变成'//')
+ *
+ * 暂不开放此接口
+ *
+ * @param string $bucket bucket名称
+ * @param string $object object名称
+ * @param array $options
+ * @return null
+ */
+ public function createObjectDir($bucket, $object, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_OBJECT] = $object . '/';
+ $options[self::OSS_CONTENT_LENGTH] = array(self::OSS_CONTENT_LENGTH => 0);
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 上传内存中的内容
+ *
+ * @param string $bucket bucket名称
+ * @param string $object objcet名称
+ * @param string $content 上传的内容
+ * @param array $options
+ * @return null
+ */
+ public function putObject($bucket, $object, $content, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+
+ OssUtil::validateContent($content);
+ $options[self::OSS_CONTENT] = $content;
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_OBJECT] = $object;
+
+ if (!isset($options[self::OSS_LENGTH])) {
+ $options[self::OSS_CONTENT_LENGTH] = strlen($options[self::OSS_CONTENT]);
+ } else {
+ $options[self::OSS_CONTENT_LENGTH] = $options[self::OSS_LENGTH];
+ }
+
+ $is_check_md5 = $this->isCheckMD5($options);
+ if ($is_check_md5) {
+ $content_md5 = base64_encode(md5($content, true));
+ $options[self::OSS_CONTENT_MD5] = $content_md5;
+ }
+
+ if (!isset($options[self::OSS_CONTENT_TYPE])) {
+ $options[self::OSS_CONTENT_TYPE] = $this->getMimeType($object);
+ }
+ $response = $this->auth($options);
+
+ if (isset($options[self::OSS_CALLBACK]) && !empty($options[self::OSS_CALLBACK])) {
+ $result = new CallbackResult($response);
+ } else {
+ $result = new PutSetDeleteResult($response);
+ }
+
+ return $result->getData();
+ }
+
+ /**
+ * 上传本地文件
+ *
+ * @param string $bucket bucket名称
+ * @param string $object object名称
+ * @param string $file 本地文件路径
+ * @param array $options
+ * @return null
+ * @throws OssException
+ */
+ public function uploadFile($bucket, $object, $file, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+ OssUtil::throwOssExceptionWithMessageIfEmpty($file, "file path is invalid");
+ $file = OssUtil::encodePath($file);
+ if (!file_exists($file)) {
+ throw new OssException($file . " file does not exist");
+ }
+ $options[self::OSS_FILE_UPLOAD] = $file;
+ $file_size = filesize($options[self::OSS_FILE_UPLOAD]);
+ $is_check_md5 = $this->isCheckMD5($options);
+ if ($is_check_md5) {
+ $content_md5 = base64_encode(md5_file($options[self::OSS_FILE_UPLOAD], true));
+ $options[self::OSS_CONTENT_MD5] = $content_md5;
+ }
+ if (!isset($options[self::OSS_CONTENT_TYPE])) {
+ $options[self::OSS_CONTENT_TYPE] = $this->getMimeType($object, $file);
+ }
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_OBJECT] = $object;
+ $options[self::OSS_CONTENT_LENGTH] = $file_size;
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 追加上传内存中的内容
+ *
+ * @param string $bucket bucket名称
+ * @param string $object objcet名称
+ * @param string $content 本次追加上传的内容
+ * @param array $options
+ * @return int next append position
+ * @throws OssException
+ */
+ public function appendObject($bucket, $object, $content, $position, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+
+ OssUtil::validateContent($content);
+ $options[self::OSS_CONTENT] = $content;
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_POST;
+ $options[self::OSS_OBJECT] = $object;
+ $options[self::OSS_SUB_RESOURCE] = 'append';
+ $options[self::OSS_POSITION] = strval($position);
+
+ if (!isset($options[self::OSS_LENGTH])) {
+ $options[self::OSS_CONTENT_LENGTH] = strlen($options[self::OSS_CONTENT]);
+ } else {
+ $options[self::OSS_CONTENT_LENGTH] = $options[self::OSS_LENGTH];
+ }
+
+ $is_check_md5 = $this->isCheckMD5($options);
+ if ($is_check_md5) {
+ $content_md5 = base64_encode(md5($content, true));
+ $options[self::OSS_CONTENT_MD5] = $content_md5;
+ }
+
+ if (!isset($options[self::OSS_CONTENT_TYPE])) {
+ $options[self::OSS_CONTENT_TYPE] = $this->getMimeType($object);
+ }
+ $response = $this->auth($options);
+ $result = new AppendResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 追加上传本地文件
+ *
+ * @param string $bucket bucket名称
+ * @param string $object object名称
+ * @param string $file 追加上传的本地文件路径
+ * @param array $options
+ * @return int next append position
+ * @throws OssException
+ */
+ public function appendFile($bucket, $object, $file, $position, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+
+ OssUtil::throwOssExceptionWithMessageIfEmpty($file, "file path is invalid");
+ $file = OssUtil::encodePath($file);
+ if (!file_exists($file)) {
+ throw new OssException($file . " file does not exist");
+ }
+ $options[self::OSS_FILE_UPLOAD] = $file;
+ $file_size = filesize($options[self::OSS_FILE_UPLOAD]);
+ $is_check_md5 = $this->isCheckMD5($options);
+ if ($is_check_md5) {
+ $content_md5 = base64_encode(md5_file($options[self::OSS_FILE_UPLOAD], true));
+ $options[self::OSS_CONTENT_MD5] = $content_md5;
+ }
+ if (!isset($options[self::OSS_CONTENT_TYPE])) {
+ $options[self::OSS_CONTENT_TYPE] = $this->getMimeType($object, $file);
+ }
+
+ $options[self::OSS_METHOD] = self::OSS_HTTP_POST;
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_OBJECT] = $object;
+ $options[self::OSS_CONTENT_LENGTH] = $file_size;
+ $options[self::OSS_SUB_RESOURCE] = 'append';
+ $options[self::OSS_POSITION] = strval($position);
+
+ $response = $this->auth($options);
+ $result = new AppendResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 拷贝一个在OSS上已经存在的object成另外一个object
+ *
+ * @param string $fromBucket 源bucket名称
+ * @param string $fromObject 源object名称
+ * @param string $toBucket 目标bucket名称
+ * @param string $toObject 目标object名称
+ * @param array $options
+ * @return null
+ * @throws OssException
+ */
+ public function copyObject($fromBucket, $fromObject, $toBucket, $toObject, $options = NULL)
+ {
+ $this->precheckCommon($fromBucket, $fromObject, $options);
+ $this->precheckCommon($toBucket, $toObject, $options);
+ $options[self::OSS_BUCKET] = $toBucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_OBJECT] = $toObject;
+ if (isset($options[self::OSS_HEADERS])) {
+ $options[self::OSS_HEADERS][self::OSS_OBJECT_COPY_SOURCE] = '/' . $fromBucket . '/' . $fromObject;
+ } else {
+ $options[self::OSS_HEADERS] = array(self::OSS_OBJECT_COPY_SOURCE => '/' . $fromBucket . '/' . $fromObject);
+ }
+ $response = $this->auth($options);
+ $result = new CopyObjectResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取Object的Meta信息
+ *
+ * @param string $bucket bucket名称
+ * @param string $object object名称
+ * @param string $options 具体参考SDK文档
+ * @return array
+ */
+ public function getObjectMeta($bucket, $object, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_HEAD;
+ $options[self::OSS_OBJECT] = $object;
+ $response = $this->auth($options);
+ $result = new HeaderResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 删除某个Object
+ *
+ * @param string $bucket bucket名称
+ * @param string $object object名称
+ * @param array $options
+ * @return null
+ */
+ public function deleteObject($bucket, $object, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_DELETE;
+ $options[self::OSS_OBJECT] = $object;
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 删除同一个Bucket中的多个Object
+ *
+ * @param string $bucket bucket名称
+ * @param array $objects object列表
+ * @param array $options
+ * @return ResponseCore
+ * @throws null
+ */
+ public function deleteObjects($bucket, $objects, $options = null)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ if (!is_array($objects) || !$objects) {
+ throw new OssException('objects must be array');
+ }
+ $options[self::OSS_METHOD] = self::OSS_HTTP_POST;
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'delete';
+ $options[self::OSS_CONTENT_TYPE] = 'application/xml';
+ $quiet = 'false';
+ if (isset($options['quiet'])) {
+ if (is_bool($options['quiet'])) { //Boolean
+ $quiet = $options['quiet'] ? 'true' : 'false';
+ } elseif (is_string($options['quiet'])) { // string
+ $quiet = ($options['quiet'] === 'true') ? 'true' : 'false';
+ }
+ }
+ $xmlBody = OssUtil::createDeleteObjectsXmlBody($objects, $quiet);
+ $options[self::OSS_CONTENT] = $xmlBody;
+ $response = $this->auth($options);
+ $result = new DeleteObjectsResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获得Object内容
+ *
+ * @param string $bucket bucket名称
+ * @param string $object object名称
+ * @param array $options 该参数中必须设置ALIOSS::OSS_FILE_DOWNLOAD,ALIOSS::OSS_RANGE可选,可以根据实际情况设置;如果不设置,默认会下载全部内容
+ * @return string
+ */
+ public function getObject($bucket, $object, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_OBJECT] = $object;
+ if (isset($options[self::OSS_LAST_MODIFIED])) {
+ $options[self::OSS_HEADERS][self::OSS_IF_MODIFIED_SINCE] = $options[self::OSS_LAST_MODIFIED];
+ unset($options[self::OSS_LAST_MODIFIED]);
+ }
+ if (isset($options[self::OSS_ETAG])) {
+ $options[self::OSS_HEADERS][self::OSS_IF_NONE_MATCH] = $options[self::OSS_ETAG];
+ unset($options[self::OSS_ETAG]);
+ }
+ if (isset($options[self::OSS_RANGE])) {
+ $range = $options[self::OSS_RANGE];
+ $options[self::OSS_HEADERS][self::OSS_RANGE] = "bytes=$range";
+ unset($options[self::OSS_RANGE]);
+ }
+ $response = $this->auth($options);
+ $result = new BodyResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 检测Object是否存在
+ * 通过获取Object的Meta信息来判断Object是否存在, 用户需要自行解析ResponseCore判断object是否存在
+ *
+ * @param string $bucket bucket名称
+ * @param string $object object名称
+ * @param array $options
+ * @return bool
+ */
+ public function doesObjectExist($bucket, $object, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_METHOD] = self::OSS_HTTP_HEAD;
+ $options[self::OSS_OBJECT] = $object;
+ $response = $this->auth($options);
+ $result = new ExistResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取分片大小,根据用户提供的part_size,重新计算一个更合理的partsize
+ *
+ * @param int $partSize
+ * @return int
+ */
+ private function computePartSize($partSize)
+ {
+ $partSize = (integer)$partSize;
+ if ($partSize <= self::OSS_MIN_PART_SIZE) {
+ $partSize = self::OSS_MIN_PART_SIZE;
+ } elseif ($partSize > self::OSS_MAX_PART_SIZE) {
+ $partSize = self::OSS_MAX_PART_SIZE;
+ }
+ return $partSize;
+ }
+
+ /**
+ * 计算文件可以分成多少个part,以及每个part的长度以及起始位置
+ * 方法必须在 中调用
+ *
+ * @param integer $file_size 文件大小
+ * @param integer $partSize part大小,默认5M
+ * @return array An array 包含 key-value 键值对. Key 为 `seekTo` 和 `length`.
+ */
+ public function generateMultiuploadParts($file_size, $partSize = 5242880)
+ {
+ $i = 0;
+ $size_count = $file_size;
+ $values = array();
+ $partSize = $this->computePartSize($partSize);
+ while ($size_count > 0) {
+ $size_count -= $partSize;
+ $values[] = array(
+ self::OSS_SEEK_TO => ($partSize * $i),
+ self::OSS_LENGTH => (($size_count > 0) ? $partSize : ($size_count + $partSize)),
+ );
+ $i++;
+ }
+ return $values;
+ }
+
+ /**
+ * 初始化multi-part upload
+ *
+ * @param string $bucket Bucket名称
+ * @param string $object Object名称
+ * @param array $options Key-Value数组
+ * @throws OssException
+ * @return string 返回uploadid
+ */
+ public function initiateMultipartUpload($bucket, $object, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+ $options[self::OSS_METHOD] = self::OSS_HTTP_POST;
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_OBJECT] = $object;
+ $options[self::OSS_SUB_RESOURCE] = 'uploads';
+ $options[self::OSS_CONTENT] = '';
+
+ if (!isset($options[self::OSS_CONTENT_TYPE])) {
+ $options[self::OSS_CONTENT_TYPE] = $this->getMimeType($object);
+ }
+ if (!isset($options[self::OSS_HEADERS])) {
+ $options[self::OSS_HEADERS] = array();
+ }
+ $response = $this->auth($options);
+ $result = new InitiateMultipartUploadResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 分片上传的块上传接口
+ *
+ * @param string $bucket Bucket名称
+ * @param string $object Object名称
+ * @param string $uploadId
+ * @param array $options Key-Value数组
+ * @return string eTag
+ * @throws OssException
+ */
+ public function uploadPart($bucket, $object, $uploadId, $options = null)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+ $this->precheckParam($options, self::OSS_FILE_UPLOAD, __FUNCTION__);
+ $this->precheckParam($options, self::OSS_PART_NUM, __FUNCTION__);
+
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_OBJECT] = $object;
+ $options[self::OSS_UPLOAD_ID] = $uploadId;
+
+ if (isset($options[self::OSS_LENGTH])) {
+ $options[self::OSS_CONTENT_LENGTH] = $options[self::OSS_LENGTH];
+ }
+ $response = $this->auth($options);
+ $result = new UploadPartResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 获取已成功上传的part
+ *
+ * @param string $bucket Bucket名称
+ * @param string $object Object名称
+ * @param string $uploadId uploadId
+ * @param array $options Key-Value数组
+ * @return ListPartsInfo
+ * @throws OssException
+ */
+ public function listParts($bucket, $object, $uploadId, $options = null)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_OBJECT] = $object;
+ $options[self::OSS_UPLOAD_ID] = $uploadId;
+ $options[self::OSS_QUERY_STRING] = array();
+ foreach (array('max-parts', 'part-number-marker') as $param) {
+ if (isset($options[$param])) {
+ $options[self::OSS_QUERY_STRING][$param] = $options[$param];
+ unset($options[$param]);
+ }
+ }
+ $response = $this->auth($options);
+ $result = new ListPartsResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 中止进行一半的分片上传操作
+ *
+ * @param string $bucket Bucket名称
+ * @param string $object Object名称
+ * @param string $uploadId uploadId
+ * @param array $options Key-Value数组
+ * @return null
+ * @throws OssException
+ */
+ public function abortMultipartUpload($bucket, $object, $uploadId, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+ $options[self::OSS_METHOD] = self::OSS_HTTP_DELETE;
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_OBJECT] = $object;
+ $options[self::OSS_UPLOAD_ID] = $uploadId;
+ $response = $this->auth($options);
+ $result = new PutSetDeleteResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 在将所有数据Part都上传完成后,调用此接口完成本次分块上传
+ *
+ * @param string $bucket Bucket名称
+ * @param string $object Object名称
+ * @param string $uploadId uploadId
+ * @param array $listParts array( array("PartNumber"=> int, "ETag"=>string))
+ * @param array $options Key-Value数组
+ * @throws OssException
+ * @return null
+ */
+ public function completeMultipartUpload($bucket, $object, $uploadId, $listParts, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+ $options[self::OSS_METHOD] = self::OSS_HTTP_POST;
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_OBJECT] = $object;
+ $options[self::OSS_UPLOAD_ID] = $uploadId;
+ $options[self::OSS_CONTENT_TYPE] = 'application/xml';
+ if (!is_array($listParts)) {
+ throw new OssException("listParts must be array type");
+ }
+ $options[self::OSS_CONTENT] = OssUtil::createCompleteMultipartUploadXmlBody($listParts);
+ $response = $this->auth($options);
+ if (isset($options[self::OSS_CALLBACK]) && !empty($options[self::OSS_CALLBACK])) {
+ $result = new CallbackResult($response);
+ } else {
+ $result = new PutSetDeleteResult($response);
+ }
+ return $result->getData();
+ }
+
+ /**
+ * 罗列出所有执行中的Multipart Upload事件,即已经被初始化的Multipart Upload但是未被
+ * Complete或者Abort的Multipart Upload事件
+ *
+ * @param string $bucket bucket
+ * @param array $options 关联数组
+ * @throws OssException
+ * @return ListMultipartUploadInfo
+ */
+ public function listMultipartUploads($bucket, $options = null)
+ {
+ $this->precheckCommon($bucket, NULL, $options, false);
+ $options[self::OSS_METHOD] = self::OSS_HTTP_GET;
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_OBJECT] = '/';
+ $options[self::OSS_SUB_RESOURCE] = 'uploads';
+
+ foreach (array('delimiter', 'key-marker', 'max-uploads', 'prefix', 'upload-id-marker') as $param) {
+ if (isset($options[$param])) {
+ $options[self::OSS_QUERY_STRING][$param] = $options[$param];
+ unset($options[$param]);
+ }
+ }
+ $query = isset($options[self::OSS_QUERY_STRING]) ? $options[self::OSS_QUERY_STRING] : array();
+ $options[self::OSS_QUERY_STRING] = array_merge(
+ $query,
+ array(self::OSS_ENCODING_TYPE => self::OSS_ENCODING_TYPE_URL)
+ );
+
+ $response = $this->auth($options);
+ $result = new ListMultipartUploadResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * 从一个已存在的Object中拷贝数据来上传一个Part
+ *
+ * @param string $fromBucket 源bucket名称
+ * @param string $fromObject 源object名称
+ * @param string $toBucket 目标bucket名称
+ * @param string $toObject 目标object名称
+ * @param int $partNumber 分块上传的块id
+ * @param string $uploadId 初始化multipart upload返回的uploadid
+ * @param array $options Key-Value数组
+ * @return null
+ * @throws OssException
+ */
+ public function uploadPartCopy($fromBucket, $fromObject, $toBucket, $toObject, $partNumber, $uploadId, $options = NULL)
+ {
+ $this->precheckCommon($fromBucket, $fromObject, $options);
+ $this->precheckCommon($toBucket, $toObject, $options);
+
+ //如果没有设置$options['isFullCopy'],则需要强制判断copy的起止位置
+ $start_range = "0";
+ if (isset($options['start'])) {
+ $start_range = $options['start'];
+ }
+ $end_range = "";
+ if (isset($options['end'])) {
+ $end_range = $options['end'];
+ }
+ $options[self::OSS_METHOD] = self::OSS_HTTP_PUT;
+ $options[self::OSS_BUCKET] = $toBucket;
+ $options[self::OSS_OBJECT] = $toObject;
+ $options[self::OSS_PART_NUM] = $partNumber;
+ $options[self::OSS_UPLOAD_ID] = $uploadId;
+
+ if (!isset($options[self::OSS_HEADERS])) {
+ $options[self::OSS_HEADERS] = array();
+ }
+
+ $options[self::OSS_HEADERS][self::OSS_OBJECT_COPY_SOURCE] = '/' . $fromBucket . '/' . $fromObject;
+ $options[self::OSS_HEADERS][self::OSS_OBJECT_COPY_SOURCE_RANGE] = "bytes=" . $start_range . "-" . $end_range;
+ $response = $this->auth($options);
+ $result = new UploadPartResult($response);
+ return $result->getData();
+ }
+
+ /**
+ * multipart上传统一封装,从初始化到完成multipart,以及出错后中止动作
+ *
+ * @param string $bucket bucket名称
+ * @param string $object object名称
+ * @param string $file 需要上传的本地文件的路径
+ * @param array $options Key-Value数组
+ * @return null
+ * @throws OssException
+ */
+ public function multiuploadFile($bucket, $object, $file, $options = null)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+ if (isset($options[self::OSS_LENGTH])) {
+ $options[self::OSS_CONTENT_LENGTH] = $options[self::OSS_LENGTH];
+ unset($options[self::OSS_LENGTH]);
+ }
+ if (empty($file)) {
+ throw new OssException("parameter invalid, file is empty");
+ }
+ $uploadFile = OssUtil::encodePath($file);
+ if (!isset($options[self::OSS_CONTENT_TYPE])) {
+ $options[self::OSS_CONTENT_TYPE] = $this->getMimeType($object, $uploadFile);
+ }
+
+ $upload_position = isset($options[self::OSS_SEEK_TO]) ? (integer)$options[self::OSS_SEEK_TO] : 0;
+
+ if (isset($options[self::OSS_CONTENT_LENGTH])) {
+ $upload_file_size = (integer)$options[self::OSS_CONTENT_LENGTH];
+ } else {
+ $upload_file_size = filesize($uploadFile);
+ if ($upload_file_size !== false) {
+ $upload_file_size -= $upload_position;
+ }
+ }
+
+ if ($upload_position === false || !isset($upload_file_size) || $upload_file_size === false || $upload_file_size < 0) {
+ throw new OssException('The size of `fileUpload` cannot be determined in ' . __FUNCTION__ . '().');
+ }
+ // 处理partSize
+ if (isset($options[self::OSS_PART_SIZE])) {
+ $options[self::OSS_PART_SIZE] = $this->computePartSize($options[self::OSS_PART_SIZE]);
+ } else {
+ $options[self::OSS_PART_SIZE] = self::OSS_MID_PART_SIZE;
+ }
+
+ $is_check_md5 = $this->isCheckMD5($options);
+ // 如果上传的文件小于partSize,则直接使用普通方式上传
+ if ($upload_file_size < $options[self::OSS_PART_SIZE] && !isset($options[self::OSS_UPLOAD_ID])) {
+ return $this->uploadFile($bucket, $object, $uploadFile, $options);
+ }
+
+ // 初始化multipart
+ if (isset($options[self::OSS_UPLOAD_ID])) {
+ $uploadId = $options[self::OSS_UPLOAD_ID];
+ } else {
+ // 初始化
+ $uploadId = $this->initiateMultipartUpload($bucket, $object, $options);
+ }
+
+ // 获取的分片
+ $pieces = $this->generateMultiuploadParts($upload_file_size, (integer)$options[self::OSS_PART_SIZE]);
+ $response_upload_part = array();
+ foreach ($pieces as $i => $piece) {
+ $from_pos = $upload_position + (integer)$piece[self::OSS_SEEK_TO];
+ $to_pos = (integer)$piece[self::OSS_LENGTH] + $from_pos - 1;
+ $up_options = array(
+ self::OSS_FILE_UPLOAD => $uploadFile,
+ self::OSS_PART_NUM => ($i + 1),
+ self::OSS_SEEK_TO => $from_pos,
+ self::OSS_LENGTH => $to_pos - $from_pos + 1,
+ self::OSS_CHECK_MD5 => $is_check_md5,
+ );
+ if ($is_check_md5) {
+ $content_md5 = OssUtil::getMd5SumForFile($uploadFile, $from_pos, $to_pos);
+ $up_options[self::OSS_CONTENT_MD5] = $content_md5;
+ }
+ $response_upload_part[] = $this->uploadPart($bucket, $object, $uploadId, $up_options);
+ }
+
+ $uploadParts = array();
+ foreach ($response_upload_part as $i => $etag) {
+ $uploadParts[] = array(
+ 'PartNumber' => ($i + 1),
+ 'ETag' => $etag,
+ );
+ }
+ return $this->completeMultipartUpload($bucket, $object, $uploadId, $uploadParts);
+ }
+
+ /**
+ * 上传本地目录内的文件或者目录到指定bucket的指定prefix的object中
+ *
+ * @param string $bucket bucket名称
+ * @param string $prefix 需要上传到的object的key前缀,可以理解成bucket中的子目录,结尾不能是'/',接口中会补充'/'
+ * @param string $localDirectory 需要上传的本地目录
+ * @param string $exclude 需要排除的目录
+ * @param bool $recursive 是否递归的上传localDirectory下的子目录内容
+ * @param bool $checkMd5
+ * @return array 返回两个列表 array("succeededList" => array("object"), "failedList" => array("object"=>"errorMessage"))
+ * @throws OssException
+ */
+ public function uploadDir($bucket, $prefix, $localDirectory, $exclude = '.|..|.svn|.git', $recursive = false, $checkMd5 = true)
+ {
+ $retArray = array("succeededList" => array(), "failedList" => array());
+ if (empty($bucket)) throw new OssException("parameter error, bucket is empty");
+ if (!is_string($prefix)) throw new OssException("parameter error, prefix is not string");
+ if (empty($localDirectory)) throw new OssException("parameter error, localDirectory is empty");
+ $directory = $localDirectory;
+ $directory = OssUtil::encodePath($directory);
+ //判断是否目录
+ if (!is_dir($directory)) {
+ throw new OssException('parameter error: ' . $directory . ' is not a directory, please check it');
+ }
+ //read directory
+ $file_list_array = OssUtil::readDir($directory, $exclude, $recursive);
+ if (!$file_list_array) {
+ throw new OssException($directory . ' is empty...');
+ }
+ foreach ($file_list_array as $k => $item) {
+ if (is_dir($item['path'])) {
+ continue;
+ }
+ $options = array(
+ self::OSS_PART_SIZE => self::OSS_MIN_PART_SIZE,
+ self::OSS_CHECK_MD5 => $checkMd5,
+ );
+ $realObject = (!empty($prefix) ? $prefix . '/' : '') . $item['file'];
+
+ try {
+ $this->multiuploadFile($bucket, $realObject, $item['path'], $options);
+ $retArray["succeededList"][] = $realObject;
+ } catch (OssException $e) {
+ $retArray["failedList"][$realObject] = $e->getMessage();
+ }
+ }
+ return $retArray;
+ }
+
+ /**
+ * 支持生成get和put签名, 用户可以生成一个具有一定有效期的
+ * 签名过的url
+ *
+ * @param string $bucket
+ * @param string $object
+ * @param int $timeout
+ * @param string $method
+ * @param array $options Key-Value数组
+ * @return string
+ * @throws OssException
+ */
+ public function signUrl($bucket, $object, $timeout = 60, $method = self::OSS_HTTP_GET, $options = NULL)
+ {
+ $this->precheckCommon($bucket, $object, $options);
+ //method
+ if (self::OSS_HTTP_GET !== $method && self::OSS_HTTP_PUT !== $method) {
+ throw new OssException("method is invalid");
+ }
+ $options[self::OSS_BUCKET] = $bucket;
+ $options[self::OSS_OBJECT] = $object;
+ $options[self::OSS_METHOD] = $method;
+ if (!isset($options[self::OSS_CONTENT_TYPE])) {
+ $options[self::OSS_CONTENT_TYPE] = '';
+ }
+ $timeout = time() + $timeout;
+ $options[self::OSS_PREAUTH] = $timeout;
+ $options[self::OSS_DATE] = $timeout;
+ $this->setSignStsInUrl(true);
+ return $this->auth($options);
+ }
+
+ /**
+ * 检测options参数
+ *
+ * @param array $options
+ * @throws OssException
+ */
+ private function precheckOptions(&$options)
+ {
+ OssUtil::validateOptions($options);
+ if (!$options) {
+ $options = array();
+ }
+ }
+
+ /**
+ * 校验bucket参数
+ *
+ * @param string $bucket
+ * @param string $errMsg
+ * @throws OssException
+ */
+ private function precheckBucket($bucket, $errMsg = 'bucket is not allowed empty')
+ {
+ OssUtil::throwOssExceptionWithMessageIfEmpty($bucket, $errMsg);
+ }
+
+ /**
+ * 校验object参数
+ *
+ * @param string $object
+ * @throws OssException
+ */
+ private function precheckObject($object)
+ {
+ OssUtil::throwOssExceptionWithMessageIfEmpty($object, "object name is empty");
+ }
+
+ /**
+ * 校验bucket,options参数
+ *
+ * @param string $bucket
+ * @param string $object
+ * @param array $options
+ * @param bool $isCheckObject
+ */
+ private function precheckCommon($bucket, $object, &$options, $isCheckObject = true)
+ {
+ if ($isCheckObject) {
+ $this->precheckObject($object);
+ }
+ $this->precheckOptions($options);
+ $this->precheckBucket($bucket);
+ }
+
+ /**
+ * 参数校验
+ *
+ * @param array $options
+ * @param string $param
+ * @param string $funcName
+ * @throws OssException
+ */
+ private function precheckParam($options, $param, $funcName)
+ {
+ if (!isset($options[$param])) {
+ throw new OssException('The `' . $param . '` options is required in ' . $funcName . '().');
+ }
+ }
+
+ /**
+ * 检测md5
+ *
+ * @param array $options
+ * @return bool|null
+ */
+ private function isCheckMD5($options)
+ {
+ return $this->getValue($options, self::OSS_CHECK_MD5, false, true, true);
+ }
+
+ /**
+ * 获取value
+ *
+ * @param array $options
+ * @param string $key
+ * @param string $default
+ * @param bool $isCheckEmpty
+ * @param bool $isCheckBool
+ * @return bool|null
+ */
+ private function getValue($options, $key, $default = NULL, $isCheckEmpty = false, $isCheckBool = false)
+ {
+ $value = $default;
+ if (isset($options[$key])) {
+ if ($isCheckEmpty) {
+ if (!empty($options[$key])) {
+ $value = $options[$key];
+ }
+ } else {
+ $value = $options[$key];
+ }
+ unset($options[$key]);
+ }
+ if ($isCheckBool) {
+ if ($value !== true && $value !== false) {
+ $value = false;
+ }
+ }
+ return $value;
+ }
+
+ /**
+ * 获取mimetype类型
+ *
+ * @param string $object
+ * @return string
+ */
+ private function getMimeType($object, $file = null)
+ {
+ if (!is_null($file)) {
+ $type = MimeTypes::getMimetype($file);
+ if (!is_null($type)) {
+ return $type;
+ }
+ }
+
+ $type = MimeTypes::getMimetype($object);
+ if (!is_null($type)) {
+ return $type;
+ }
+
+ return self::DEFAULT_CONTENT_TYPE;
+ }
+
+ /**
+ * 验证并且执行请求,按照OSS Api协议,执行操作
+ *
+ * @param array $options
+ * @return ResponseCore
+ * @throws OssException
+ * @throws RequestCore_Exception
+ */
+ private function auth($options)
+ {
+ OssUtil::validateOptions($options);
+ //验证bucket,list_bucket时不需要验证
+ $this->authPrecheckBucket($options);
+ //验证object
+ $this->authPrecheckObject($options);
+ //Object名称的编码必须是utf8
+ $this->authPrecheckObjectEncoding($options);
+ //验证ACL
+ $this->authPrecheckAcl($options);
+ // 获得当次请求使用的协议头,是https还是http
+ $scheme = $this->useSSL ? 'https://' : 'http://';
+ // 获得当次请求使用的hostname,如果是公共域名或者专有域名,bucket拼在前面构成三级域名
+ $hostname = $this->generateHostname($options[self::OSS_BUCKET]);
+ $string_to_sign = '';
+ $headers = $this->generateHeaders($options, $hostname);
+ $signable_query_string_params = $this->generateSignableQueryStringParam($options);
+ $signable_query_string = OssUtil::toQueryString($signable_query_string_params);
+ $resource_uri = $this->generateResourceUri($options);
+ //生成请求URL
+ $conjunction = '?';
+ $non_signable_resource = '';
+ if (isset($options[self::OSS_SUB_RESOURCE])) {
+ $conjunction = '&';
+ }
+ if ($signable_query_string !== '') {
+ $signable_query_string = $conjunction . $signable_query_string;
+ $conjunction = '&';
+ }
+ $query_string = $this->generateQueryString($options);
+ if ($query_string !== '') {
+ $non_signable_resource .= $conjunction . $query_string;
+ $conjunction = '&';
+ }
+ $this->requestUrl = $scheme . $hostname . $resource_uri . $signable_query_string . $non_signable_resource;
+
+ //创建请求
+ $request = new RequestCore($this->requestUrl);
+ $request->set_useragent($this->generateUserAgent());
+ // Streaming uploads
+ if (isset($options[self::OSS_FILE_UPLOAD])) {
+ if (is_resource($options[self::OSS_FILE_UPLOAD])) {
+ $length = null;
+
+ if (isset($options[self::OSS_CONTENT_LENGTH])) {
+ $length = $options[self::OSS_CONTENT_LENGTH];
+ } elseif (isset($options[self::OSS_SEEK_TO])) {
+ $stats = fstat($options[self::OSS_FILE_UPLOAD]);
+ if ($stats && $stats[self::OSS_SIZE] >= 0) {
+ $length = $stats[self::OSS_SIZE] - (integer)$options[self::OSS_SEEK_TO];
+ }
+ }
+ $request->set_read_stream($options[self::OSS_FILE_UPLOAD], $length);
+ } else {
+ $request->set_read_file($options[self::OSS_FILE_UPLOAD]);
+ $length = $request->read_stream_size;
+ if (isset($options[self::OSS_CONTENT_LENGTH])) {
+ $length = $options[self::OSS_CONTENT_LENGTH];
+ } elseif (isset($options[self::OSS_SEEK_TO]) && isset($length)) {
+ $length -= (integer)$options[self::OSS_SEEK_TO];
+ }
+ $request->set_read_stream_size($length);
+ }
+ }
+ if (isset($options[self::OSS_SEEK_TO])) {
+ $request->set_seek_position((integer)$options[self::OSS_SEEK_TO]);
+ }
+ if (isset($options[self::OSS_FILE_DOWNLOAD])) {
+ if (is_resource($options[self::OSS_FILE_DOWNLOAD])) {
+ $request->set_write_stream($options[self::OSS_FILE_DOWNLOAD]);
+ } else {
+ $request->set_write_file($options[self::OSS_FILE_DOWNLOAD]);
+ }
+ }
+
+ if (isset($options[self::OSS_METHOD])) {
+ $request->set_method($options[self::OSS_METHOD]);
+ $string_to_sign .= $options[self::OSS_METHOD] . "\n";
+ }
+
+ if (isset($options[self::OSS_CONTENT])) {
+ $request->set_body($options[self::OSS_CONTENT]);
+ if ($headers[self::OSS_CONTENT_TYPE] === 'application/x-www-form-urlencoded') {
+ $headers[self::OSS_CONTENT_TYPE] = 'application/octet-stream';
+ }
+
+ $headers[self::OSS_CONTENT_LENGTH] = strlen($options[self::OSS_CONTENT]);
+ $headers[self::OSS_CONTENT_MD5] = base64_encode(md5($options[self::OSS_CONTENT], true));
+ }
+
+ if (isset($options[self::OSS_CALLBACK])) {
+ $headers[self::OSS_CALLBACK] = base64_encode($options[self::OSS_CALLBACK]);
+ }
+ if (isset($options[self::OSS_CALLBACK_VAR])) {
+ $headers[self::OSS_CALLBACK_VAR] = base64_encode($options[self::OSS_CALLBACK_VAR]);
+ }
+
+ if (!isset($headers[self::OSS_ACCEPT_ENCODING])) {
+ $headers[self::OSS_ACCEPT_ENCODING] = '';
+ }
+
+ uksort($headers, 'strnatcasecmp');
+
+ foreach ($headers as $header_key => $header_value) {
+ $header_value = str_replace(array("\r", "\n"), '', $header_value);
+ if ($header_value !== '' || $header_key === self::OSS_ACCEPT_ENCODING) {
+ $request->add_header($header_key, $header_value);
+ }
+
+ if (
+ strtolower($header_key) === 'content-md5' ||
+ strtolower($header_key) === 'content-type' ||
+ strtolower($header_key) === 'date' ||
+ (isset($options['self::OSS_PREAUTH']) && (integer)$options['self::OSS_PREAUTH'] > 0)
+ ) {
+ $string_to_sign .= $header_value . "\n";
+ } elseif (substr(strtolower($header_key), 0, 6) === self::OSS_DEFAULT_PREFIX) {
+ $string_to_sign .= strtolower($header_key) . ':' . $header_value . "\n";
+ }
+ }
+ // 生成 signable_resource
+ $signable_resource = $this->generateSignableResource($options);
+ $string_to_sign .= rawurldecode($signable_resource) . urldecode($signable_query_string);
+
+ //对?后面的要签名的string字母序排序
+ $string_to_sign_ordered = $this->stringToSignSorted($string_to_sign);
+
+ $signature = base64_encode(hash_hmac('sha1', $string_to_sign_ordered, $this->accessKeySecret, true));
+ $request->add_header('Authorization', 'OSS ' . $this->accessKeyId . ':' . $signature);
+
+ if (isset($options[self::OSS_PREAUTH]) && (integer)$options[self::OSS_PREAUTH] > 0) {
+ $signed_url = $this->requestUrl . $conjunction . self::OSS_URL_ACCESS_KEY_ID . '=' . rawurlencode($this->accessKeyId) . '&' . self::OSS_URL_EXPIRES . '=' . $options[self::OSS_PREAUTH] . '&' . self::OSS_URL_SIGNATURE . '=' . rawurlencode($signature);
+ return $signed_url;
+ } elseif (isset($options[self::OSS_PREAUTH])) {
+ return $this->requestUrl;
+ }
+
+ if ($this->timeout !== 0) {
+ $request->timeout = $this->timeout;
+ }
+ if ($this->connectTimeout !== 0) {
+ $request->connect_timeout = $this->connectTimeout;
+ }
+
+ try {
+ $request->send_request();
+ } catch (RequestCore_Exception $e) {
+ throw(new OssException('RequestCoreException: ' . $e->getMessage()));
+ }
+ $response_header = $request->get_response_header();
+ $response_header['oss-request-url'] = $this->requestUrl;
+ $response_header['oss-redirects'] = $this->redirects;
+ $response_header['oss-stringtosign'] = $string_to_sign;
+ $response_header['oss-requestheaders'] = $request->request_headers;
+
+ $data = new ResponseCore($response_header, $request->get_response_body(), $request->get_response_code());
+ //retry if OSS Internal Error
+ if ((integer)$request->get_response_code() === 500) {
+ if ($this->redirects <= $this->maxRetries) {
+ //设置休眠
+ $delay = (integer)(pow(4, $this->redirects) * 100000);
+ usleep($delay);
+ $this->redirects++;
+ $data = $this->auth($options);
+ }
+ }
+
+ $this->redirects = 0;
+ return $data;
+ }
+
+ /**
+ * 设置最大尝试次数
+ *
+ * @param int $maxRetries
+ * @return void
+ */
+ public function setMaxTries($maxRetries = 3)
+ {
+ $this->maxRetries = $maxRetries;
+ }
+
+ /**
+ * 获取最大尝试次数
+ *
+ * @return int
+ */
+ public function getMaxRetries()
+ {
+ return $this->maxRetries;
+ }
+
+ /**
+ * 打开sts enable标志,使用户构造函数中传入的$sts生效
+ *
+ * @param boolean $enable
+ */
+ public function setSignStsInUrl($enable)
+ {
+ $this->enableStsInUrl = $enable;
+ }
+
+ /**
+ * @return boolean
+ */
+ public function isUseSSL()
+ {
+ return $this->useSSL;
+ }
+
+ /**
+ * @param boolean $useSSL
+ */
+ public function setUseSSL($useSSL)
+ {
+ $this->useSSL = $useSSL;
+ }
+
+ /**
+ * 检查bucket名称格式是否正确,如果非法抛出异常
+ *
+ * @param $options
+ * @throws OssException
+ */
+ private function authPrecheckBucket($options)
+ {
+ if (!(('/' == $options[self::OSS_OBJECT]) && ('' == $options[self::OSS_BUCKET]) && ('GET' == $options[self::OSS_METHOD])) && !OssUtil::validateBucket($options[self::OSS_BUCKET])) {
+ throw new OssException('"' . $options[self::OSS_BUCKET] . '"' . 'bucket name is invalid');
+ }
+ }
+
+ /**
+ *
+ * 检查object名称格式是否正确,如果非法抛出异常
+ *
+ * @param $options
+ * @throws OssException
+ */
+ private function authPrecheckObject($options)
+ {
+ if (isset($options[self::OSS_OBJECT]) && $options[self::OSS_OBJECT] === '/') {
+ return;
+ }
+
+ if (isset($options[self::OSS_OBJECT]) && !OssUtil::validateObject($options[self::OSS_OBJECT])) {
+ throw new OssException('"' . $options[self::OSS_OBJECT] . '"' . ' object name is invalid');
+ }
+ }
+
+ /**
+ * 检查object的编码,如果是gbk或者gb2312则尝试将其转化为utf8编码
+ *
+ * @param mixed $options 参数
+ */
+ private function authPrecheckObjectEncoding(&$options)
+ {
+ $tmp_object = $options[self::OSS_OBJECT];
+ try {
+ if (OssUtil::isGb2312($options[self::OSS_OBJECT])) {
+ $options[self::OSS_OBJECT] = iconv('GB2312', "UTF-8//IGNORE", $options[self::OSS_OBJECT]);
+ } elseif (OssUtil::checkChar($options[self::OSS_OBJECT], true)) {
+ $options[self::OSS_OBJECT] = iconv('GBK', "UTF-8//IGNORE", $options[self::OSS_OBJECT]);
+ }
+ } catch (\Exception $e) {
+ try {
+ $tmp_object = iconv(mb_detect_encoding($tmp_object), "UTF-8", $tmp_object);
+ } catch (\Exception $e) {
+ }
+ }
+ $options[self::OSS_OBJECT] = $tmp_object;
+ }
+
+ /**
+ * 检查ACL是否是预定义中三种之一,如果不是抛出异常
+ *
+ * @param $options
+ * @throws OssException
+ */
+ private function authPrecheckAcl($options)
+ {
+ if (isset($options[self::OSS_HEADERS][self::OSS_ACL]) && !empty($options[self::OSS_HEADERS][self::OSS_ACL])) {
+ if (!in_array(strtolower($options[self::OSS_HEADERS][self::OSS_ACL]), self::$OSS_ACL_TYPES)) {
+ throw new OssException($options[self::OSS_HEADERS][self::OSS_ACL] . ':' . 'acl is invalid(private,public-read,public-read-write)');
+ }
+ }
+ }
+
+ /**
+ * 获得档次请求使用的域名
+ * bucket在前的三级域名,或者二级域名,如果是cname或者ip的话,则是二级域名
+ *
+ * @param $bucket
+ * @return string 剥掉协议头的域名
+ */
+ private function generateHostname($bucket)
+ {
+ if ($this->hostType === self::OSS_HOST_TYPE_IP) {
+ $hostname = $this->hostname;
+ } elseif ($this->hostType === self::OSS_HOST_TYPE_CNAME) {
+ $hostname = $this->hostname;
+ } else {
+ // 专有域或者官网endpoint
+ $hostname = ($bucket == '') ? $this->hostname : ($bucket . '.') . $this->hostname;
+ }
+ return $hostname;
+ }
+
+ /**
+ * 获得当次请求的资源定位字段
+ *
+ * @param $options
+ * @return string 资源定位字段
+ */
+ private function generateResourceUri($options)
+ {
+ $resource_uri = "";
+
+ // resource_uri + bucket
+ if (isset($options[self::OSS_BUCKET]) && '' !== $options[self::OSS_BUCKET]) {
+ if ($this->hostType === self::OSS_HOST_TYPE_IP) {
+ $resource_uri = '/' . $options[self::OSS_BUCKET];
+ }
+ }
+
+ // resource_uri + object
+ if (isset($options[self::OSS_OBJECT]) && '/' !== $options[self::OSS_OBJECT]) {
+ $resource_uri .= '/' . str_replace(array('%2F', '%25'), array('/', '%'), rawurlencode($options[self::OSS_OBJECT]));
+ }
+
+ // resource_uri + sub_resource
+ $conjunction = '?';
+ if (isset($options[self::OSS_SUB_RESOURCE])) {
+ $resource_uri .= $conjunction . $options[self::OSS_SUB_RESOURCE];
+ }
+ return $resource_uri;
+ }
+
+ /**
+ * 生成signalbe_query_string_param, array类型
+ *
+ * @param array $options
+ * @return array
+ */
+ private function generateSignableQueryStringParam($options)
+ {
+ $signableQueryStringParams = array();
+ $signableList = array(
+ self::OSS_PART_NUM,
+ 'response-content-type',
+ 'response-content-language',
+ 'response-cache-control',
+ 'response-content-encoding',
+ 'response-expires',
+ 'response-content-disposition',
+ self::OSS_UPLOAD_ID,
+ self::OSS_COMP,
+ self::OSS_LIVE_CHANNEL_STATUS,
+ self::OSS_LIVE_CHANNEL_START_TIME,
+ self::OSS_LIVE_CHANNEL_END_TIME,
+ self::OSS_PROCESS,
+ self::OSS_POSITION
+ );
+
+ foreach ($signableList as $item) {
+ if (isset($options[$item])) {
+ $signableQueryStringParams[$item] = $options[$item];
+ }
+ }
+
+ if ($this->enableStsInUrl && (!is_null($this->securityToken))) {
+ $signableQueryStringParams["security-token"] = $this->securityToken;
+ }
+
+ return $signableQueryStringParams;
+ }
+
+ /**
+ * 生成用于签名resource段
+ *
+ * @param mixed $options
+ * @return string
+ */
+ private function generateSignableResource($options)
+ {
+ $signableResource = "";
+ $signableResource .= '/';
+ if (isset($options[self::OSS_BUCKET]) && '' !== $options[self::OSS_BUCKET]) {
+ $signableResource .= $options[self::OSS_BUCKET];
+ // 如果操作没有Object操作的话,这里最后是否有斜线有个trick,ip的域名下,不需要加'/', 否则需要加'/'
+ if ($options[self::OSS_OBJECT] == '/') {
+ if ($this->hostType !== self::OSS_HOST_TYPE_IP) {
+ $signableResource .= "/";
+ }
+ }
+ }
+ //signable_resource + object
+ if (isset($options[self::OSS_OBJECT]) && '/' !== $options[self::OSS_OBJECT]) {
+ $signableResource .= '/' . str_replace(array('%2F', '%25'), array('/', '%'), rawurlencode($options[self::OSS_OBJECT]));
+ }
+ if (isset($options[self::OSS_SUB_RESOURCE])) {
+ $signableResource .= '?' . $options[self::OSS_SUB_RESOURCE];
+ }
+ return $signableResource;
+ }
+
+ /**
+ * 生成query_string
+ *
+ * @param mixed $options
+ * @return string
+ */
+ private function generateQueryString($options)
+ {
+ //请求参数
+ $queryStringParams = array();
+ if (isset($options[self::OSS_QUERY_STRING])) {
+ $queryStringParams = array_merge($queryStringParams, $options[self::OSS_QUERY_STRING]);
+ }
+ return OssUtil::toQueryString($queryStringParams);
+ }
+
+ private function stringToSignSorted($string_to_sign)
+ {
+ $queryStringSorted = '';
+ $explodeResult = explode('?', $string_to_sign);
+ $index = count($explodeResult);
+ if ($index === 1)
+ return $string_to_sign;
+
+ $queryStringParams = explode('&', $explodeResult[$index - 1]);
+ sort($queryStringParams);
+
+ foreach($queryStringParams as $params)
+ {
+ $queryStringSorted .= $params . '&';
+ }
+
+ $queryStringSorted = substr($queryStringSorted, 0, -1);
+
+ return $explodeResult[0] . '?' . $queryStringSorted;
+ }
+
+ /**
+ * 初始化headers
+ *
+ * @param mixed $options
+ * @param string $hostname hostname
+ * @return array
+ */
+ private function generateHeaders($options, $hostname)
+ {
+ $headers = array(
+ self::OSS_CONTENT_MD5 => '',
+ self::OSS_CONTENT_TYPE => isset($options[self::OSS_CONTENT_TYPE]) ? $options[self::OSS_CONTENT_TYPE] : self::DEFAULT_CONTENT_TYPE,
+ self::OSS_DATE => isset($options[self::OSS_DATE]) ? $options[self::OSS_DATE] : gmdate('D, d M Y H:i:s \G\M\T'),
+ self::OSS_HOST => $hostname,
+ );
+ if (isset($options[self::OSS_CONTENT_MD5])) {
+ $headers[self::OSS_CONTENT_MD5] = $options[self::OSS_CONTENT_MD5];
+ }
+
+ //添加stsSecurityToken
+ if ((!is_null($this->securityToken)) && (!$this->enableStsInUrl)) {
+ $headers[self::OSS_SECURITY_TOKEN] = $this->securityToken;
+ }
+ //合并HTTP headers
+ if (isset($options[self::OSS_HEADERS])) {
+ $headers = array_merge($headers, $options[self::OSS_HEADERS]);
+ }
+ return $headers;
+ }
+
+ /**
+ * 生成请求用的UserAgent
+ *
+ * @return string
+ */
+ private function generateUserAgent()
+ {
+ return self::OSS_NAME . "/" . self::OSS_VERSION . " (" . php_uname('s') . "/" . php_uname('r') . "/" . php_uname('m') . ";" . PHP_VERSION . ")";
+ }
+
+ /**
+ * 检查endpoint的种类
+ * 如有有协议头,剥去协议头
+ * 并且根据参数 is_cname 和endpoint本身,判定域名类型,是ip,cname,还是专有域或者官网域名
+ *
+ * @param string $endpoint
+ * @param boolean $isCName
+ * @return string 剥掉协议头的域名
+ */
+ private function checkEndpoint($endpoint, $isCName)
+ {
+ $ret_endpoint = null;
+ if (strpos($endpoint, 'http://') === 0) {
+ $ret_endpoint = substr($endpoint, strlen('http://'));
+ } elseif (strpos($endpoint, 'https://') === 0) {
+ $ret_endpoint = substr($endpoint, strlen('https://'));
+ $this->useSSL = true;
+ } else {
+ $ret_endpoint = $endpoint;
+ }
+
+ if ($isCName) {
+ $this->hostType = self::OSS_HOST_TYPE_CNAME;
+ } elseif (OssUtil::isIPFormat($ret_endpoint)) {
+ $this->hostType = self::OSS_HOST_TYPE_IP;
+ } else {
+ $this->hostType = self::OSS_HOST_TYPE_NORMAL;
+ }
+ return $ret_endpoint;
+ }
+
+ /**
+ * 用来检查sdk所以来的扩展是否打开
+ *
+ * @throws OssException
+ */
+ public static function checkEnv()
+ {
+ if (function_exists('get_loaded_extensions')) {
+ //检测curl扩展
+ $enabled_extension = array("curl");
+ $extensions = get_loaded_extensions();
+ if ($extensions) {
+ foreach ($enabled_extension as $item) {
+ if (!in_array($item, $extensions)) {
+ throw new OssException("Extension {" . $item . "} is not installed or not enabled, please check your php env.");
+ }
+ }
+ } else {
+ throw new OssException("function get_loaded_extensions not found.");
+ }
+ } else {
+ throw new OssException('Function get_loaded_extensions has been disabled, please check php config.');
+ }
+ }
+
+ /**
+ //* 设置http库的请求超时时间,单位秒
+ *
+ * @param int $timeout
+ */
+ public function setTimeout($timeout)
+ {
+ $this->timeout = $timeout;
+ }
+
+ /**
+ * 设置http库的连接超时时间,单位秒
+ *
+ * @param int $connectTimeout
+ */
+ public function setConnectTimeout($connectTimeout)
+ {
+ $this->connectTimeout = $connectTimeout;
+ }
+
+ // 生命周期相关常量
+ const OSS_LIFECYCLE_EXPIRATION = "Expiration";
+ const OSS_LIFECYCLE_TIMING_DAYS = "Days";
+ const OSS_LIFECYCLE_TIMING_DATE = "Date";
+ //OSS 内部常量
+ const OSS_BUCKET = 'bucket';
+ const OSS_OBJECT = 'object';
+ const OSS_HEADERS = OssUtil::OSS_HEADERS;
+ const OSS_METHOD = 'method';
+ const OSS_QUERY = 'query';
+ const OSS_BASENAME = 'basename';
+ const OSS_MAX_KEYS = 'max-keys';
+ const OSS_UPLOAD_ID = 'uploadId';
+ const OSS_PART_NUM = 'partNumber';
+ const OSS_COMP = 'comp';
+ const OSS_LIVE_CHANNEL_STATUS = 'status';
+ const OSS_LIVE_CHANNEL_START_TIME = 'startTime';
+ const OSS_LIVE_CHANNEL_END_TIME = 'endTime';
+ const OSS_POSITION = 'position';
+ const OSS_MAX_KEYS_VALUE = 100;
+ const OSS_MAX_OBJECT_GROUP_VALUE = OssUtil::OSS_MAX_OBJECT_GROUP_VALUE;
+ const OSS_MAX_PART_SIZE = OssUtil::OSS_MAX_PART_SIZE;
+ const OSS_MID_PART_SIZE = OssUtil::OSS_MID_PART_SIZE;
+ const OSS_MIN_PART_SIZE = OssUtil::OSS_MIN_PART_SIZE;
+ const OSS_FILE_SLICE_SIZE = 8192;
+ const OSS_PREFIX = 'prefix';
+ const OSS_DELIMITER = 'delimiter';
+ const OSS_MARKER = 'marker';
+ const OSS_ACCEPT_ENCODING = 'Accept-Encoding';
+ const OSS_CONTENT_MD5 = 'Content-Md5';
+ const OSS_SELF_CONTENT_MD5 = 'x-oss-meta-md5';
+ const OSS_CONTENT_TYPE = 'Content-Type';
+ const OSS_CONTENT_LENGTH = 'Content-Length';
+ const OSS_IF_MODIFIED_SINCE = 'If-Modified-Since';
+ const OSS_IF_UNMODIFIED_SINCE = 'If-Unmodified-Since';
+ const OSS_IF_MATCH = 'If-Match';
+ const OSS_IF_NONE_MATCH = 'If-None-Match';
+ const OSS_CACHE_CONTROL = 'Cache-Control';
+ const OSS_EXPIRES = 'Expires';
+ const OSS_PREAUTH = 'preauth';
+ const OSS_CONTENT_COING = 'Content-Coding';
+ const OSS_CONTENT_DISPOSTION = 'Content-Disposition';
+ const OSS_RANGE = 'range';
+ const OSS_ETAG = 'etag';
+ const OSS_LAST_MODIFIED = 'lastmodified';
+ const OS_CONTENT_RANGE = 'Content-Range';
+ const OSS_CONTENT = OssUtil::OSS_CONTENT;
+ const OSS_BODY = 'body';
+ const OSS_LENGTH = OssUtil::OSS_LENGTH;
+ const OSS_HOST = 'Host';
+ const OSS_DATE = 'Date';
+ const OSS_AUTHORIZATION = 'Authorization';
+ const OSS_FILE_DOWNLOAD = 'fileDownload';
+ const OSS_FILE_UPLOAD = 'fileUpload';
+ const OSS_PART_SIZE = 'partSize';
+ const OSS_SEEK_TO = 'seekTo';
+ const OSS_SIZE = 'size';
+ const OSS_QUERY_STRING = 'query_string';
+ const OSS_SUB_RESOURCE = 'sub_resource';
+ const OSS_DEFAULT_PREFIX = 'x-oss-';
+ const OSS_CHECK_MD5 = 'checkmd5';
+ const DEFAULT_CONTENT_TYPE = 'application/octet-stream';
+
+ //私有URL变量
+ const OSS_URL_ACCESS_KEY_ID = 'OSSAccessKeyId';
+ const OSS_URL_EXPIRES = 'Expires';
+ const OSS_URL_SIGNATURE = 'Signature';
+ //HTTP方法
+ const OSS_HTTP_GET = 'GET';
+ const OSS_HTTP_PUT = 'PUT';
+ const OSS_HTTP_HEAD = 'HEAD';
+ const OSS_HTTP_POST = 'POST';
+ const OSS_HTTP_DELETE = 'DELETE';
+ const OSS_HTTP_OPTIONS = 'OPTIONS';
+ //其他常量
+ const OSS_ACL = 'x-oss-acl';
+ const OSS_OBJECT_ACL = 'x-oss-object-acl';
+ const OSS_OBJECT_GROUP = 'x-oss-file-group';
+ const OSS_MULTI_PART = 'uploads';
+ const OSS_MULTI_DELETE = 'delete';
+ const OSS_OBJECT_COPY_SOURCE = 'x-oss-copy-source';
+ const OSS_OBJECT_COPY_SOURCE_RANGE = "x-oss-copy-source-range";
+ const OSS_PROCESS = "x-oss-process";
+ const OSS_CALLBACK = "x-oss-callback";
+ const OSS_CALLBACK_VAR = "x-oss-callback-var";
+ //支持STS SecurityToken
+ const OSS_SECURITY_TOKEN = "x-oss-security-token";
+ const OSS_ACL_TYPE_PRIVATE = 'private';
+ const OSS_ACL_TYPE_PUBLIC_READ = 'public-read';
+ const OSS_ACL_TYPE_PUBLIC_READ_WRITE = 'public-read-write';
+ const OSS_ENCODING_TYPE = "encoding-type";
+ const OSS_ENCODING_TYPE_URL = "url";
+
+ // 域名类型
+ const OSS_HOST_TYPE_NORMAL = "normal";//http://bucket.oss-cn-hangzhou.aliyuncs.com/object
+ const OSS_HOST_TYPE_IP = "ip"; //http://1.1.1.1/bucket/object
+ const OSS_HOST_TYPE_SPECIAL = 'special'; //http://bucket.guizhou.gov/object
+ const OSS_HOST_TYPE_CNAME = "cname"; //http://mydomain.com/object
+ //OSS ACL数组
+ static $OSS_ACL_TYPES = array(
+ self::OSS_ACL_TYPE_PRIVATE,
+ self::OSS_ACL_TYPE_PUBLIC_READ,
+ self::OSS_ACL_TYPE_PUBLIC_READ_WRITE
+ );
+ // OssClient版本信息
+ const OSS_NAME = "aliyun-sdk-php";
+ const OSS_VERSION = "2.2.4";
+ const OSS_BUILD = "20170425";
+ const OSS_AUTHOR = "";
+ const OSS_OPTIONS_ORIGIN = 'Origin';
+ const OSS_OPTIONS_REQUEST_METHOD = 'Access-Control-Request-Method';
+ const OSS_OPTIONS_REQUEST_HEADERS = 'Access-Control-Request-Headers';
+
+ //是否使用ssl
+ private $useSSL = false;
+ private $maxRetries = 3;
+ private $redirects = 0;
+
+ // 用户提供的域名类型,有四种 OSS_HOST_TYPE_NORMAL, OSS_HOST_TYPE_IP, OSS_HOST_TYPE_SPECIAL, OSS_HOST_TYPE_CNAME
+ private $hostType = self::OSS_HOST_TYPE_NORMAL;
+ private $requestUrl;
+ private $accessKeyId;
+ private $accessKeySecret;
+ private $hostname;
+ private $securityToken;
+ private $enableStsInUrl = false;
+ private $timeout = 0;
+ private $connectTimeout = 0;
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/AclResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/AclResult.php
new file mode 100644
index 000000000..6da086042
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/AclResult.php
@@ -0,0 +1,32 @@
+rawResponse->body;
+ if (empty($content)) {
+ throw new OssException("body is null");
+ }
+ $xml = simplexml_load_string($content);
+ if (isset($xml->AccessControlList->Grant)) {
+ return strval($xml->AccessControlList->Grant);
+ } else {
+ throw new OssException("xml format exception");
+ }
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/AppendResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/AppendResult.php
new file mode 100644
index 000000000..433c03eb1
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/AppendResult.php
@@ -0,0 +1,27 @@
+rawResponse->header;
+ if (isset($header["x-oss-next-append-position"])) {
+ return intval($header["x-oss-next-append-position"]);
+ }
+ throw new OssException("cannot get next-append-position");
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/BodyResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/BodyResult.php
new file mode 100644
index 000000000..44ba15ef5
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/BodyResult.php
@@ -0,0 +1,19 @@
+rawResponse->body) ? "" : $this->rawResponse->body;
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/CallbackResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/CallbackResult.php
new file mode 100644
index 000000000..514e985c2
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/CallbackResult.php
@@ -0,0 +1,21 @@
+rawResponse->status;
+ if ((int)(intval($status) / 100) == 2 && (int)(intval($status)) !== 203) {
+ return true;
+ }
+ return false;
+ }
+
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/CopyObjectResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/CopyObjectResult.php
new file mode 100644
index 000000000..498723e1b
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/CopyObjectResult.php
@@ -0,0 +1,30 @@
+rawResponse->body;
+ $xml = simplexml_load_string($body);
+ $result = array();
+
+ if (isset($xml->LastModified)) {
+ $result[] = $xml->LastModified;
+ }
+ if (isset($xml->ETag)) {
+ $result[] = $xml->ETag;
+ }
+
+ return $result;
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/DeleteObjectsResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/DeleteObjectsResult.php
new file mode 100644
index 000000000..dc373b854
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/DeleteObjectsResult.php
@@ -0,0 +1,27 @@
+rawResponse->body;
+ $xml = simplexml_load_string($body);
+ $objects = array();
+
+ if (isset($xml->Deleted)) {
+ foreach($xml->Deleted as $deleteKey)
+ $objects[] = $deleteKey->Key;
+ }
+ return $objects;
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ExistResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ExistResult.php
new file mode 100644
index 000000000..f7aa287c8
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ExistResult.php
@@ -0,0 +1,35 @@
+rawResponse->status) === 200 ? true : false;
+ }
+
+ /**
+ * 根据返回http状态码判断,[200-299]即认为是OK, 判断是否存在的接口,404也认为是一种
+ * 有效响应
+ *
+ * @return bool
+ */
+ protected function isResponseOk()
+ {
+ $status = $this->rawResponse->status;
+ if ((int)(intval($status) / 100) == 2 || (int)(intval($status)) === 404) {
+ return true;
+ }
+ return false;
+ }
+
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetCnameResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetCnameResult.php
new file mode 100644
index 000000000..eed01f902
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetCnameResult.php
@@ -0,0 +1,19 @@
+rawResponse->body;
+ $config = new CnameConfig();
+ $config->parseFromXml($content);
+ return $config;
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetCorsResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetCorsResult.php
new file mode 100644
index 000000000..a51afe2a8
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetCorsResult.php
@@ -0,0 +1,35 @@
+rawResponse->body;
+ $config = new CorsConfig();
+ $config->parseFromXml($content);
+ return $config;
+ }
+
+ /**
+ * 根据返回http状态码判断,[200-299]即认为是OK, 获取bucket相关配置的接口,404也认为是一种
+ * 有效响应
+ *
+ * @return bool
+ */
+ protected function isResponseOk()
+ {
+ $status = $this->rawResponse->status;
+ if ((int)(intval($status) / 100) == 2 || (int)(intval($status)) === 404) {
+ return true;
+ }
+ return false;
+ }
+
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLifecycleResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLifecycleResult.php
new file mode 100644
index 000000000..6b440c352
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLifecycleResult.php
@@ -0,0 +1,41 @@
+rawResponse->body;
+ $config = new LifecycleConfig();
+ $config->parseFromXml($content);
+ return $config;
+ }
+
+ /**
+ * 根据返回http状态码判断,[200-299]即认为是OK, 获取bucket相关配置的接口,404也认为是一种
+ * 有效响应
+ *
+ * @return bool
+ */
+ protected function isResponseOk()
+ {
+ $status = $this->rawResponse->status;
+ if ((int)(intval($status) / 100) == 2 || (int)(intval($status)) === 404) {
+ return true;
+ }
+ return false;
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLiveChannelHistoryResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLiveChannelHistoryResult.php
new file mode 100644
index 000000000..202a6681d
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLiveChannelHistoryResult.php
@@ -0,0 +1,19 @@
+rawResponse->body;
+ $channelList = new GetLiveChannelHistory();
+ $channelList->parseFromXml($content);
+ return $channelList;
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLiveChannelInfoResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLiveChannelInfoResult.php
new file mode 100644
index 000000000..d5a9005e7
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLiveChannelInfoResult.php
@@ -0,0 +1,19 @@
+rawResponse->body;
+ $channelList = new GetLiveChannelInfo();
+ $channelList->parseFromXml($content);
+ return $channelList;
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLiveChannelStatusResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLiveChannelStatusResult.php
new file mode 100644
index 000000000..6b8a60f59
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLiveChannelStatusResult.php
@@ -0,0 +1,19 @@
+rawResponse->body;
+ $channelList = new GetLiveChannelStatus();
+ $channelList->parseFromXml($content);
+ return $channelList;
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLoggingResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLoggingResult.php
new file mode 100644
index 000000000..72fc3aeb1
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetLoggingResult.php
@@ -0,0 +1,41 @@
+rawResponse->body;
+ $config = new LoggingConfig();
+ $config->parseFromXml($content);
+ return $config;
+ }
+
+ /**
+ * 根据返回http状态码判断,[200-299]即认为是OK, 获取bucket相关配置的接口,404也认为是一种
+ * 有效响应
+ *
+ * @return bool
+ */
+ protected function isResponseOk()
+ {
+ $status = $this->rawResponse->status;
+ if ((int)(intval($status) / 100) == 2 || (int)(intval($status)) === 404) {
+ return true;
+ }
+ return false;
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetRefererResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetRefererResult.php
new file mode 100644
index 000000000..aee50d3ae
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetRefererResult.php
@@ -0,0 +1,41 @@
+rawResponse->body;
+ $config = new RefererConfig();
+ $config->parseFromXml($content);
+ return $config;
+ }
+
+ /**
+ * 根据返回http状态码判断,[200-299]即认为是OK, 获取bucket相关配置的接口,404也认为是一种
+ * 有效响应
+ *
+ * @return bool
+ */
+ protected function isResponseOk()
+ {
+ $status = $this->rawResponse->status;
+ if ((int)(intval($status) / 100) == 2 || (int)(intval($status)) === 404) {
+ return true;
+ }
+ return false;
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetWebsiteResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetWebsiteResult.php
new file mode 100644
index 000000000..3099172cd
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/GetWebsiteResult.php
@@ -0,0 +1,40 @@
+rawResponse->body;
+ $config = new WebsiteConfig();
+ $config->parseFromXml($content);
+ return $config;
+ }
+
+ /**
+ * 根据返回http状态码判断,[200-299]即认为是OK, 获取bucket相关配置的接口,404也认为是一种
+ * 有效响应
+ *
+ * @return bool
+ */
+ protected function isResponseOk()
+ {
+ $status = $this->rawResponse->status;
+ if ((int)(intval($status) / 100) == 2 || (int)(intval($status)) === 404) {
+ return true;
+ }
+ return false;
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/HeaderResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/HeaderResult.php
new file mode 100644
index 000000000..c9aae561f
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/HeaderResult.php
@@ -0,0 +1,23 @@
+rawResponse->header) ? array() : $this->rawResponse->header;
+ }
+
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/InitiateMultipartUploadResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/InitiateMultipartUploadResult.php
new file mode 100644
index 000000000..af985f272
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/InitiateMultipartUploadResult.php
@@ -0,0 +1,29 @@
+rawResponse->body;
+ $xml = simplexml_load_string($content);
+ if (isset($xml->UploadId)) {
+ return strval($xml->UploadId);
+ }
+ throw new OssException("cannot get UploadId");
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListBucketsResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListBucketsResult.php
new file mode 100644
index 000000000..a58fb2d61
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListBucketsResult.php
@@ -0,0 +1,33 @@
+rawResponse->body;
+ $xml = new \SimpleXMLElement($content);
+ if (isset($xml->Buckets) && isset($xml->Buckets->Bucket)) {
+ foreach ($xml->Buckets->Bucket as $bucket) {
+ $bucketInfo = new BucketInfo(strval($bucket->Location),
+ strval($bucket->Name),
+ strval($bucket->CreationDate));
+ $bucketList[] = $bucketInfo;
+ }
+ }
+ return new BucketListInfo($bucketList);
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListLiveChannelResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListLiveChannelResult.php
new file mode 100644
index 000000000..1a6e2a41f
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListLiveChannelResult.php
@@ -0,0 +1,16 @@
+rawResponse->body;
+ $channelList = new LiveChannelListInfo();
+ $channelList->parseFromXml($content);
+ return $channelList;
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListMultipartUploadResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListMultipartUploadResult.php
new file mode 100644
index 000000000..bcb20bf59
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListMultipartUploadResult.php
@@ -0,0 +1,55 @@
+rawResponse->body;
+ $xml = simplexml_load_string($content);
+
+ $encodingType = isset($xml->EncodingType) ? strval($xml->EncodingType) : "";
+ $bucket = isset($xml->Bucket) ? strval($xml->Bucket) : "";
+ $keyMarker = isset($xml->KeyMarker) ? strval($xml->KeyMarker) : "";
+ $keyMarker = OssUtil::decodeKey($keyMarker, $encodingType);
+ $uploadIdMarker = isset($xml->UploadIdMarker) ? strval($xml->UploadIdMarker) : "";
+ $nextKeyMarker = isset($xml->NextKeyMarker) ? strval($xml->NextKeyMarker) : "";
+ $nextKeyMarker = OssUtil::decodeKey($nextKeyMarker, $encodingType);
+ $nextUploadIdMarker = isset($xml->NextUploadIdMarker) ? strval($xml->NextUploadIdMarker) : "";
+ $delimiter = isset($xml->Delimiter) ? strval($xml->Delimiter) : "";
+ $delimiter = OssUtil::decodeKey($delimiter, $encodingType);
+ $prefix = isset($xml->Prefix) ? strval($xml->Prefix) : "";
+ $prefix = OssUtil::decodeKey($prefix, $encodingType);
+ $maxUploads = isset($xml->MaxUploads) ? intval($xml->MaxUploads) : 0;
+ $isTruncated = isset($xml->IsTruncated) ? strval($xml->IsTruncated) : "";
+ $listUpload = array();
+
+ if (isset($xml->Upload)) {
+ foreach ($xml->Upload as $upload) {
+ $key = isset($upload->Key) ? strval($upload->Key) : "";
+ $key = OssUtil::decodeKey($key, $encodingType);
+ $uploadId = isset($upload->UploadId) ? strval($upload->UploadId) : "";
+ $initiated = isset($upload->Initiated) ? strval($upload->Initiated) : "";
+ $listUpload[] = new UploadInfo($key, $uploadId, $initiated);
+ }
+ }
+ return new ListMultipartUploadInfo($bucket, $keyMarker, $uploadIdMarker,
+ $nextKeyMarker, $nextUploadIdMarker,
+ $delimiter, $prefix, $maxUploads, $isTruncated, $listUpload);
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListObjectsResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListObjectsResult.php
new file mode 100644
index 000000000..fcf493d25
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListObjectsResult.php
@@ -0,0 +1,71 @@
+rawResponse->body);
+ $encodingType = isset($xml->EncodingType) ? strval($xml->EncodingType) : "";
+ $objectList = $this->parseObjectList($xml, $encodingType);
+ $prefixList = $this->parsePrefixList($xml, $encodingType);
+ $bucketName = isset($xml->Name) ? strval($xml->Name) : "";
+ $prefix = isset($xml->Prefix) ? strval($xml->Prefix) : "";
+ $prefix = OssUtil::decodeKey($prefix, $encodingType);
+ $marker = isset($xml->Marker) ? strval($xml->Marker) : "";
+ $marker = OssUtil::decodeKey($marker, $encodingType);
+ $maxKeys = isset($xml->MaxKeys) ? intval($xml->MaxKeys) : 0;
+ $delimiter = isset($xml->Delimiter) ? strval($xml->Delimiter) : "";
+ $delimiter = OssUtil::decodeKey($delimiter, $encodingType);
+ $isTruncated = isset($xml->IsTruncated) ? strval($xml->IsTruncated) : "";
+ $nextMarker = isset($xml->NextMarker) ? strval($xml->NextMarker) : "";
+ $nextMarker = OssUtil::decodeKey($nextMarker, $encodingType);
+ return new ObjectListInfo($bucketName, $prefix, $marker, $nextMarker, $maxKeys, $delimiter, $isTruncated, $objectList, $prefixList);
+ }
+
+ private function parseObjectList($xml, $encodingType)
+ {
+ $retList = array();
+ if (isset($xml->Contents)) {
+ foreach ($xml->Contents as $content) {
+ $key = isset($content->Key) ? strval($content->Key) : "";
+ $key = OssUtil::decodeKey($key, $encodingType);
+ $lastModified = isset($content->LastModified) ? strval($content->LastModified) : "";
+ $eTag = isset($content->ETag) ? strval($content->ETag) : "";
+ $type = isset($content->Type) ? strval($content->Type) : "";
+ $size = isset($content->Size) ? intval($content->Size) : 0;
+ $storageClass = isset($content->StorageClass) ? strval($content->StorageClass) : "";
+ $retList[] = new ObjectInfo($key, $lastModified, $eTag, $type, $size, $storageClass);
+ }
+ }
+ return $retList;
+ }
+
+ private function parsePrefixList($xml, $encodingType)
+ {
+ $retList = array();
+ if (isset($xml->CommonPrefixes)) {
+ foreach ($xml->CommonPrefixes as $commonPrefix) {
+ $prefix = isset($commonPrefix->Prefix) ? strval($commonPrefix->Prefix) : "";
+ $prefix = OssUtil::decodeKey($prefix, $encodingType);
+ $retList[] = new PrefixInfo($prefix);
+ }
+ }
+ return $retList;
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListPartsResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListPartsResult.php
new file mode 100644
index 000000000..fd8a1b863
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/ListPartsResult.php
@@ -0,0 +1,42 @@
+rawResponse->body;
+ $xml = simplexml_load_string($content);
+ $bucket = isset($xml->Bucket) ? strval($xml->Bucket) : "";
+ $key = isset($xml->Key) ? strval($xml->Key) : "";
+ $uploadId = isset($xml->UploadId) ? strval($xml->UploadId) : "";
+ $nextPartNumberMarker = isset($xml->NextPartNumberMarker) ? intval($xml->NextPartNumberMarker) : "";
+ $maxParts = isset($xml->MaxParts) ? intval($xml->MaxParts) : "";
+ $isTruncated = isset($xml->IsTruncated) ? strval($xml->IsTruncated) : "";
+ $partList = array();
+ if (isset($xml->Part)) {
+ foreach ($xml->Part as $part) {
+ $partNumber = isset($part->PartNumber) ? intval($part->PartNumber) : "";
+ $lastModified = isset($part->LastModified) ? strval($part->LastModified) : "";
+ $eTag = isset($part->ETag) ? strval($part->ETag) : "";
+ $size = isset($part->Size) ? intval($part->Size) : "";
+ $partList[] = new PartInfo($partNumber, $lastModified, $eTag, $size);
+ }
+ }
+ return new ListPartsInfo($bucket, $key, $uploadId, $nextPartNumberMarker, $maxParts, $isTruncated, $partList);
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/PutLiveChannelResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/PutLiveChannelResult.php
new file mode 100644
index 000000000..dcac86b78
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/PutLiveChannelResult.php
@@ -0,0 +1,16 @@
+rawResponse->body;
+ $channel = new LiveChannelInfo();
+ $channel->parseFromXml($content);
+ return $channel;
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/PutSetDeleteResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/PutSetDeleteResult.php
new file mode 100644
index 000000000..97af003b6
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/PutSetDeleteResult.php
@@ -0,0 +1,20 @@
+ $this->rawResponse->body);
+ return array_merge($this->rawResponse->header, $body);
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/Result.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/Result.php
new file mode 100644
index 000000000..491256f00
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/Result.php
@@ -0,0 +1,175 @@
+rawResponse = $response;
+ $this->parseResponse();
+ }
+
+ /**
+ * 获取requestId
+ *
+ * @return string
+ */
+ public function getRequestId()
+ {
+ if (isset($this->rawResponse) &&
+ isset($this->rawResponse->header) &&
+ isset($this->rawResponse->header['x-oss-request-id'])
+ ) {
+ return $this->rawResponse->header['x-oss-request-id'];
+ } else {
+ return '';
+ }
+ }
+
+ /**
+ * 得到返回数据,不同的请求返回数据格式不同
+ *
+ * $return mixed
+ */
+ public function getData()
+ {
+ return $this->parsedData;
+ }
+
+ /**
+ * 由子类实现,不同的请求返回数据有不同的解析逻辑,由子类实现
+ *
+ * @return mixed
+ */
+ abstract protected function parseDataFromResponse();
+
+ /**
+ * 操作是否成功
+ *
+ * @return mixed
+ */
+ public function isOK()
+ {
+ return $this->isOk;
+ }
+
+ /**
+ * @throws OssException
+ */
+ public function parseResponse()
+ {
+ $this->isOk = $this->isResponseOk();
+ if ($this->isOk) {
+ $this->parsedData = $this->parseDataFromResponse();
+ } else {
+ $httpStatus = strval($this->rawResponse->status);
+ $requestId = strval($this->getRequestId());
+ $code = $this->retrieveErrorCode($this->rawResponse->body);
+ $message = $this->retrieveErrorMessage($this->rawResponse->body);
+ $body = $this->rawResponse->body;
+
+ $details = array(
+ 'status' => $httpStatus,
+ 'request-id' => $requestId,
+ 'code' => $code,
+ 'message' => $message,
+ 'body' => $body
+ );
+ throw new OssException($details);
+ }
+ }
+
+ /**
+ * 尝试从body中获取错误Message
+ *
+ * @param $body
+ * @return string
+ */
+ private function retrieveErrorMessage($body)
+ {
+ if (empty($body) || false === strpos($body, 'Message)) {
+ return strval($xml->Message);
+ }
+ return '';
+ }
+
+ /**
+ * 尝试从body中获取错误Code
+ *
+ * @param $body
+ * @return string
+ */
+ private function retrieveErrorCode($body)
+ {
+ if (empty($body) || false === strpos($body, 'Code)) {
+ return strval($xml->Code);
+ }
+ return '';
+ }
+
+ /**
+ * 根据返回http状态码判断,[200-299]即认为是OK
+ *
+ * @return bool
+ */
+ protected function isResponseOk()
+ {
+ $status = $this->rawResponse->status;
+ if ((int)(intval($status) / 100) == 2) {
+ return true;
+ }
+ return false;
+ }
+
+ /**
+ * 返回原始的返回数据
+ *
+ * @return ResponseCore
+ */
+ public function getRawResponse()
+ {
+ return $this->rawResponse;
+ }
+
+ /**
+ * 标示请求是否成功
+ */
+ protected $isOk = false;
+ /**
+ * 由子类解析过的数据
+ */
+ protected $parsedData = null;
+ /**
+ * 存放auth函数返回的原始Response
+ *
+ * @var ResponseCore
+ */
+ protected $rawResponse;
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/UploadPartResult.php b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/UploadPartResult.php
new file mode 100644
index 000000000..c6b66d454
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/src/OSS/Result/UploadPartResult.php
@@ -0,0 +1,28 @@
+rawResponse->header;
+ if (isset($header["etag"])) {
+ return $header["etag"];
+ }
+ throw new OssException("cannot get ETag");
+
+ }
+}
\ No newline at end of file
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/AclResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/AclResultTest.php
new file mode 100644
index 000000000..12f4b1a7e
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/AclResultTest.php
@@ -0,0 +1,59 @@
+
+
+
+ 00220120222
+ user_example
+
+
+ public-read
+
+
+BBBB;
+
+ private $invalidXml = <<
+
+
+BBBB;
+
+ public function testParseValidXml()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 200);
+ $result = new AclResult($response);
+ $this->assertEquals("public-read", $result->getData());
+ }
+
+ public function testParseNullXml()
+ {
+ $response = new ResponseCore(array(), "", 200);
+ try {
+ new AclResult($response);
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+ $this->assertEquals('body is null', $e->getMessage());
+ }
+ }
+
+ public function testParseInvalidXml()
+ {
+ $response = new ResponseCore(array(), $this->invalidXml, 200);
+ try {
+ new AclResult($response);
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals("xml format exception", $e->getMessage());
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BodyResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BodyResultTest.php
new file mode 100644
index 000000000..af13d4d4c
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BodyResultTest.php
@@ -0,0 +1,26 @@
+assertTrue($result->isOK());
+ $this->assertEquals($result->getData(), "hi");
+ }
+
+ public function testParseInvalid404()
+ {
+ $response = new ResponseCore(array(), null, 200);
+ $result = new BodyResult($response);
+ $this->assertTrue($result->isOK());
+ $this->assertEquals($result->getData(), "");
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BucketCnameTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BucketCnameTest.php
new file mode 100644
index 000000000..87c9e5430
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BucketCnameTest.php
@@ -0,0 +1,77 @@
+client = Common::getOssClient();
+ $this->bucketName = 'php-sdk-test-bucket-' . strval(rand(0, 10000));
+ $this->client->createBucket($this->bucketName);
+ }
+
+ public function tearDown()
+ {
+ $this->client->deleteBucket($this->bucketName);
+ }
+
+ public function testBucketWithoutCname()
+ {
+ $cnameConfig = $this->client->getBucketCname($this->bucketName);
+ $this->assertEquals(0, count($cnameConfig->getCnames()));
+ }
+
+ public function testAddCname()
+ {
+ $this->client->addBucketCname($this->bucketName, 'www.baidu.com');
+ $this->client->addBucketCname($this->bucketName, 'www.qq.com');
+
+ $ret = $this->client->getBucketCname($this->bucketName);
+ $this->assertEquals(2, count($ret->getCnames()));
+
+ // add another 2 cnames
+ $this->client->addBucketCname($this->bucketName, 'www.sina.com.cn');
+ $this->client->addBucketCname($this->bucketName, 'www.iqiyi.com');
+
+ $ret = $this->client->getBucketCname($this->bucketName);
+ $cnames = $ret->getCnames();
+ $cnameList = array();
+
+ foreach ($cnames as $c) {
+ $cnameList[] = $c['Domain'];
+ }
+ $should = array(
+ 'www.baidu.com',
+ 'www.qq.com',
+ 'www.sina.com.cn',
+ 'www.iqiyi.com'
+ );
+ $this->assertEquals(4, count($cnames));
+ $this->assertEquals(sort($should), sort($cnameList));
+ }
+
+ public function testDeleteCname()
+ {
+ $this->client->addBucketCname($this->bucketName, 'www.baidu.com');
+ $this->client->addBucketCname($this->bucketName, 'www.qq.com');
+
+ $ret = $this->client->getBucketCname($this->bucketName);
+ $this->assertEquals(2, count($ret->getCnames()));
+
+ // delete one cname
+ $this->client->deleteBucketCname($this->bucketName, 'www.baidu.com');
+
+ $ret = $this->client->getBucketCname($this->bucketName);
+ $this->assertEquals(1, count($ret->getCnames()));
+ $cnames = $ret->getCnames();
+ $this->assertEquals('www.qq.com', $cnames[0]['Domain']);
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BucketInfoTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BucketInfoTest.php
new file mode 100644
index 000000000..80fa25c8e
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BucketInfoTest.php
@@ -0,0 +1,21 @@
+assertNotNull($bucketInfo);
+ $this->assertEquals('cn-beijing', $bucketInfo->getLocation());
+ $this->assertEquals('name', $bucketInfo->getName());
+ $this->assertEquals('today', $bucketInfo->getCreateDate());
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BucketLiveChannelTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BucketLiveChannelTest.php
new file mode 100644
index 000000000..bed68b036
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/BucketLiveChannelTest.php
@@ -0,0 +1,283 @@
+client = Common::getOssClient();
+ $this->bucketName = 'php-sdk-test-rtmp-bucket-name-' . strval(rand(0, 10000));
+ $this->client->createBucket($this->bucketName);
+ Common::waitMetaSync();
+ }
+
+ public function tearDown()
+ {
+ ////to delete created bucket
+ //1. delele live channel
+ $list = $this->client->listBucketLiveChannels($this->bucketName);
+ if (count($list->getChannelList()) != 0)
+ {
+ foreach($list->getChannelList() as $list)
+ {
+ $this->client->deleteBucketLiveChannel($this->bucketName, $list->getName());
+ }
+ }
+ //2. delete exsited object
+ $prefix = 'live-test/';
+ $delimiter = '/';
+ $nextMarker = '';
+ $maxkeys = 1000;
+ $options = array(
+ 'delimiter' => $delimiter,
+ 'prefix' => $prefix,
+ 'max-keys' => $maxkeys,
+ 'marker' => $nextMarker,
+ );
+
+ try {
+ $listObjectInfo = $this->client->listObjects($this->bucketName, $options);
+ } catch (OssException $e) {
+ printf($e->getMessage() . "\n");
+ return;
+ }
+
+ $objectList = $listObjectInfo->getObjectList(); // 文件列表
+ if (!empty($objectList))
+ {
+ foreach($objectList as $objectInfo)
+ $this->client->deleteObject($this->bucketName, $objectInfo->getKey());
+ }
+ //3. delete the bucket
+ $this->client->deleteBucket($this->bucketName);
+ }
+
+ public function testPutLiveChannel()
+ {
+ $config = new LiveChannelConfig(array(
+ 'description' => 'live channel 1',
+ 'type' => 'HLS',
+ 'fragDuration' => 10,
+ 'fragCount' => 5,
+ 'playListName' => 'hello.m3u8'
+ ));
+ $info = $this->client->putBucketLiveChannel($this->bucketName, 'live-1', $config);
+ $this->client->deleteBucketLiveChannel($this->bucketName, 'live-1');
+
+ $this->assertEquals('live-1', $info->getName());
+ $this->assertEquals('live channel 1', $info->getDescription());
+ $this->assertEquals(1, count($info->getPublishUrls()));
+ $this->assertEquals(1, count($info->getPlayUrls()));
+ }
+
+ public function testPutLiveChannelWithDefaultParams()
+ {
+ $config = new LiveChannelConfig(array(
+ 'description' => 'live channel 1',
+ 'type' => 'HLS',
+ ));
+ $info = $this->client->putBucketLiveChannel($this->bucketName, 'live-1', $config);
+ $this->client->deleteBucketLiveChannel($this->bucketName, 'live-1');
+
+ $this->assertEquals('live-1', $info->getName());
+ $this->assertEquals('live channel 1', $info->getDescription());
+ $this->assertEquals(1, count($info->getPublishUrls()));
+ $this->assertEquals(1, count($info->getPlayUrls()));
+ }
+
+ public function testListLiveChannels()
+ {
+ $config = new LiveChannelConfig(array(
+ 'description' => 'live channel 1',
+ 'type' => 'HLS',
+ 'fragDuration' => 10,
+ 'fragCount' => 5,
+ 'playListName' => 'hello.m3u8'
+ ));
+ $this->client->putBucketLiveChannel($this->bucketName, 'live-1', $config);
+
+ $config = new LiveChannelConfig(array(
+ 'description' => 'live channel 2',
+ 'type' => 'HLS',
+ 'fragDuration' => 10,
+ 'fragCount' => 5,
+ 'playListName' => 'hello.m3u8'
+ ));
+ $this->client->putBucketLiveChannel($this->bucketName, 'live-2', $config);
+
+ $list = $this->client->listBucketLiveChannels($this->bucketName);
+
+ $this->assertEquals($this->bucketName, $list->getBucketName());
+ $this->assertEquals(false, $list->getIsTruncated());
+ $channels = $list->getChannelList();
+ $this->assertEquals(2, count($channels));
+
+ $chan1 = $channels[0];
+ $this->assertEquals('live-1', $chan1->getName());
+ $this->assertEquals('live channel 1', $chan1->getDescription());
+ $this->assertEquals(1, count($chan1->getPublishUrls()));
+ $this->assertEquals(1, count($chan1->getPlayUrls()));
+
+ $chan2 = $channels[1];
+ $this->assertEquals('live-2', $chan2->getName());
+ $this->assertEquals('live channel 2', $chan2->getDescription());
+ $this->assertEquals(1, count($chan2->getPublishUrls()));
+ $this->assertEquals(1, count($chan2->getPlayUrls()));
+
+ $list = $this->client->listBucketLiveChannels($this->bucketName, array(
+ 'prefix' => 'live-',
+ 'marker' => 'live-1',
+ 'max-keys' => 10
+ ));
+ $channels = $list->getChannelList();
+ $this->assertEquals(1, count($channels));
+ $chan2 = $channels[0];
+ $this->assertEquals('live-2', $chan2->getName());
+ $this->assertEquals('live channel 2', $chan2->getDescription());
+ $this->assertEquals(1, count($chan2->getPublishUrls()));
+ $this->assertEquals(1, count($chan2->getPlayUrls()));
+
+ $this->client->deleteBucketLiveChannel($this->bucketName, 'live-1');
+ $this->client->deleteBucketLiveChannel($this->bucketName, 'live-2');
+ $list = $this->client->listBucketLiveChannels($this->bucketName, array(
+ 'prefix' => 'live-'
+ ));
+ $this->assertEquals(0, count($list->getChannelList()));
+ }
+
+ public function testDeleteLiveChannel()
+ {
+ $channelName = 'live-to-delete';
+ $config = new LiveChannelConfig(array(
+ 'description' => 'live channel to delete',
+ 'type' => 'HLS',
+ 'fragDuration' => 10,
+ 'fragCount' => 5,
+ 'playListName' => 'hello.m3u8'
+ ));
+ $this->client->putBucketLiveChannel($this->bucketName, $channelName, $config);
+
+ $this->client->deleteBucketLiveChannel($this->bucketName, $channelName);
+ $list = $this->client->listBucketLiveChannels($this->bucketName, array(
+ 'prefix' => $channelName
+ ));
+
+ $this->assertEquals(0, count($list->getChannelList()));
+ }
+
+ public function testSignRtmpUrl()
+ {
+ $channelName = '90475';
+ $bucket = 'douyu';
+ $now = time();
+ $url = $this->client->signRtmpUrl($bucket, $channelName, 900, array(
+ 'params' => array(
+ 'playlistName' => 'playlist.m3u8'
+ )
+ ));
+
+ $ret = parse_url($url);
+ $this->assertEquals('rtmp', $ret['scheme']);
+ parse_str($ret['query'], $query);
+
+ $this->assertTrue(isset($query['OSSAccessKeyId']));
+ $this->assertTrue(isset($query['Signature']));
+ $this->assertTrue(intval($query['Expires']) - ($now + 900) < 3);
+ $this->assertEquals('playlist.m3u8', $query['playlistName']);
+ }
+
+ public function testLiveChannelInfo()
+ {
+ $channelName = 'live-to-put-status';
+ $config = new LiveChannelConfig(array(
+ 'description' => 'test live channel info',
+ 'type' => 'HLS',
+ 'fragDuration' => 10,
+ 'fragCount' => 5,
+ 'playListName' => 'hello.m3u8'
+ ));
+ $this->client->putBucketLiveChannel($this->bucketName, $channelName, $config);
+
+ $info = $this->client->getLiveChannelInfo($this->bucketName, $channelName);
+ $this->assertEquals('test live channel info', $info->getDescription());
+ $this->assertEquals('enabled', $info->getStatus());
+ $this->assertEquals('HLS', $info->getType());
+ $this->assertEquals(10, $info->getFragDuration());
+ $this->assertEquals(5, $info->getFragCount());
+ $this->assertEquals('playlist.m3u8', $info->getPlayListName());
+
+ $this->client->deleteBucketLiveChannel($this->bucketName, $channelName);
+ $list = $this->client->listBucketLiveChannels($this->bucketName, array(
+ 'prefix' => $channelName
+ ));
+ $this->assertEquals(0, count($list->getChannelList()));
+ }
+
+ public function testPutLiveChannelStatus()
+ {
+ $channelName = 'live-to-put-status';
+ $config = new LiveChannelConfig(array(
+ 'description' => 'test live channel info',
+ 'type' => 'HLS',
+ 'fragDuration' => 10,
+ 'fragCount' => 5,
+ 'playListName' => 'hello.m3u8'
+ ));
+ $this->client->putBucketLiveChannel($this->bucketName, $channelName, $config);
+
+ $info = $this->client->getLiveChannelInfo($this->bucketName, $channelName);
+ $this->assertEquals('test live channel info', $info->getDescription());
+ $this->assertEquals('enabled', $info->getStatus());
+ $this->assertEquals('HLS', $info->getType());
+ $this->assertEquals(10, $info->getFragDuration());
+ $this->assertEquals(5, $info->getFragCount());
+ $this->assertEquals('playlist.m3u8', $info->getPlayListName());
+ $status = $this->client->getLiveChannelStatus($this->bucketName, $channelName);
+ $this->assertEquals('Idle', $status->getStatus());
+
+
+ $resp = $this->client->putLiveChannelStatus($this->bucketName, $channelName, "disabled");
+ $info = $this->client->getLiveChannelInfo($this->bucketName, $channelName);
+ $this->assertEquals('test live channel info', $info->getDescription());
+ $this->assertEquals('disabled', $info->getStatus());
+ $this->assertEquals('HLS', $info->getType());
+ $this->assertEquals(10, $info->getFragDuration());
+ $this->assertEquals(5, $info->getFragCount());
+ $this->assertEquals('playlist.m3u8', $info->getPlayListName());
+
+ $status = $this->client->getLiveChannelStatus($this->bucketName, $channelName);
+ //getLiveChannelInfo
+ $this->assertEquals('Disabled', $status->getStatus());
+
+ $this->client->deleteBucketLiveChannel($this->bucketName, $channelName);
+ $list = $this->client->listBucketLiveChannels($this->bucketName, array(
+ 'prefix' => $channelName
+ ));
+ $this->assertEquals(0, count($list->getChannelList()));
+
+ }
+ public function testLiveChannelHistory()
+ {
+ $channelName = 'live-test-history';
+ $config = new LiveChannelConfig(array(
+ 'description' => 'test live channel info',
+ 'type' => 'HLS',
+ 'fragDuration' => 10,
+ 'fragCount' => 5,
+ 'playListName' => 'hello.m3u8'
+ ));
+ $this->client->putBucketLiveChannel($this->bucketName, $channelName, $config);
+
+ $history = $this->client->getLiveChannelHistory($this->bucketName, $channelName);
+ $this->assertEquals(0, count($history->getLiveRecordList()));
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CallbackTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CallbackTest.php
new file mode 100644
index 000000000..491c4d9e3
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CallbackTest.php
@@ -0,0 +1,297 @@
+ossClient->putObject($this->bucket, $copiedObject, file_get_contents(__FILE__));
+
+ /**
+ * step 1. 初始化一个分块上传事件, 也就是初始化上传Multipart, 获取upload id
+ */
+ try {
+ $upload_id = $this->ossClient->initiateMultipartUpload($this->bucket, $object);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ /*
+ * step 2. uploadPartCopy
+ */
+ $copyId = 1;
+ $eTag = $this->ossClient->uploadPartCopy($this->bucket, $copiedObject, $this->bucket, $object, $copyId, $upload_id);
+ $upload_parts[] = array(
+ 'PartNumber' => $copyId,
+ 'ETag' => $eTag,
+ );
+
+ try {
+ $listPartsInfo = $this->ossClient->listParts($this->bucket, $object, $upload_id);
+ $this->assertNotNull($listPartsInfo);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+
+ /**
+ * step 3.
+ */
+
+ $json =
+ '{
+ "callbackUrl":"callback.oss-demo.com:23450",
+ "callbackHost":"oss-cn-hangzhou.aliyuncs.com",
+ "callbackBody":"{\"mimeType\":${mimeType},\"size\":${size},\"x:var1\":${x:var1},\"x:var2\":${x:var2}}",
+ "callbackBodyType":"application/json"
+ }';
+
+ $var =
+ '{
+ "x:var1":"value1",
+ "x:var2":"值2"
+ }';
+ $options = array(OssClient::OSS_CALLBACK => $json,
+ OssClient::OSS_CALLBACK_VAR => $var
+ );
+
+ try {
+ $result = $this->ossClient->completeMultipartUpload($this->bucket, $object, $upload_id, $upload_parts, $options);
+ $this->assertEquals("200", $result['info']['http_code']);
+ $this->assertEquals("{\"Status\":\"OK\"}", $result['body']);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ }
+
+ public function testMultipartUploadCallbackFailed()
+ {
+ $object = "multipart-callback-test.txt";
+ $copiedObject = "multipart-callback-test.txt.copied";
+ $this->ossClient->putObject($this->bucket, $copiedObject, file_get_contents(__FILE__));
+
+ /**
+ * step 1. 初始化一个分块上传事件, 也就是初始化上传Multipart, 获取upload id
+ */
+ try {
+ $upload_id = $this->ossClient->initiateMultipartUpload($this->bucket, $object);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ /*
+ * step 2. uploadPartCopy
+ */
+ $copyId = 1;
+ $eTag = $this->ossClient->uploadPartCopy($this->bucket, $copiedObject, $this->bucket, $object, $copyId, $upload_id);
+ $upload_parts[] = array(
+ 'PartNumber' => $copyId,
+ 'ETag' => $eTag,
+ );
+
+ try {
+ $listPartsInfo = $this->ossClient->listParts($this->bucket, $object, $upload_id);
+ $this->assertNotNull($listPartsInfo);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+
+ /**
+ * step 3.
+ */
+
+ $json =
+ '{
+ "callbackUrl":"www.baidu.com",
+ "callbackHost":"oss-cn-hangzhou.aliyuncs.com",
+ "callbackBody":"{\"mimeType\":${mimeType},\"size\":${size},\"x:var1\":${x:var1},\"x:var2\":${x:var2}}",
+ "callbackBodyType":"application/json"
+ }';
+
+ $var =
+ '{
+ "x:var1":"value1",
+ "x:var2":"值2"
+ }';
+ $options = array(OssClient::OSS_CALLBACK => $json,
+ OssClient::OSS_CALLBACK_VAR => $var
+ );
+
+ try {
+ $result = $this->ossClient->completeMultipartUpload($this->bucket, $object, $upload_id, $upload_parts, $options);
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+ $this->assertTrue(true);
+ $this->assertEquals("203", $e->getHTTPStatus());
+ }
+
+ }
+
+ public function testPutObjectCallbackNormal()
+ {
+ //json
+ {
+ $json =
+ '{
+ "callbackUrl":"callback.oss-demo.com:23450",
+ "callbackHost":"oss-cn-hangzhou.aliyuncs.com",
+ "callbackBody":"{\"mimeType\":${mimeType},\"size\":${size}}",
+ "callbackBodyType":"application/json"
+ }';
+ $options = array(OssClient::OSS_CALLBACK => $json);
+ $this->putObjectCallbackOk($options, "200");
+ }
+ //url
+ {
+ $url =
+ '{
+ "callbackUrl":"callback.oss-demo.com:23450",
+ "callbackHost":"oss-cn-hangzhou.aliyuncs.com",
+ "callbackBody":"bucket=${bucket}&object=${object}&etag=${etag}&size=${size}&mimeType=${mimeType}&imageInfo.height=${imageInfo.height}&imageInfo.width=${imageInfo.width}&imageInfo.format=${imageInfo.format}",
+ "callbackBodyType":"application/x-www-form-urlencoded"
+ }';
+ $options = array(OssClient::OSS_CALLBACK => $url);
+ $this->putObjectCallbackOk($options, "200");
+ }
+ // Unspecified typre
+ {
+ $url =
+ '{
+ "callbackUrl":"callback.oss-demo.com:23450",
+ "callbackHost":"oss-cn-hangzhou.aliyuncs.com",
+ "callbackBody":"bucket=${bucket}&object=${object}&etag=${etag}&size=${size}&mimeType=${mimeType}&imageInfo.height=${imageInfo.height}&imageInfo.width=${imageInfo.width}&imageInfo.format=${imageInfo.format}"
+ }';
+ $options = array(OssClient::OSS_CALLBACK => $url);
+ $this->putObjectCallbackOk($options, "200");
+ }
+ //json and body is chinese
+ {
+ $json =
+ '{
+ "callbackUrl":"callback.oss-demo.com:23450",
+ "callbackHost":"oss-cn-hangzhou.aliyuncs.com",
+ "callbackBody":"{\" 春水碧于天,画船听雨眠。\":\"垆边人似月,皓腕凝霜雪。\"}",
+ "callbackBodyType":"application/json"
+ }';
+ $options = array(OssClient::OSS_CALLBACK => $json);
+ $this->putObjectCallbackOk($options, "200");
+ }
+ //url and body is chinese
+ {
+ $url =
+ '{
+ "callbackUrl":"callback.oss-demo.com:23450",
+ "callbackHost":"oss-cn-hangzhou.aliyuncs.com",
+ "callbackBody":"春水碧于天,画船听雨眠。垆边人似月,皓腕凝霜雪",
+ "callbackBodyType":"application/x-www-form-urlencoded"
+ }';
+ $options = array(OssClient::OSS_CALLBACK => $url);
+ $this->putObjectCallbackOk($options, "200");
+ }
+ //json and add callback_var
+ {
+ $json =
+ '{
+ "callbackUrl":"callback.oss-demo.com:23450",
+ "callbackHost":"oss-cn-hangzhou.aliyuncs.com",
+ "callbackBody":"{\"mimeType\":${mimeType},\"size\":${size},\"x:var1\":${x:var1},\"x:var2\":${x:var2}}",
+ "callbackBodyType":"application/json"
+ }';
+
+ $var =
+ '{
+ "x:var1":"value1",
+ "x:var2":"aliyun.com"
+ }';
+ $options = array(OssClient::OSS_CALLBACK => $json,
+ OssClient::OSS_CALLBACK_VAR => $var
+ );
+ $this->putObjectCallbackOk($options, "200");
+ }
+ //url and add callback_var
+ {
+ $url =
+ '{
+ "callbackUrl":"callback.oss-demo.com:23450",
+ "callbackHost":"oss-cn-hangzhou.aliyuncs.com",
+ "callbackBody":"bucket=${bucket}&object=${object}&etag=${etag}&size=${size}&mimeType=${mimeType}&imageInfo.height=${imageInfo.height}&imageInfo.width=${imageInfo.width}&imageInfo.format=${imageInfo.format}&my_var1=${x:var1}&my_var2=${x:var2}",
+ "callbackBodyType":"application/x-www-form-urlencoded"
+ }';
+ $var =
+ '{
+ "x:var1":"value1凌波不过横塘路,但目送,芳",
+ "x:var2":"值2"
+ }';
+ $options = array(OssClient::OSS_CALLBACK => $url,
+ OssClient::OSS_CALLBACK_VAR => $var
+ );
+ $this->putObjectCallbackOk($options, "200");
+ }
+
+ }
+
+ public function testPutCallbackWithCallbackFailed()
+ {
+ {
+ $json =
+ '{
+ "callbackUrl":"http://www.baidu.com",
+ "callbackHost":"oss-cn-hangzhou.aliyuncs.com",
+ "callbackBody":"{\"mimeType\":${mimeType},\"size\":${size}}",
+ "callbackBodyType":"application/json"
+ }';
+ $options = array(OssClient::OSS_CALLBACK => $json);
+ $this->putObjectCallbackFailed($options, "203");
+ }
+
+ {
+ $url =
+ '{
+ "callbackUrl":"http://www.baidu.com",
+ "callbackHost":"oss-cn-hangzhou.aliyuncs.com",
+ "callbackBody":"bucket=${bucket}&object=${object}&etag=${etag}&size=${size}&mimeType=${mimeType}&imageInfo.height=${imageInfo.height}&imageInfo.width=${imageInfo.width}&imageInfo.format=${imageInfo.format}&my_var1=${x:var1}&my_var2=${x:var2}",
+ "callbackBodyType":"application/x-www-form-urlencoded"
+ }';
+ $options = array(OssClient::OSS_CALLBACK => $url);
+ $this->putObjectCallbackFailed($options, "203");
+ }
+
+ }
+
+ private function putObjectCallbackOk($options, $status)
+ {
+ $object = "oss-php-sdk-callback-test.txt";
+ $content = file_get_contents(__FILE__);
+ try {
+ $result = $this->ossClient->putObject($this->bucket, $object, $content, $options);
+ $this->assertEquals($status, $result['info']['http_code']);
+ $this->assertEquals("{\"Status\":\"OK\"}", $result['body']);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ }
+
+ private function putObjectCallbackFailed($options, $status)
+ {
+ $object = "oss-php-sdk-callback-test.txt";
+ $content = file_get_contents(__FILE__);
+ try {
+ $result = $this->ossClient->putObject($this->bucket, $object, $content, $options);
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+ $this->assertEquals($status, $e->getHTTPStatus());
+ $this->assertTrue(true);
+ }
+ }
+
+ public function setUp()
+ {
+ parent::setUp();
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CnameConfigTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CnameConfigTest.php
new file mode 100644
index 000000000..e3c1ce902
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CnameConfigTest.php
@@ -0,0 +1,77 @@
+
+
+
+ www.foo.com
+ enabled
+ 20150101
+
+
+ bar.com
+ disabled
+ 20160101
+
+
+BBBB;
+
+ public function testFromXml()
+ {
+ $cnameConfig = new CnameConfig();
+ $cnameConfig->parseFromXml($this->xml1);
+
+ $cnames = $cnameConfig->getCnames();
+ $this->assertEquals(2, count($cnames));
+ $this->assertEquals('www.foo.com', $cnames[0]['Domain']);
+ $this->assertEquals('enabled', $cnames[0]['Status']);
+ $this->assertEquals('20150101', $cnames[0]['LastModified']);
+
+ $this->assertEquals('bar.com', $cnames[1]['Domain']);
+ $this->assertEquals('disabled', $cnames[1]['Status']);
+ $this->assertEquals('20160101', $cnames[1]['LastModified']);
+ }
+
+ public function testToXml()
+ {
+ $cnameConfig = new CnameConfig();
+ $cnameConfig->addCname('www.foo.com');
+ $cnameConfig->addCname('bar.com');
+
+ $xml = $cnameConfig->serializeToXml();
+ $comp = new CnameConfig();
+ $comp->parseFromXml($xml);
+
+ $cnames1 = $cnameConfig->getCnames();
+ $cnames2 = $comp->getCnames();
+
+ $this->assertEquals(count($cnames1), count($cnames2));
+ $this->assertEquals(count($cnames1[0]), count($cnames2[0]));
+ $this->assertEquals(1, count($cnames1[0]));
+ $this->assertEquals($cnames1[0]['Domain'], $cnames2[0]['Domain']);
+ }
+
+ public function testCnameNumberLimit()
+ {
+ $cnameConfig = new CnameConfig();
+ for ($i = 0; $i < CnameConfig::OSS_MAX_RULES; $i += 1) {
+ $cnameConfig->addCname(strval($i) . '.foo.com');
+ }
+ try {
+ $cnameConfig->addCname('www.foo.com');
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals(
+ $e->getMessage(),
+ "num of cname in the config exceeds self::OSS_MAX_RULES: " . strval(CnameConfig::OSS_MAX_RULES));
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/Common.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/Common.php
new file mode 100644
index 000000000..9d7190ccf
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/Common.php
@@ -0,0 +1,70 @@
+getMessage() . "\n");
+ return null;
+ }
+ return $ossClient;
+ }
+
+ public static function getBucketName()
+ {
+ return getenv('OSS_BUCKET');
+ }
+
+ /**
+ * 工具方法,创建一个bucket
+ */
+ public static function createBucket()
+ {
+ $ossClient = self::getOssClient();
+ if (is_null($ossClient)) exit(1);
+ $bucket = self::getBucketName();
+ $acl = OssClient::OSS_ACL_TYPE_PUBLIC_READ;
+ try {
+ $ossClient->createBucket($bucket, $acl);
+ } catch (OssException $e) {
+ printf(__FUNCTION__ . ": FAILED\n");
+ printf($e->getMessage() . "\n");
+ return;
+ }
+ print(__FUNCTION__ . ": OK" . "\n");
+ }
+
+ /**
+ * Wait for bucket meta sync
+ */
+ public static function waitMetaSync()
+ {
+ if (getenv('TRAVIS')) {
+ sleep(10);
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ContentTypeTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ContentTypeTest.php
new file mode 100644
index 000000000..606c81041
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ContentTypeTest.php
@@ -0,0 +1,133 @@
+/dev/null', $output, $status);
+
+ $this->assertEquals(0, $status);
+ }
+
+ private function getContentType($bucket, $object)
+ {
+ $client = Common::getOssClient();
+ $headers = $client->getObjectMeta($bucket, $object);
+ return $headers['content-type'];
+ }
+
+ public function testByFileName()
+ {
+ $client = Common::getOssClient();
+ $bucket = Common::getBucketName();
+
+ $file = '/tmp/x.html';
+ $object = 'test/x';
+ $this->runCmd('touch ' . $file);
+
+ $client->uploadFile($bucket, $object, $file);
+ $type = $this->getContentType($bucket, $object);
+
+ $this->assertEquals('text/html', $type);
+
+ $file = '/tmp/x.json';
+ $object = 'test/y';
+ $this->runCmd('dd if=/dev/urandom of=' . $file . ' bs=1024 count=100');
+
+ $client->multiuploadFile($bucket, $object, $file, array('partSize' => 100));
+ $type = $this->getContentType($bucket, $object);
+
+ $this->assertEquals('application/json', $type);
+ }
+
+ public function testByObjectKey()
+ {
+ $client = Common::getOssClient();
+ $bucket = Common::getBucketName();
+
+ $object = "test/x.txt";
+ $client->putObject($bucket, $object, "hello world");
+ $type = $this->getContentType($bucket, $object);
+
+ $this->assertEquals('text/plain', $type);
+
+ $file = '/tmp/x.html';
+ $object = 'test/x.txt';
+ $this->runCmd('touch ' . $file);
+
+ $client->uploadFile($bucket, $object, $file);
+ $type = $this->getContentType($bucket, $object);
+
+ $this->assertEquals('text/html', $type);
+
+ $file = '/tmp/x.none';
+ $object = 'test/x.txt';
+ $this->runCmd('touch ' . $file);
+
+ $client->uploadFile($bucket, $object, $file);
+ $type = $this->getContentType($bucket, $object);
+
+ $this->assertEquals('text/plain', $type);
+
+ $file = '/tmp/x.mp3';
+ $object = 'test/y.json';
+ $this->runCmd('dd if=/dev/urandom of=' . $file . ' bs=1024 count=100');
+
+ $client->multiuploadFile($bucket, $object, $file, array('partSize' => 100));
+ $type = $this->getContentType($bucket, $object);
+
+ $this->assertEquals('audio/mpeg', $type);
+
+ $file = '/tmp/x.none';
+ $object = 'test/y.json';
+ $this->runCmd('dd if=/dev/urandom of=' . $file . ' bs=1024 count=100');
+
+ $client->multiuploadFile($bucket, $object, $file, array('partSize' => 100));
+ $type = $this->getContentType($bucket, $object);
+
+ $this->assertEquals('application/json', $type);
+ }
+
+ public function testByUser()
+ {
+ $client = Common::getOssClient();
+ $bucket = Common::getBucketName();
+
+ $object = "test/x.txt";
+ $client->putObject($bucket, $object, "hello world", array(
+ 'Content-Type' => 'text/html'
+ ));
+ $type = $this->getContentType($bucket, $object);
+
+ $this->assertEquals('text/html', $type);
+
+ $file = '/tmp/x.html';
+ $object = 'test/x';
+ $this->runCmd('touch ' . $file);
+
+ $client->uploadFile($bucket, $object, $file, array(
+ 'Content-Type' => 'application/json'
+ ));
+ $type = $this->getContentType($bucket, $object);
+
+ $this->assertEquals('application/json', $type);
+
+ $file = '/tmp/x.json';
+ $object = 'test/y';
+ $this->runCmd('dd if=/dev/urandom of=' . $file . ' bs=1024 count=100');
+
+ $client->multiuploadFile($bucket, $object, $file, array(
+ 'partSize' => 100,
+ 'Content-Type' => 'audio/mpeg'
+ ));
+ $type = $this->getContentType($bucket, $object);
+
+ $this->assertEquals('audio/mpeg', $type);
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CopyObjectResult.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CopyObjectResult.php
new file mode 100644
index 000000000..171d4c84d
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CopyObjectResult.php
@@ -0,0 +1,52 @@
+
+
+ Fri, 24 Feb 2012 07:18:48 GMT
+ "5B3C1A2E053D763E1B002CC607C5A0FE"
+
+BBBB;
+
+ public function testNullResponse()
+ {
+ $response = null;
+ try {
+ new CopyObjectResult($response);
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals('raw response is null', $e->getMessage());
+ }
+ }
+
+ public function testOkResponse()
+ {
+ $header= array();
+ $response = new ResponseCore($header, $this->body, 200);
+ $result = new CopyObjectResult($response);
+ $data = $result->getData();
+ $this->assertTrue($result->isOK());
+ $this->assertEquals("Fri, 24 Feb 2012 07:18:48 GMT", $data[0]);
+ $this->assertEquals("\"5B3C1A2E053D763E1B002CC607C5A0FE\"", $data[1]);
+ }
+
+ public function testFailResponse()
+ {
+ $response = new ResponseCore(array(), "", 404);
+ try {
+ new CopyObjectResult($response);
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+
+ }
+ }
+
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CorsConfigTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CorsConfigTest.php
new file mode 100644
index 000000000..ddc4d3ab8
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/CorsConfigTest.php
@@ -0,0 +1,140 @@
+
+
+
+http://www.b.com
+http://www.a.com
+http://www.a.com
+GET
+PUT
+POST
+x-oss-test
+x-oss-test2
+x-oss-test2
+x-oss-test3
+x-oss-test1
+x-oss-test1
+x-oss-test2
+10
+
+
+http://www.b.com
+GET
+x-oss-test
+x-oss-test1
+110
+
+
+BBBB;
+
+ private $validXml2 = <<
+
+
+http://www.b.com
+http://www.a.com
+http://www.a.com
+GET
+PUT
+POST
+x-oss-test
+x-oss-test2
+x-oss-test2
+x-oss-test3
+x-oss-test1
+x-oss-test1
+x-oss-test2
+10
+
+
+BBBB;
+
+ public function testParseValidXml()
+ {
+ $corsConfig = new CorsConfig();
+ $corsConfig->parseFromXml($this->validXml);
+ $this->assertEquals($this->cleanXml($this->validXml), $this->cleanXml($corsConfig->serializeToXml()));
+ $this->assertNotNull($corsConfig->getRules());
+ $rules = $corsConfig->getRules();
+ $this->assertNotNull($rules[0]->getAllowedHeaders());
+ $this->assertNotNull($rules[0]->getAllowedMethods());
+ $this->assertNotNull($rules[0]->getAllowedOrigins());
+ $this->assertNotNull($rules[0]->getExposeHeaders());
+ $this->assertNotNull($rules[0]->getMaxAgeSeconds());
+ }
+
+ public function testParseValidXml2()
+ {
+ $corsConfig = new CorsConfig();
+ $corsConfig->parseFromXml($this->validXml2);
+ $this->assertEquals($this->cleanXml($this->validXml2), $this->cleanXml($corsConfig->serializeToXml()));
+ }
+
+ public function testCreateCorsConfigFromMoreThan10Rules()
+ {
+ $corsConfig = new CorsConfig();
+ $rule = new CorsRule();
+ for ($i = 0; $i < CorsConfig::OSS_MAX_RULES; $i += 1) {
+ $corsConfig->addRule($rule);
+ }
+ try {
+ $corsConfig->addRule($rule);
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals($e->getMessage(), "num of rules in the config exceeds self::OSS_MAX_RULES: " . strval(CorsConfig::OSS_MAX_RULES));
+ }
+ }
+
+ public function testCreateCorsConfigParamAbsent()
+ {
+ $corsConfig = new CorsConfig();
+ $rule = new CorsRule();
+ $corsConfig->addRule($rule);
+
+ try {
+ $xml = $corsConfig->serializeToXml();
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals($e->getMessage(), "maxAgeSeconds is not set in the Rule");
+ }
+ }
+
+ public function testCreateCorsConfigFromScratch()
+ {
+ $corsConfig = new CorsConfig();
+ $rule = new CorsRule();
+ $rule->addAllowedHeader("x-oss-test");
+ $rule->addAllowedHeader("x-oss-test2");
+ $rule->addAllowedHeader("x-oss-test2");
+ $rule->addAllowedHeader("x-oss-test3");
+ $rule->addAllowedOrigin("http://www.b.com");
+ $rule->addAllowedOrigin("http://www.a.com");
+ $rule->addAllowedOrigin("http://www.a.com");
+ $rule->addAllowedMethod("GET");
+ $rule->addAllowedMethod("PUT");
+ $rule->addAllowedMethod("POST");
+ $rule->addExposeHeader("x-oss-test1");
+ $rule->addExposeHeader("x-oss-test1");
+ $rule->addExposeHeader("x-oss-test2");
+ $rule->setMaxAgeSeconds(10);
+ $corsConfig->addRule($rule);
+ $this->assertEquals($this->cleanXml($this->validXml2), $this->cleanXml($corsConfig->serializeToXml()));
+ $this->assertEquals($this->cleanXml($this->validXml2), $this->cleanXml(strval($corsConfig)));
+ }
+
+ private function cleanXml($xml)
+ {
+ return str_replace("\n", "", str_replace("\r", "", $xml));
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ExistResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ExistResultTest.php
new file mode 100644
index 000000000..e1b4e8142
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ExistResultTest.php
@@ -0,0 +1,38 @@
+assertTrue($result->isOK());
+ $this->assertEquals($result->getData(), true);
+ }
+
+ public function testParseInvalid404()
+ {
+ $response = new ResponseCore(array(), "", 404);
+ $result = new ExistResult($response);
+ $this->assertTrue($result->isOK());
+ $this->assertEquals($result->getData(), false);
+ }
+
+ public function testInvalidResponse()
+ {
+ $response = new ResponseCore(array(), "", 300);
+ try {
+ new ExistResult($response);
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetCorsResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetCorsResultTest.php
new file mode 100644
index 000000000..a3281c856
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetCorsResultTest.php
@@ -0,0 +1,67 @@
+
+
+
+http://www.b.com
+http://www.a.com
+http://www.a.com
+GET
+PUT
+POST
+x-oss-test
+x-oss-test2
+x-oss-test2
+x-oss-test3
+x-oss-test1
+x-oss-test1
+x-oss-test2
+10
+
+
+http://www.b.com
+GET
+x-oss-test
+x-oss-test1
+110
+
+
+BBBB;
+
+ public function testParseValidXml()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 200);
+ $result = new GetCorsResult($response);
+ $this->assertTrue($result->isOK());
+ $this->assertNotNull($result->getData());
+ $this->assertNotNull($result->getRawResponse());
+ $corsConfig = $result->getData();
+ $this->assertEquals($this->cleanXml($this->validXml), $this->cleanXml($corsConfig->serializeToXml()));
+ }
+
+ private function cleanXml($xml)
+ {
+ return str_replace("\n", "", str_replace("\r", "", $xml));
+ }
+
+ public function testInvalidResponse()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 300);
+ try {
+ new GetCorsResult($response);
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetLifecycleResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetLifecycleResultTest.php
new file mode 100644
index 000000000..92ae2086a
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetLifecycleResultTest.php
@@ -0,0 +1,59 @@
+
+
+
+delete obsoleted files
+obsoleted/
+Enabled
+3
+
+
+delete temporary files
+temporary/
+Enabled
+2022-10-12T00:00:00.000Z
+2022-10-12T00:00:00.000Z
+
+
+BBBB;
+
+ public function testParseValidXml()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 200);
+ $result = new GetLifecycleResult($response);
+ $this->assertTrue($result->isOK());
+ $this->assertNotNull($result->getData());
+ $this->assertNotNull($result->getRawResponse());
+ $lifecycleConfig = $result->getData();
+ $this->assertEquals($this->cleanXml($this->validXml), $this->cleanXml($lifecycleConfig->serializeToXml()));
+ }
+
+ private function cleanXml($xml)
+ {
+ return str_replace("\n", "", str_replace("\r", "", $xml));
+ }
+
+ public function testInvalidResponse()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 300);
+ try {
+ new GetLifecycleResult($response);
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+
+ }
+ }
+
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetLoggingResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetLoggingResultTest.php
new file mode 100644
index 000000000..619501481
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetLoggingResultTest.php
@@ -0,0 +1,51 @@
+
+
+
+TargetBucket
+TargetPrefix
+
+
+BBBB;
+
+ public function testParseValidXml()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 200);
+ $result = new GetLoggingResult($response);
+ $this->assertTrue($result->isOK());
+ $this->assertNotNull($result->getData());
+ $this->assertNotNull($result->getRawResponse());
+ $loggingConfig = $result->getData();
+ $this->assertEquals($this->cleanXml($this->validXml), $this->cleanXml($loggingConfig->serializeToXml()));
+ $this->assertEquals("TargetBucket", $loggingConfig->getTargetBucket());
+ $this->assertEquals("TargetPrefix", $loggingConfig->getTargetPrefix());
+ }
+
+ private function cleanXml($xml)
+ {
+ return str_replace("\n", "", str_replace("\r", "", $xml));
+ }
+
+ public function testInvalidResponse()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 300);
+ try {
+ new GetLoggingResult($response);
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetRefererResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetRefererResultTest.php
new file mode 100644
index 000000000..072aa43ac
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetRefererResultTest.php
@@ -0,0 +1,51 @@
+
+
+true
+
+http://www.aliyun.com
+https://www.aliyun.com
+http://www.*.com
+https://www.?.aliyuncs.com
+
+
+BBBB;
+
+ public function testParseValidXml()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 200);
+ $result = new GetRefererResult($response);
+ $this->assertTrue($result->isOK());
+ $this->assertNotNull($result->getData());
+ $this->assertNotNull($result->getRawResponse());
+ $refererConfig = $result->getData();
+ $this->assertEquals($this->cleanXml($this->validXml), $this->cleanXml($refererConfig->serializeToXml()));
+ }
+
+ private function cleanXml($xml)
+ {
+ return str_replace("\n", "", str_replace("\r", "", $xml));
+ }
+
+ public function testInvalidResponse()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 300);
+ try {
+ new GetRefererResult($response);
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetWebsiteResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetWebsiteResultTest.php
new file mode 100644
index 000000000..70e155943
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/GetWebsiteResultTest.php
@@ -0,0 +1,50 @@
+
+
+
+index.html
+
+
+errorDocument.html
+
+
+BBBB;
+
+ public function testParseValidXml()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 200);
+ $result = new GetWebsiteResult($response);
+ $this->assertTrue($result->isOK());
+ $this->assertNotNull($result->getData());
+ $this->assertNotNull($result->getRawResponse());
+ $websiteConfig = $result->getData();
+ $this->assertEquals($this->cleanXml($this->validXml), $this->cleanXml($websiteConfig->serializeToXml()));
+ }
+
+ private function cleanXml($xml)
+ {
+ return str_replace("\n", "", str_replace("\r", "", $xml));
+ }
+
+ public function testInvalidResponse()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 300);
+ try {
+ new GetWebsiteResult($response);
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/HeaderResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/HeaderResultTest.php
new file mode 100644
index 000000000..dae497544
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/HeaderResultTest.php
@@ -0,0 +1,23 @@
+ 'value'), "", 200);
+ $result = new HeaderResult($response);
+ $this->assertTrue($result->isOK());
+ $this->assertTrue(is_array($result->getData()));
+ $data = $result->getData();
+ $this->assertEquals($data['key'], 'value');
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/HttpTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/HttpTest.php
new file mode 100644
index 000000000..a59dfcd2d
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/HttpTest.php
@@ -0,0 +1,77 @@
+assertFalse($res->isOK());
+ $this->assertTrue($res->isOK(500));
+ }
+
+ public function testGet()
+ {
+ $httpCore = new RequestCore("http://www.baidu.com");
+ $httpResponse = $httpCore->send_request();
+ $this->assertNotNull($httpResponse);
+ }
+
+ public function testSetProxyAndTimeout()
+ {
+ $httpCore = new RequestCore("http://www.baidu.com");
+ $httpCore->set_proxy("1.0.2.1:8888");
+ $httpCore->connect_timeout = 1;
+ try {
+ $httpResponse = $httpCore->send_request();
+ $this->assertTrue(false);
+ } catch (RequestCore_Exception $e) {
+
+ }
+ }
+
+ public function testGetParseTrue()
+ {
+ $httpCore = new RequestCore("http://www.baidu.com");
+ $httpCore->curlopts = array(CURLOPT_HEADER => true);
+ $url = $httpCore->send_request(true);
+ foreach ($httpCore->get_response_header() as $key => $value) {
+ $this->assertEquals($httpCore->get_response_header($key), $value);
+ }
+ $this->assertNotNull($url);
+ }
+
+ public function testParseResponse()
+ {
+ $httpCore = new RequestCore("http://www.baidu.com");
+ $response = $httpCore->send_request();
+ $parsed = $httpCore->process_response(null, $response);
+ $this->assertNotNull($parsed);
+ }
+
+ public function testExceptionGet()
+ {
+ $httpCore = null;
+ $exception = false;
+ try {
+ $httpCore = new RequestCore("http://www.notexistsitexx.com");
+ $httpCore->set_body("");
+ $httpCore->set_method("GET");
+ $httpCore->connect_timeout = 10;
+ $httpCore->timeout = 10;
+ $res = $httpCore->send_request();
+ } catch (RequestCore_Exception $e) {
+ $exception = true;
+ }
+ $this->assertTrue($exception);
+ }
+}
+
+
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/InitiateMultipartUploadResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/InitiateMultipartUploadResultTest.php
new file mode 100644
index 000000000..9f6c7a53e
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/InitiateMultipartUploadResultTest.php
@@ -0,0 +1,47 @@
+
+
+ multipart_upload
+ multipart.data
+ 0004B9894A22E5B1888A1E29F8236E2D
+
+BBBB;
+
+ private $invalidXml = <<
+
+ multipart_upload
+ multipart.data
+
+BBBB;
+
+
+ public function testParseValidXml()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 200);
+ $result = new InitiateMultipartUploadResult($response);
+ $this->assertEquals("0004B9894A22E5B1888A1E29F8236E2D", $result->getData());
+ }
+
+ public function testParseInvalidXml()
+ {
+ $response = new ResponseCore(array(), $this->invalidXml, 200);
+ try {
+ $result = new InitiateMultipartUploadResult($response);
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/LifecycleConfigTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/LifecycleConfigTest.php
new file mode 100644
index 000000000..7bd033185
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/LifecycleConfigTest.php
@@ -0,0 +1,130 @@
+
+
+
+delete obsoleted files
+obsoleted/
+Enabled
+3
+
+
+delete temporary files
+temporary/
+Enabled
+2022-10-12T00:00:00.000Z
+2022-10-12T00:00:00.000Z
+
+
+BBBB;
+
+ private $validLifecycle2 = <<
+
+delete temporary files
+temporary/
+Enabled
+2022-10-12T00:00:00.000Z
+2022-10-12T00:00:00.000Z
+
+
+BBBB;
+
+ private $nullLifecycle = <<
+
+BBBB;
+
+ public function testConstructValidConfig()
+ {
+ $lifecycleConfig = new LifecycleConfig();
+ $actions = array();
+ $actions[] = new LifecycleAction("Expiration", "Days", 3);
+ $lifecycleRule = new LifecycleRule("delete obsoleted files", "obsoleted/", "Enabled", $actions);
+ $lifecycleConfig->addRule($lifecycleRule);
+ $actions = array();
+ $actions[] = new LifecycleAction("Expiration", "Date", '2022-10-12T00:00:00.000Z');
+ $actions[] = new LifecycleAction("Expiration2", "Date", '2022-10-12T00:00:00.000Z');
+ $lifecycleRule = new LifecycleRule("delete temporary files", "temporary/", "Enabled", $actions);
+ $lifecycleConfig->addRule($lifecycleRule);
+ try {
+ $lifecycleConfig->addRule(null);
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals('lifecycleRule is null', $e->getMessage());
+ }
+ $this->assertEquals($this->cleanXml(strval($lifecycleConfig)), $this->cleanXml($this->validLifecycle));
+ }
+
+ public function testParseValidXml()
+ {
+ $lifecycleConfig = new LifecycleConfig();
+ $lifecycleConfig->parseFromXml($this->validLifecycle);
+ $this->assertEquals($this->cleanXml($lifecycleConfig->serializeToXml()), $this->cleanXml($this->validLifecycle));
+ $this->assertEquals(2, count($lifecycleConfig->getRules()));
+ $rules = $lifecycleConfig->getRules();
+ $this->assertEquals('delete temporary files', $rules[1]->getId());
+ }
+
+ public function testParseValidXml2()
+ {
+ $lifecycleConfig = new LifecycleConfig();
+ $lifecycleConfig->parseFromXml($this->validLifecycle2);
+ $this->assertEquals($this->cleanXml($lifecycleConfig->serializeToXml()), $this->cleanXml($this->validLifecycle2));
+ $this->assertEquals(1, count($lifecycleConfig->getRules()));
+ $rules = $lifecycleConfig->getRules();
+ $this->assertEquals('delete temporary files', $rules[0]->getId());
+ }
+
+ public function testParseNullXml()
+ {
+ $lifecycleConfig = new LifecycleConfig();
+ $lifecycleConfig->parseFromXml($this->nullLifecycle);
+ $this->assertEquals($this->cleanXml($lifecycleConfig->serializeToXml()), $this->cleanXml($this->nullLifecycle));
+ $this->assertEquals(0, count($lifecycleConfig->getRules()));
+ }
+
+ public function testLifecycleRule()
+ {
+ $lifecycleRule = new LifecycleRule("x", "x", "x", array('x'));
+ $lifecycleRule->setId("id");
+ $lifecycleRule->setPrefix("prefix");
+ $lifecycleRule->setStatus("Enabled");
+ $lifecycleRule->setActions(array());
+
+ $this->assertEquals('id', $lifecycleRule->getId());
+ $this->assertEquals('prefix', $lifecycleRule->getPrefix());
+ $this->assertEquals('Enabled', $lifecycleRule->getStatus());
+ $this->assertEmpty($lifecycleRule->getActions());
+ }
+
+ public function testLifecycleAction()
+ {
+ $action = new LifecycleAction('x', 'x', 'x');
+ $this->assertEquals($action->getAction(), 'x');
+ $this->assertEquals($action->getTimeSpec(), 'x');
+ $this->assertEquals($action->getTimeValue(), 'x');
+ $action->setAction('y');
+ $action->setTimeSpec('y');
+ $action->setTimeValue('y');
+ $this->assertEquals($action->getAction(), 'y');
+ $this->assertEquals($action->getTimeSpec(), 'y');
+ $this->assertEquals($action->getTimeValue(), 'y');
+ }
+
+ private function cleanXml($xml)
+ {
+ return str_replace("\n", "", str_replace("\r", "", $xml));
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListBucketsResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListBucketsResultTest.php
new file mode 100644
index 000000000..1abe1f503
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListBucketsResultTest.php
@@ -0,0 +1,97 @@
+
+
+
+ ut_test_put_bucket
+ ut_test_put_bucket
+
+
+
+ oss-cn-hangzhou-a
+ xz02tphky6fjfiuc0
+ 2014-05-15T11:18:32.000Z
+
+
+ oss-cn-hangzhou-a
+ xz02tphky6fjfiuc1
+ 2014-05-15T11:18:32.000Z
+
+
+
+BBBB;
+
+ private $nullXml = <<
+
+
+ ut_test_put_bucket
+ ut_test_put_bucket
+
+
+
+
+BBBB;
+
+ public function testParseValidXml()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 200);
+ $result = new ListBucketsResult($response);
+ $this->assertTrue($result->isOK());
+ $this->assertNotNull($result->getData());
+ $this->assertNotNull($result->getRawResponse());
+ $bucketListInfo = $result->getData();
+ $this->assertEquals(2, count($bucketListInfo->getBucketList()));
+ }
+
+ public function testParseNullXml()
+ {
+ $response = new ResponseCore(array(), $this->nullXml, 200);
+ $result = new ListBucketsResult($response);
+ $this->assertTrue($result->isOK());
+ $this->assertNotNull($result->getData());
+ $this->assertNotNull($result->getRawResponse());
+ $bucketListInfo = $result->getData();
+ $this->assertEquals(0, count($bucketListInfo->getBucketList()));
+ }
+
+ public function test403()
+ {
+ $errorHeader = array(
+ 'x-oss-request-id' => '1a2b-3c4d'
+ );
+
+ $errorBody = <<< BBBB
+
+
+ NoSuchBucket
+ The specified bucket does not exist.
+ 566B870D207FB3044302EB0A
+ hello.oss-test.aliyun-inc.com
+ hello
+
+BBBB;
+ $response = new ResponseCore($errorHeader, $errorBody, 403);
+ try {
+ new ListBucketsResult($response);
+ } catch (OssException $e) {
+ $this->assertEquals(
+ $e->getMessage(),
+ 'NoSuchBucket: The specified bucket does not exist. RequestId: 1a2b-3c4d');
+ $this->assertEquals($e->getHTTPStatus(), '403');
+ $this->assertEquals($e->getRequestId(), '1a2b-3c4d');
+ $this->assertEquals($e->getErrorCode(), 'NoSuchBucket');
+ $this->assertEquals($e->getErrorMessage(), 'The specified bucket does not exist.');
+ $this->assertEquals($e->getDetails(), $errorBody);
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListMultipartUploadResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListMultipartUploadResultTest.php
new file mode 100644
index 000000000..5c757d315
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListMultipartUploadResultTest.php
@@ -0,0 +1,114 @@
+
+
+ oss-example
+ xx
+ 3
+ oss.avi
+ 0004B99B8E707874FC2D692FA5D77D3F
+ x
+ xx
+ 1000
+ false
+
+ multipart.data
+ 0004B999EF518A1FE585B0C9360DC4C8
+ 2012-02-23T04:18:23.000Z
+
+
+ multipart.data
+ 0004B999EF5A239BB9138C6227D69F95
+ 2012-02-23T04:18:23.000Z
+
+
+ oss.avi
+ 0004B99B8E707874FC2D692FA5D77D3F
+ 2012-02-23T06:14:27.000Z
+
+
+BBBB;
+
+ private $validXmlWithEncodedKey = <<
+
+ oss-example
+ url
+ php%2Bkey-marker
+ 3
+ php%2Bnext-key-marker
+ 0004B99B8E707874FC2D692FA5D77D3F
+ %2F
+ php%2Bprefix
+ 1000
+ true
+
+ php%2Bkey-1
+ 0004B999EF518A1FE585B0C9360DC4C8
+ 2012-02-23T04:18:23.000Z
+
+
+ php%2Bkey-2
+ 0004B999EF5A239BB9138C6227D69F95
+ 2012-02-23T04:18:23.000Z
+
+
+ php%2Bkey-3
+ 0004B99B8E707874FC2D692FA5D77D3F
+ 2012-02-23T06:14:27.000Z
+
+
+BBBB;
+
+ public function testParseValidXml()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 200);
+ $result = new ListMultipartUploadResult($response);
+ $listMultipartUploadInfo = $result->getData();
+ $this->assertEquals("oss-example", $listMultipartUploadInfo->getBucket());
+ $this->assertEquals("xx", $listMultipartUploadInfo->getKeyMarker());
+ $this->assertEquals(3, $listMultipartUploadInfo->getUploadIdMarker());
+ $this->assertEquals("oss.avi", $listMultipartUploadInfo->getNextKeyMarker());
+ $this->assertEquals("0004B99B8E707874FC2D692FA5D77D3F", $listMultipartUploadInfo->getNextUploadIdMarker());
+ $this->assertEquals("x", $listMultipartUploadInfo->getDelimiter());
+ $this->assertEquals("xx", $listMultipartUploadInfo->getPrefix());
+ $this->assertEquals(1000, $listMultipartUploadInfo->getMaxUploads());
+ $this->assertEquals("false", $listMultipartUploadInfo->getIsTruncated());
+ $uploads = $listMultipartUploadInfo->getUploads();
+ $this->assertEquals("multipart.data", $uploads[0]->getKey());
+ $this->assertEquals("0004B999EF518A1FE585B0C9360DC4C8", $uploads[0]->getUploadId());
+ $this->assertEquals("2012-02-23T04:18:23.000Z", $uploads[0]->getInitiated());
+ }
+
+ public function testParseValidXmlWithEncodedKey()
+ {
+ $response = new ResponseCore(array(), $this->validXmlWithEncodedKey, 200);
+ $result = new ListMultipartUploadResult($response);
+ $listMultipartUploadInfo = $result->getData();
+ $this->assertEquals("oss-example", $listMultipartUploadInfo->getBucket());
+ $this->assertEquals("php+key-marker", $listMultipartUploadInfo->getKeyMarker());
+ $this->assertEquals("php+next-key-marker", $listMultipartUploadInfo->getNextKeyMarker());
+ $this->assertEquals(3, $listMultipartUploadInfo->getUploadIdMarker());
+ $this->assertEquals("0004B99B8E707874FC2D692FA5D77D3F", $listMultipartUploadInfo->getNextUploadIdMarker());
+ $this->assertEquals("/", $listMultipartUploadInfo->getDelimiter());
+ $this->assertEquals("php+prefix", $listMultipartUploadInfo->getPrefix());
+ $this->assertEquals(1000, $listMultipartUploadInfo->getMaxUploads());
+ $this->assertEquals("true", $listMultipartUploadInfo->getIsTruncated());
+ $uploads = $listMultipartUploadInfo->getUploads();
+ $this->assertEquals("php+key-1", $uploads[0]->getKey());
+ $this->assertEquals("0004B999EF518A1FE585B0C9360DC4C8", $uploads[0]->getUploadId());
+ $this->assertEquals("2012-02-23T04:18:23.000Z", $uploads[0]->getInitiated());
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListObjectsResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListObjectsResultTest.php
new file mode 100644
index 000000000..85f262ca4
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListObjectsResultTest.php
@@ -0,0 +1,151 @@
+
+
+ testbucket-hf
+
+
+ 1000
+ /
+ false
+
+ oss-php-sdk-test/
+
+
+ test/
+
+
+BBBB;
+
+ private $validXml2 = <<
+
+ testbucket-hf
+ oss-php-sdk-test/
+ xx
+ 1000
+ /
+ false
+
+ oss-php-sdk-test/upload-test-object-name.txt
+ 2015-11-18T03:36:00.000Z
+ "89B9E567E7EB8815F2F7D41851F9A2CD"
+ Normal
+ 13115
+ Standard
+
+ cname_user
+ cname_user
+
+
+
+BBBB;
+
+ private $validXmlWithEncodedKey = <<
+
+ testbucket-hf
+ url
+ php%2Fprefix
+ php%2Fmarker
+ php%2Fnext-marker
+ 1000
+ %2F
+ true
+
+ php/a%2Bb
+ 2015-11-18T03:36:00.000Z
+ "89B9E567E7EB8815F2F7D41851F9A2CD"
+ Normal
+ 13115
+ Standard
+
+ cname_user
+ cname_user
+
+
+
+BBBB;
+
+ public function testParseValidXml1()
+ {
+ $response = new ResponseCore(array(), $this->validXml1, 200);
+ $result = new ListObjectsResult($response);
+ $this->assertTrue($result->isOK());
+ $this->assertNotNull($result->getData());
+ $this->assertNotNull($result->getRawResponse());
+ $objectListInfo = $result->getData();
+ $this->assertEquals(2, count($objectListInfo->getPrefixList()));
+ $this->assertEquals(0, count($objectListInfo->getObjectList()));
+ $this->assertEquals('testbucket-hf', $objectListInfo->getBucketName());
+ $this->assertEquals('', $objectListInfo->getPrefix());
+ $this->assertEquals('', $objectListInfo->getMarker());
+ $this->assertEquals(1000, $objectListInfo->getMaxKeys());
+ $this->assertEquals('/', $objectListInfo->getDelimiter());
+ $this->assertEquals('false', $objectListInfo->getIsTruncated());
+ $prefixes = $objectListInfo->getPrefixList();
+ $this->assertEquals('oss-php-sdk-test/', $prefixes[0]->getPrefix());
+ $this->assertEquals('test/', $prefixes[1]->getPrefix());
+ }
+
+ public function testParseValidXml2()
+ {
+ $response = new ResponseCore(array(), $this->validXml2, 200);
+ $result = new ListObjectsResult($response);
+ $this->assertTrue($result->isOK());
+ $this->assertNotNull($result->getData());
+ $this->assertNotNull($result->getRawResponse());
+ $objectListInfo = $result->getData();
+ $this->assertEquals(0, count($objectListInfo->getPrefixList()));
+ $this->assertEquals(1, count($objectListInfo->getObjectList()));
+ $this->assertEquals('testbucket-hf', $objectListInfo->getBucketName());
+ $this->assertEquals('oss-php-sdk-test/', $objectListInfo->getPrefix());
+ $this->assertEquals('xx', $objectListInfo->getMarker());
+ $this->assertEquals(1000, $objectListInfo->getMaxKeys());
+ $this->assertEquals('/', $objectListInfo->getDelimiter());
+ $this->assertEquals('false', $objectListInfo->getIsTruncated());
+ $objects = $objectListInfo->getObjectList();
+ $this->assertEquals('oss-php-sdk-test/upload-test-object-name.txt', $objects[0]->getKey());
+ $this->assertEquals('2015-11-18T03:36:00.000Z', $objects[0]->getLastModified());
+ $this->assertEquals('"89B9E567E7EB8815F2F7D41851F9A2CD"', $objects[0]->getETag());
+ $this->assertEquals('Normal', $objects[0]->getType());
+ $this->assertEquals(13115, $objects[0]->getSize());
+ $this->assertEquals('Standard', $objects[0]->getStorageClass());
+ }
+
+ public function testParseValidXmlWithEncodedKey()
+ {
+ $response = new ResponseCore(array(), $this->validXmlWithEncodedKey, 200);
+ $result = new ListObjectsResult($response);
+ $this->assertTrue($result->isOK());
+ $this->assertNotNull($result->getData());
+ $this->assertNotNull($result->getRawResponse());
+ $objectListInfo = $result->getData();
+ $this->assertEquals(0, count($objectListInfo->getPrefixList()));
+ $this->assertEquals(1, count($objectListInfo->getObjectList()));
+ $this->assertEquals('testbucket-hf', $objectListInfo->getBucketName());
+ $this->assertEquals('php/prefix', $objectListInfo->getPrefix());
+ $this->assertEquals('php/marker', $objectListInfo->getMarker());
+ $this->assertEquals('php/next-marker', $objectListInfo->getNextMarker());
+ $this->assertEquals(1000, $objectListInfo->getMaxKeys());
+ $this->assertEquals('/', $objectListInfo->getDelimiter());
+ $this->assertEquals('true', $objectListInfo->getIsTruncated());
+ $objects = $objectListInfo->getObjectList();
+ $this->assertEquals('php/a+b', $objects[0]->getKey());
+ $this->assertEquals('2015-11-18T03:36:00.000Z', $objects[0]->getLastModified());
+ $this->assertEquals('"89B9E567E7EB8815F2F7D41851F9A2CD"', $objects[0]->getETag());
+ $this->assertEquals('Normal', $objects[0]->getType());
+ $this->assertEquals(13115, $objects[0]->getSize());
+ $this->assertEquals('Standard', $objects[0]->getStorageClass());
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListPartsResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListPartsResultTest.php
new file mode 100644
index 000000000..c446714f6
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ListPartsResultTest.php
@@ -0,0 +1,62 @@
+
+
+ multipart_upload
+ multipart.data
+ 0004B999EF5A239BB9138C6227D69F95
+ 5
+ 1000
+ false
+
+ 1
+ 2012-02-23T07:01:34.000Z
+ "3349DC700140D7F86A078484278075A9"
+ 6291456
+
+
+ 2
+ 2012-02-23T07:01:12.000Z
+ "3349DC700140D7F86A078484278075A9"
+ 6291456
+
+
+ 5
+ 2012-02-23T07:02:03.000Z
+ "7265F4D211B56873A381D321F586E4A9"
+ 1024
+
+
+BBBB;
+
+ public function testParseValidXml()
+ {
+ $response = new ResponseCore(array(), $this->validXml, 200);
+ $result = new ListPartsResult($response);
+ $listPartsInfo = $result->getData();
+ $this->assertEquals("multipart_upload", $listPartsInfo->getBucket());
+ $this->assertEquals("multipart.data", $listPartsInfo->getKey());
+ $this->assertEquals("0004B999EF5A239BB9138C6227D69F95", $listPartsInfo->getUploadId());
+ $this->assertEquals(5, $listPartsInfo->getNextPartNumberMarker());
+ $this->assertEquals(1000, $listPartsInfo->getMaxParts());
+ $this->assertEquals("false", $listPartsInfo->getIsTruncated());
+ $this->assertEquals(3, count($listPartsInfo->getListPart()));
+ $parts = $listPartsInfo->getListPart();
+ $this->assertEquals(1, $parts[0]->getPartNumber());
+ $this->assertEquals('2012-02-23T07:01:34.000Z', $parts[0]->getLastModified());
+ $this->assertEquals('"3349DC700140D7F86A078484278075A9"', $parts[0]->getETag());
+ $this->assertEquals(6291456, $parts[0]->getSize());
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/LiveChannelXmlTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/LiveChannelXmlTest.php
new file mode 100644
index 000000000..cc3e2199b
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/LiveChannelXmlTest.php
@@ -0,0 +1,249 @@
+
+
+ xxx
+ enabled
+
+ hls
+ 1000
+ 5
+ hello.m3u8
+
+
+BBBB;
+
+ private $info = <<
+
+ live-1
+ xxx
+
+ rtmp://bucket.oss-cn-hangzhou.aliyuncs.com/live/213443245345
+
+
+ http://bucket.oss-cn-hangzhou.aliyuncs.com/213443245345/播放列表.m3u8
+
+ enabled
+ 2015-11-24T14:25:31.000Z
+
+BBBB;
+
+ private $list = <<
+
+xxx
+ yyy
+ 100
+ false
+ 121312132
+
+ 12123214323431
+ xxx
+
+ rtmp://bucket.oss-cn-hangzhou.aliyuncs.com/live/1
+
+
+ http://bucket.oss-cn-hangzhou.aliyuncs.com/1/播放列表.m3u8
+
+ enabled
+ 2015-11-24T14:25:31.000Z
+
+
+ 432423432423
+ yyy
+
+ rtmp://bucket.oss-cn-hangzhou.aliyuncs.com/live/2
+
+
+ http://bucket.oss-cn-hangzhou.aliyuncs.com/2/播放列表.m3u8
+
+ enabled
+ 2016-11-24T14:25:31.000Z
+
+
+BBBB;
+
+ private $status = <<
+
+ Live
+ 2016-10-20T14:25:31.000Z
+ 10.1.2.4:47745
+
+ 1280
+ 536
+ 24
+ 72513
+ H264
+
+
+ 6519
+ 44100
+ AAC
+
+
+BBBB;
+
+ private $history = <<
+
+
+ 2013-11-24T14:25:31.000Z
+ 2013-11-24T15:25:31.000Z
+ 10.101.194.148:56861
+
+
+ 2014-11-24T14:25:31.000Z
+ 2014-11-24T15:25:31.000Z
+ 10.101.194.148:56862
+
+
+ 2015-11-24T14:25:31.000Z
+ 2015-11-24T15:25:31.000Z
+ 10.101.194.148:56863
+
+
+BBBB;
+
+ public function testLiveChannelStatus()
+ {
+ $stat = new GetLiveChannelStatus();
+ $stat->parseFromXml($this->status);
+
+ $this->assertEquals('Live', $stat->getStatus());
+ $this->assertEquals('2016-10-20T14:25:31.000Z', $stat->getConnectedTime());
+ $this->assertEquals('10.1.2.4:47745', $stat->getRemoteAddr());
+
+ $this->assertEquals(1280, $stat->getVideoWidth());
+ $this->assertEquals(536, $stat->getVideoHeight());
+ $this->assertEquals(24, $stat->getVideoFrameRate());
+ $this->assertEquals(72513, $stat->getVideoBandwidth());
+ $this->assertEquals('H264', $stat->getVideoCodec());
+ $this->assertEquals(6519, $stat->getAudioBandwidth());
+ $this->assertEquals(44100, $stat->getAudioSampleRate());
+ $this->assertEquals('AAC', $stat->getAudioCodec());
+
+ }
+
+ public function testLiveChannelHistory()
+ {
+ $history = new GetLiveChannelHistory();
+ $history->parseFromXml($this->history);
+
+ $recordList = $history->getLiveRecordList();
+ $this->assertEquals(3, count($recordList));
+
+ $list0 = $recordList[0];
+ $this->assertEquals('2013-11-24T14:25:31.000Z', $list0->getStartTime());
+ $this->assertEquals('2013-11-24T15:25:31.000Z', $list0->getEndTime());
+ $this->assertEquals('10.101.194.148:56861', $list0->getRemoteAddr());
+
+ $list1 = $recordList[1];
+ $this->assertEquals('2014-11-24T14:25:31.000Z', $list1->getStartTime());
+ $this->assertEquals('2014-11-24T15:25:31.000Z', $list1->getEndTime());
+ $this->assertEquals('10.101.194.148:56862', $list1->getRemoteAddr());
+
+ $list2 = $recordList[2];
+ $this->assertEquals('2015-11-24T14:25:31.000Z', $list2->getStartTime());
+ $this->assertEquals('2015-11-24T15:25:31.000Z', $list2->getEndTime());
+ $this->assertEquals('10.101.194.148:56863', $list2->getRemoteAddr());
+
+ }
+
+ public function testLiveChannelConfig()
+ {
+ $config = new LiveChannelConfig(array('name' => 'live-1'));
+ $config->parseFromXml($this->config);
+
+ $this->assertEquals('xxx', $config->getDescription());
+ $this->assertEquals('enabled', $config->getStatus());
+ $this->assertEquals('hls', $config->getType());
+ $this->assertEquals(1000, $config->getFragDuration());
+ $this->assertEquals(5, $config->getFragCount());
+ $this->assertEquals('hello.m3u8', $config->getPlayListName());
+
+ $xml = $config->serializeToXml();
+ $config2 = new LiveChannelConfig(array('name' => 'live-2'));
+ $config2->parseFromXml($xml);
+ $this->assertEquals('xxx', $config2->getDescription());
+ $this->assertEquals('enabled', $config2->getStatus());
+ $this->assertEquals('hls', $config2->getType());
+ $this->assertEquals(1000, $config2->getFragDuration());
+ $this->assertEquals(5, $config2->getFragCount());
+ $this->assertEquals('hello.m3u8', $config2->getPlayListName());
+ }
+
+ public function testLiveChannelInfo()
+ {
+ $info = new LiveChannelInfo(array('name' => 'live-1'));
+ $info->parseFromXml($this->info);
+
+ $this->assertEquals('live-1', $info->getName());
+ $this->assertEquals('xxx', $info->getDescription());
+ $this->assertEquals('enabled', $info->getStatus());
+ $this->assertEquals('2015-11-24T14:25:31.000Z', $info->getLastModified());
+ $pubs = $info->getPublishUrls();
+ $this->assertEquals(1, count($pubs));
+ $this->assertEquals('rtmp://bucket.oss-cn-hangzhou.aliyuncs.com/live/213443245345', $pubs[0]);
+
+ $plays = $info->getPlayUrls();
+ $this->assertEquals(1, count($plays));
+ $this->assertEquals('http://bucket.oss-cn-hangzhou.aliyuncs.com/213443245345/播放列表.m3u8', $plays[0]);
+ }
+
+ public function testLiveChannelList()
+ {
+ $list = new LiveChannelListInfo();
+ $list->parseFromXml($this->list);
+
+ $this->assertEquals('xxx', $list->getPrefix());
+ $this->assertEquals('yyy', $list->getMarker());
+ $this->assertEquals(100, $list->getMaxKeys());
+ $this->assertEquals(false, $list->getIsTruncated());
+ $this->assertEquals('121312132', $list->getNextMarker());
+
+ $channels = $list->getChannelList();
+ $this->assertEquals(2, count($channels));
+
+ $chan1 = $channels[0];
+ $this->assertEquals('12123214323431', $chan1->getName());
+ $this->assertEquals('xxx', $chan1->getDescription());
+ $this->assertEquals('enabled', $chan1->getStatus());
+ $this->assertEquals('2015-11-24T14:25:31.000Z', $chan1->getLastModified());
+ $pubs = $chan1->getPublishUrls();
+ $this->assertEquals(1, count($pubs));
+ $this->assertEquals('rtmp://bucket.oss-cn-hangzhou.aliyuncs.com/live/1', $pubs[0]);
+
+ $plays = $chan1->getPlayUrls();
+ $this->assertEquals(1, count($plays));
+ $this->assertEquals('http://bucket.oss-cn-hangzhou.aliyuncs.com/1/播放列表.m3u8', $plays[0]);
+
+ $chan2 = $channels[1];
+ $this->assertEquals('432423432423', $chan2->getName());
+ $this->assertEquals('yyy', $chan2->getDescription());
+ $this->assertEquals('enabled', $chan2->getStatus());
+ $this->assertEquals('2016-11-24T14:25:31.000Z', $chan2->getLastModified());
+ $pubs = $chan2->getPublishUrls();
+ $this->assertEquals(1, count($pubs));
+ $this->assertEquals('rtmp://bucket.oss-cn-hangzhou.aliyuncs.com/live/2', $pubs[0]);
+
+ $plays = $chan2->getPlayUrls();
+ $this->assertEquals(1, count($plays));
+ $this->assertEquals('http://bucket.oss-cn-hangzhou.aliyuncs.com/2/播放列表.m3u8', $plays[0]);
+ }
+
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/LoggingConfigTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/LoggingConfigTest.php
new file mode 100644
index 000000000..01496bb8f
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/LoggingConfigTest.php
@@ -0,0 +1,47 @@
+
+
+
+TargetBucket
+TargetPrefix
+
+
+BBBB;
+
+ private $nullXml = <<
+
+BBBB;
+
+ public function testParseValidXml()
+ {
+ $loggingConfig = new LoggingConfig();
+ $loggingConfig->parseFromXml($this->validXml);
+ $this->assertEquals($this->cleanXml($this->validXml), $this->cleanXml(strval($loggingConfig)));
+ }
+
+ public function testConstruct()
+ {
+ $loggingConfig = new LoggingConfig('TargetBucket', 'TargetPrefix');
+ $this->assertEquals($this->cleanXml($this->validXml), $this->cleanXml($loggingConfig->serializeToXml()));
+ }
+
+ public function testFailedConstruct()
+ {
+ $loggingConfig = new LoggingConfig('TargetBucket', null);
+ $this->assertEquals($this->cleanXml($this->nullXml), $this->cleanXml($loggingConfig->serializeToXml()));
+ }
+
+ private function cleanXml($xml)
+ {
+ return str_replace("\n", "", str_replace("\r", "", $xml));
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/MimeTypesTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/MimeTypesTest.php
new file mode 100644
index 000000000..0697409e1
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/MimeTypesTest.php
@@ -0,0 +1,13 @@
+assertEquals('application/xml', MimeTypes::getMimetype('file.xml'));
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ObjectAclTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ObjectAclTest.php
new file mode 100644
index 000000000..d39728814
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/ObjectAclTest.php
@@ -0,0 +1,28 @@
+deleteObject($bucket, $object);
+ $client->putObject($bucket, $object, "hello world");
+
+ $acl = $client->getObjectAcl($bucket, $object);
+ $this->assertEquals('default', $acl);
+
+ $client->putObjectAcl($bucket, $object, 'public-read');
+ $acl = $client->getObjectAcl($bucket, $object);
+ $this->assertEquals('public-read', $acl);
+
+ $content = $client->getObject($bucket, $object);
+ $this->assertEquals('hello world', $content);
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketCorsTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketCorsTest.php
new file mode 100644
index 000000000..a32154b55
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketCorsTest.php
@@ -0,0 +1,84 @@
+addAllowedHeader("x-oss-test");
+ $rule->addAllowedHeader("x-oss-test2");
+ $rule->addAllowedHeader("x-oss-test2");
+ $rule->addAllowedHeader("x-oss-test3");
+ $rule->addAllowedOrigin("http://www.b.com");
+ $rule->addAllowedOrigin("http://www.a.com");
+ $rule->addAllowedOrigin("http://www.a.com");
+ $rule->addAllowedMethod("GET");
+ $rule->addAllowedMethod("PUT");
+ $rule->addAllowedMethod("POST");
+ $rule->addExposeHeader("x-oss-test1");
+ $rule->addExposeHeader("x-oss-test1");
+ $rule->addExposeHeader("x-oss-test2");
+ $rule->setMaxAgeSeconds(10);
+ $corsConfig->addRule($rule);
+ $rule = new CorsRule();
+ $rule->addAllowedHeader("x-oss-test");
+ $rule->addAllowedMethod("GET");
+ $rule->addAllowedOrigin("http://www.b.com");
+ $rule->addExposeHeader("x-oss-test1");
+ $rule->setMaxAgeSeconds(110);
+ $corsConfig->addRule($rule);
+
+ try {
+ $this->ossClient->putBucketCors($this->bucket, $corsConfig);
+ } catch (OssException $e) {
+ $this->assertFalse(True);
+ }
+
+ try {
+ Common::waitMetaSync();
+ $object = "cors/test.txt";
+ $this->ossClient->putObject($this->bucket, $object, file_get_contents(__FILE__));
+ $headers = $this->ossClient->optionsObject($this->bucket, $object, "http://www.a.com", "GET", "", null);
+ $this->assertNotEmpty($headers);
+ } catch (OssException $e) {
+ var_dump($e->getMessage());
+ }
+
+ try {
+ Common::waitMetaSync();
+ $corsConfig2 = $this->ossClient->getBucketCors($this->bucket);
+ $this->assertNotNull($corsConfig2);
+ $this->assertEquals($corsConfig->serializeToXml(), $corsConfig2->serializeToXml());
+ } catch (OssException $e) {
+ $this->assertFalse(True);
+ }
+
+ try {
+ Common::waitMetaSync();
+ $this->ossClient->deleteBucketCors($this->bucket);
+ } catch (OssException $e) {
+ $this->assertFalse(True);
+ }
+
+ try {
+ Common::waitMetaSync();
+ $corsConfig3 = $this->ossClient->getBucketCors($this->bucket);
+ $this->assertNotNull($corsConfig3);
+ $this->assertNotEquals($corsConfig->serializeToXml(), $corsConfig3->serializeToXml());
+ } catch (OssException $e) {
+ $this->assertFalse(True);
+ }
+
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketLifecycleTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketLifecycleTest.php
new file mode 100644
index 000000000..46da1f063
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketLifecycleTest.php
@@ -0,0 +1,57 @@
+addRule($lifecycleRule);
+ $actions = array();
+ $actions[] = new LifecycleAction("Expiration", "Date", '2022-10-12T00:00:00.000Z');
+ $lifecycleRule = new LifecycleRule("delete temporary files", "temporary/", "Enabled", $actions);
+ $lifecycleConfig->addRule($lifecycleRule);
+
+ try {
+ $this->ossClient->putBucketLifecycle($this->bucket, $lifecycleConfig);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+
+ try {
+ Common::waitMetaSync();
+ $lifecycleConfig2 = $this->ossClient->getBucketLifecycle($this->bucket);
+ $this->assertEquals($lifecycleConfig->serializeToXml(), $lifecycleConfig2->serializeToXml());
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+
+ try {
+ Common::waitMetaSync();
+ $this->ossClient->deleteBucketLifecycle($this->bucket);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+
+ try {
+ Common::waitMetaSync();
+ $lifecycleConfig3 = $this->ossClient->getBucketLifecycle($this->bucket);
+ $this->assertNotEquals($lifecycleConfig->serializeToXml(), $lifecycleConfig3->serializeToXml());
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketLoggingTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketLoggingTest.php
new file mode 100644
index 000000000..16a10ebfa
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketLoggingTest.php
@@ -0,0 +1,43 @@
+bucket, 'prefix');
+ try {
+ $this->ossClient->putBucketLogging($this->bucket, $this->bucket, 'prefix');
+ } catch (OssException $e) {
+ var_dump($e->getMessage());
+ $this->assertTrue(false);
+ }
+ try {
+ Common::waitMetaSync();
+ $loggingConfig2 = $this->ossClient->getBucketLogging($this->bucket);
+ $this->assertEquals($loggingConfig->serializeToXml(), $loggingConfig2->serializeToXml());
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ try {
+ Common::waitMetaSync();
+ $this->ossClient->deleteBucketLogging($this->bucket);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ try {
+ Common::waitMetaSync();
+ $loggingConfig3 = $this->ossClient->getBucketLogging($this->bucket);
+ $this->assertNotEquals($loggingConfig->serializeToXml(), $loggingConfig3->serializeToXml());
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketRefererTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketRefererTest.php
new file mode 100644
index 000000000..ba7d14f5b
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketRefererTest.php
@@ -0,0 +1,48 @@
+addReferer('http://www.aliyun.com');
+
+ try {
+ $this->ossClient->putBucketReferer($this->bucket, $refererConfig);
+ } catch (OssException $e) {
+ var_dump($e->getMessage());
+ $this->assertTrue(false);
+ }
+ try {
+ Common::waitMetaSync();
+ $refererConfig2 = $this->ossClient->getBucketReferer($this->bucket);
+ $this->assertEquals($refererConfig->serializeToXml(), $refererConfig2->serializeToXml());
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ try {
+ Common::waitMetaSync();
+ $nullRefererConfig = new RefererConfig();
+ $nullRefererConfig->setAllowEmptyReferer(false);
+ $this->ossClient->putBucketReferer($this->bucket, $nullRefererConfig);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ try {
+ Common::waitMetaSync();
+ $refererConfig3 = $this->ossClient->getBucketLogging($this->bucket);
+ $this->assertNotEquals($refererConfig->serializeToXml(), $refererConfig3->serializeToXml());
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketTest.php
new file mode 100644
index 000000000..b5e0862cf
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketTest.php
@@ -0,0 +1,49 @@
+ossClient->createBucket("s");
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals('"s"bucket name is invalid', $e->getMessage());
+ }
+ }
+
+ public function testBucketWithInvalidACL()
+ {
+ try {
+ $this->ossClient->createBucket($this->bucket, "invalid");
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals('invalid:acl is invalid(private,public-read,public-read-write)', $e->getMessage());
+ }
+ }
+
+ public function testBucket()
+ {
+ $this->ossClient->createBucket($this->bucket, OssClient::OSS_ACL_TYPE_PUBLIC_READ_WRITE);
+
+ $bucketListInfo = $this->ossClient->listBuckets();
+ $this->assertNotNull($bucketListInfo);
+ $bucketList = $bucketListInfo->getBucketList();
+ $this->assertTrue(is_array($bucketList));
+ $this->assertGreaterThan(0, count($bucketList));
+ $this->ossClient->putBucketAcl($this->bucket, OssClient::OSS_ACL_TYPE_PUBLIC_READ_WRITE);
+ Common::waitMetaSync();
+ $this->assertEquals($this->ossClient->getBucketAcl($this->bucket), OssClient::OSS_ACL_TYPE_PUBLIC_READ_WRITE);
+
+ $this->assertTrue($this->ossClient->doesBucketExist($this->bucket));
+ $this->assertFalse($this->ossClient->doesBucketExist($this->bucket . '-notexist'));
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketWebsiteTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketWebsiteTest.php
new file mode 100644
index 000000000..dfa9cc174
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientBucketWebsiteTest.php
@@ -0,0 +1,46 @@
+ossClient->putBucketWebsite($this->bucket, $websiteConfig);
+ } catch (OssException $e) {
+ var_dump($e->getMessage());
+ $this->assertTrue(false);
+ }
+
+ try {
+ Common::waitMetaSync();
+ $websiteConfig2 = $this->ossClient->getBucketWebsite($this->bucket);
+ $this->assertEquals($websiteConfig->serializeToXml(), $websiteConfig2->serializeToXml());
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ try {
+ Common::waitMetaSync();
+ $this->ossClient->deleteBucketWebsite($this->bucket);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ try {
+ Common::waitMetaSync();
+ $websiteConfig3 = $this->ossClient->getBucketLogging($this->bucket);
+ $this->assertNotEquals($websiteConfig->serializeToXml(), $websiteConfig3->serializeToXml());
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientImageTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientImageTest.php
new file mode 100644
index 000000000..575292bac
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientImageTest.php
@@ -0,0 +1,100 @@
+client = Common::getOssClient();
+ $this->bucketName = 'php-sdk-test-bucket-image-' . strval(rand(0, 10000));
+ $this->client->createBucket($this->bucketName);
+ Common::waitMetaSync();
+ $this->local_file = "example.jpg";
+ $this->object = "oss-example.jpg";
+ $this->download_file = "image.jpg";
+
+ $this->client->uploadFile($this->bucketName, $this->object, $this->local_file);
+ }
+
+ public function tearDown()
+ {
+ $this->client->deleteObject($this->bucketName, $this->object);
+ $this->client->deleteBucket($this->bucketName);
+ }
+
+ public function testImageResize()
+ {
+ $options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $this->download_file,
+ OssClient::OSS_PROCESS => "image/resize,m_fixed,h_100,w_100", );
+ $this->check($options, 100, 100, 3587, 'jpg');
+ }
+
+ public function testImageCrop()
+ {
+ $options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $this->download_file,
+ OssClient::OSS_PROCESS => "image/crop,w_100,h_100,x_100,y_100,r_1", );
+ $this->check($options, 100, 100, 2281, 'jpg');
+ }
+
+ public function testImageRotate()
+ {
+ $options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $this->download_file,
+ OssClient::OSS_PROCESS => "image/rotate,90", );
+ $this->check($options, 267, 400, 21509, 'jpg');
+ }
+
+ public function testImageSharpen()
+ {
+ $options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $this->download_file,
+ OssClient::OSS_PROCESS => "image/sharpen,100", );
+ $this->check($options, 400, 267, 24183, 'jpg');
+ }
+
+ public function testImageWatermark()
+ {
+ $options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $this->download_file,
+ OssClient::OSS_PROCESS => "image/watermark,text_SGVsbG8g5Zu-54mH5pyN5YqhIQ", );
+ $this->check($options, 400, 267, 26953, 'jpg');
+ }
+
+ public function testImageFormat()
+ {
+ $options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $this->download_file,
+ OssClient::OSS_PROCESS => "image/format,png", );
+ $this->check($options, 400, 267, 160733, 'png');
+ }
+
+ public function testImageTofile()
+ {
+ $options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $this->download_file,
+ OssClient::OSS_PROCESS => "image/resize,m_fixed,w_100,h_100", );
+ $this->check($options, 100, 100, 3587, 'jpg');
+ }
+
+ private function check($options, $width, $height, $size, $type)
+ {
+ $this->client->getObject($this->bucketName, $this->object, $options);
+ $array = getimagesize($this->download_file);
+ $this->assertEquals($width, $array[0]);
+ $this->assertEquals($height, $array[1]);
+ $this->assertEquals($type === 'jpg' ? 2 : 3, $array[2]);//2 <=> jpg
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientMultipartUploadTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientMultipartUploadTest.php
new file mode 100644
index 000000000..a95f412d3
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientMultipartUploadTest.php
@@ -0,0 +1,313 @@
+ossClient->uploadDir($this->bucket, "", "abc/ds/s/s/notexitst");
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals("parameter error: abc/ds/s/s/notexitst is not a directory, please check it", $e->getMessage());
+ }
+
+ }
+
+ public function testMultipartUploadBigFile()
+ {
+ $bigFileName = __DIR__ . DIRECTORY_SEPARATOR . "/bigfile.tmp";
+ $localFilename = __DIR__ . DIRECTORY_SEPARATOR . "/localfile.tmp";
+ OssUtil::generateFile($bigFileName, 6 * 1024 * 1024);
+ $object = 'mpu/multipart-bigfile-test.tmp';
+ try {
+ $this->ossClient->multiuploadFile($this->bucket, $object, $bigFileName, array(OssClient::OSS_PART_SIZE => 1));
+ $options = array(OssClient::OSS_FILE_DOWNLOAD => $localFilename);
+ $this->ossClient->getObject($this->bucket, $object, $options);
+ $this->assertEquals(md5_file($bigFileName), md5_file($localFilename));
+ } catch (OssException $e) {
+ var_dump($e->getMessage());
+ $this->assertFalse(true);
+ }
+ unlink($bigFileName);
+ unlink($localFilename);
+ }
+
+ public function testMultipartUploadBigFileWithMD5Check()
+ {
+ $bigFileName = __DIR__ . DIRECTORY_SEPARATOR . "/bigfile.tmp";
+ $localFilename = __DIR__ . DIRECTORY_SEPARATOR . "/localfile.tmp";
+ OssUtil::generateFile($bigFileName, 6 * 1024 * 1024);
+ $object = 'mpu/multipart-bigfile-test.tmp';
+ $options = array(
+ OssClient::OSS_CHECK_MD5 => true,
+ OssClient::OSS_PART_SIZE => 1,
+ );
+ try {
+ $this->ossClient->multiuploadFile($this->bucket, $object, $bigFileName, $options);
+ $options = array(OssClient::OSS_FILE_DOWNLOAD => $localFilename);
+ $this->ossClient->getObject($this->bucket, $object, $options);
+ $this->assertEquals(md5_file($bigFileName), md5_file($localFilename));
+ } catch (OssException $e) {
+ var_dump($e->getMessage());
+ $this->assertFalse(true);
+ }
+ unlink($bigFileName);
+ unlink($localFilename);
+ }
+
+ public function testCopyPart()
+ {
+ $object = "mpu/multipart-test.txt";
+ $copiedObject = "mpu/multipart-test.txt.copied";
+ $this->ossClient->putObject($this->bucket, $copiedObject, file_get_contents(__FILE__));
+ /**
+ * step 1. 初始化一个分块上传事件, 也就是初始化上传Multipart, 获取upload id
+ */
+ try {
+ $upload_id = $this->ossClient->initiateMultipartUpload($this->bucket, $object);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ /*
+ * step 2. uploadPartCopy
+ */
+ $copyId = 1;
+ $eTag = $this->ossClient->uploadPartCopy($this->bucket, $copiedObject, $this->bucket, $object, $copyId, $upload_id);
+ $upload_parts[] = array(
+ 'PartNumber' => $copyId,
+ 'ETag' => $eTag,
+ );
+
+ try {
+ $listPartsInfo = $this->ossClient->listParts($this->bucket, $object, $upload_id);
+ $this->assertNotNull($listPartsInfo);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+
+ /**
+ * step 3.
+ */
+ try {
+ $this->ossClient->completeMultipartUpload($this->bucket, $object, $upload_id, $upload_parts);
+ } catch (OssException $e) {
+ var_dump($e->getMessage());
+ $this->assertTrue(false);
+ }
+
+ $this->assertEquals($this->ossClient->getObject($this->bucket, $object), file_get_contents(__FILE__));
+ $this->assertEquals($this->ossClient->getObject($this->bucket, $copiedObject), file_get_contents(__FILE__));
+ }
+
+ public function testAbortMultipartUpload()
+ {
+ $object = "mpu/multipart-test.txt";
+ /**
+ * step 1. 初始化一个分块上传事件, 也就是初始化上传Multipart, 获取upload id
+ */
+ try {
+ $upload_id = $this->ossClient->initiateMultipartUpload($this->bucket, $object);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ /*
+ * step 2. 上传分片
+ */
+ $part_size = 10 * 1024 * 1024;
+ $upload_file = __FILE__;
+ $upload_filesize = filesize($upload_file);
+ $pieces = $this->ossClient->generateMultiuploadParts($upload_filesize, $part_size);
+ $response_upload_part = array();
+ $upload_position = 0;
+ $is_check_md5 = true;
+ foreach ($pieces as $i => $piece) {
+ $from_pos = $upload_position + (integer)$piece[OssClient::OSS_SEEK_TO];
+ $to_pos = (integer)$piece[OssClient::OSS_LENGTH] + $from_pos - 1;
+ $up_options = array(
+ OssClient::OSS_FILE_UPLOAD => $upload_file,
+ OssClient::OSS_PART_NUM => ($i + 1),
+ OssClient::OSS_SEEK_TO => $from_pos,
+ OssClient::OSS_LENGTH => $to_pos - $from_pos + 1,
+ OssClient::OSS_CHECK_MD5 => $is_check_md5,
+ );
+ if ($is_check_md5) {
+ $content_md5 = OssUtil::getMd5SumForFile($upload_file, $from_pos, $to_pos);
+ $up_options[OssClient::OSS_CONTENT_MD5] = $content_md5;
+ }
+ //2. 将每一分片上传到OSS
+ try {
+ $response_upload_part[] = $this->ossClient->uploadPart($this->bucket, $object, $upload_id, $up_options);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ }
+ $upload_parts = array();
+ foreach ($response_upload_part as $i => $eTag) {
+ $upload_parts[] = array(
+ 'PartNumber' => ($i + 1),
+ 'ETag' => $eTag,
+ );
+ }
+
+ try {
+ $listPartsInfo = $this->ossClient->listParts($this->bucket, $object, $upload_id);
+ $this->assertNotNull($listPartsInfo);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ $this->assertEquals(1, count($listPartsInfo->getListPart()));
+
+ $numOfMultipartUpload1 = 0;
+ $options = null;
+ try {
+ $listMultipartUploadInfo = $listMultipartUploadInfo = $this->ossClient->listMultipartUploads($this->bucket, $options);
+ $this->assertNotNull($listMultipartUploadInfo);
+ $numOfMultipartUpload1 = count($listMultipartUploadInfo->getUploads());
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ try {
+ $this->ossClient->abortMultipartUpload($this->bucket, $object, $upload_id);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+
+ $numOfMultipartUpload2 = 0;
+ try {
+ $listMultipartUploadInfo = $listMultipartUploadInfo = $this->ossClient->listMultipartUploads($this->bucket, $options);
+ $this->assertNotNull($listMultipartUploadInfo);
+ $numOfMultipartUpload2 = count($listMultipartUploadInfo->getUploads());
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ $this->assertEquals($numOfMultipartUpload1 - 1, $numOfMultipartUpload2);
+ }
+
+ public function testPutObjectByRawApis()
+ {
+ $object = "mpu/multipart-test.txt";
+ /**
+ * step 1. 初始化一个分块上传事件, 也就是初始化上传Multipart, 获取upload id
+ */
+ try {
+ $upload_id = $this->ossClient->initiateMultipartUpload($this->bucket, $object);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ /*
+ * step 2. 上传分片
+ */
+ $part_size = 10 * 1024 * 1024;
+ $upload_file = __FILE__;
+ $upload_filesize = filesize($upload_file);
+ $pieces = $this->ossClient->generateMultiuploadParts($upload_filesize, $part_size);
+ $response_upload_part = array();
+ $upload_position = 0;
+ $is_check_md5 = true;
+ foreach ($pieces as $i => $piece) {
+ $from_pos = $upload_position + (integer)$piece[OssClient::OSS_SEEK_TO];
+ $to_pos = (integer)$piece[OssClient::OSS_LENGTH] + $from_pos - 1;
+ $up_options = array(
+ OssClient::OSS_FILE_UPLOAD => $upload_file,
+ OssClient::OSS_PART_NUM => ($i + 1),
+ OssClient::OSS_SEEK_TO => $from_pos,
+ OssClient::OSS_LENGTH => $to_pos - $from_pos + 1,
+ OssClient::OSS_CHECK_MD5 => $is_check_md5,
+ );
+ if ($is_check_md5) {
+ $content_md5 = OssUtil::getMd5SumForFile($upload_file, $from_pos, $to_pos);
+ $up_options[OssClient::OSS_CONTENT_MD5] = $content_md5;
+ }
+ //2. 将每一分片上传到OSS
+ try {
+ $response_upload_part[] = $this->ossClient->uploadPart($this->bucket, $object, $upload_id, $up_options);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ }
+ $upload_parts = array();
+ foreach ($response_upload_part as $i => $eTag) {
+ $upload_parts[] = array(
+ 'PartNumber' => ($i + 1),
+ 'ETag' => $eTag,
+ );
+ }
+
+ try {
+ $listPartsInfo = $this->ossClient->listParts($this->bucket, $object, $upload_id);
+ $this->assertNotNull($listPartsInfo);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+
+ /**
+ * step 3.
+ */
+ try {
+ $this->ossClient->completeMultipartUpload($this->bucket, $object, $upload_id, $upload_parts);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ }
+
+ function testPutObjectsByDir()
+ {
+ $localDirectory = dirname(__FILE__);
+ $prefix = "samples/codes";
+ try {
+ $this->ossClient->uploadDir($this->bucket, $prefix, $localDirectory);
+ } catch (OssException $e) {
+ var_dump($e->getMessage());
+ $this->assertFalse(true);
+
+ }
+ $this->assertTrue($this->ossClient->doesObjectExist($this->bucket, 'samples/codes/' . "OssClientMultipartUploadTest.php"));
+ }
+
+ public function testPutObjectByMultipartUpload()
+ {
+ $object = "mpu/multipart-test.txt";
+ $file = __FILE__;
+ $options = array();
+
+ try {
+ $this->ossClient->multiuploadFile($this->bucket, $object, $file, $options);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ }
+
+ public function testPutObjectByMultipartUploadWithMD5Check()
+ {
+ $object = "mpu/multipart-test.txt";
+ $file = __FILE__;
+ $options = array(OssClient::OSS_CHECK_MD5 => true);
+
+ try {
+ $this->ossClient->multiuploadFile($this->bucket, $object, $file, $options);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ }
+
+ public function testListMultipartUploads()
+ {
+ $options = null;
+ try {
+ $listMultipartUploadInfo = $this->ossClient->listMultipartUploads($this->bucket, $options);
+ $this->assertNotNull($listMultipartUploadInfo);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientObjectTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientObjectTest.php
new file mode 100644
index 000000000..34e3ded7d
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientObjectTest.php
@@ -0,0 +1,588 @@
+ossClient->getObjectMeta($this->bucket, $object);
+ $this->assertEquals('200', $res['info']['http_code']);
+ $this->assertEquals('text/plain', $res['content-type']);
+ $this->assertEquals('Accept-Encoding', $res['vary']);
+ $this->assertTrue(isset($res['content-length']));
+ $this->assertFalse(isset($res['content-encoding']));
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+
+ $options = array(OssClient::OSS_HEADERS => array(OssClient::OSS_ACCEPT_ENCODING => 'deflate, gzip'));
+
+ try {
+ $res = $this->ossClient->getObjectMeta($this->bucket, $object, $options);
+ $this->assertEquals('200', $res['info']['http_code']);
+ $this->assertEquals('text/plain', $res['content-type']);
+ $this->assertEquals('Accept-Encoding', $res['vary']);
+ $this->assertFalse(isset($res['content-length']));
+ $this->assertEquals('gzip', $res['content-encoding']);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ }
+
+ public function testGetObjectWithAcceptEncoding()
+ {
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+ $options = array(OssClient::OSS_HEADERS => array(OssClient::OSS_ACCEPT_ENCODING => 'deflate, gzip'));
+
+ try {
+ $res = $this->ossClient->getObject($this->bucket, $object, $options);
+ $this->assertEquals(file_get_contents(__FILE__), $res);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ }
+
+ public function testGetObjectWithHeader()
+ {
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+ try {
+ $res = $this->ossClient->getObject($this->bucket, $object, array(OssClient::OSS_LAST_MODIFIED => "xx"));
+ $this->assertEquals(file_get_contents(__FILE__), $res);
+ } catch (OssException $e) {
+ $this->assertEquals('"/ilegal.txt" object name is invalid', $e->getMessage());
+ }
+ }
+
+ public function testGetObjectWithIleggalEtag()
+ {
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+ try {
+ $res = $this->ossClient->getObject($this->bucket, $object, array(OssClient::OSS_ETAG => "xx"));
+ $this->assertEquals(file_get_contents(__FILE__), $res);
+ } catch (OssException $e) {
+ $this->assertEquals('"/ilegal.txt" object name is invalid', $e->getMessage());
+ }
+ }
+
+ public function testObject()
+ {
+ /**
+ * 上传本地变量到bucket
+ */
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+ $content = file_get_contents(__FILE__);
+ $options = array(
+ OssClient::OSS_LENGTH => strlen($content),
+ OssClient::OSS_HEADERS => array(
+ 'Expires' => 'Fri, 28 Feb 2020 05:38:42 GMT',
+ 'Cache-Control' => 'no-cache',
+ 'Content-Disposition' => 'attachment;filename=oss_download.log',
+ 'Content-Encoding' => 'utf-8',
+ 'Content-Language' => 'zh-CN',
+ 'x-oss-server-side-encryption' => 'AES256',
+ 'x-oss-meta-self-define-title' => 'user define meta info',
+ ),
+ );
+
+ try {
+ $this->ossClient->putObject($this->bucket, $object, $content, $options);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ try {
+ $this->ossClient->putObject($this->bucket, $object, $content, $options);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ try {
+ $result = $this->ossClient->deleteObjects($this->bucket, "stringtype", $options);
+ $this->assertEquals('stringtype', $result[0]);
+ } catch (OssException $e) {
+ $this->assertEquals('objects must be array', $e->getMessage());
+ }
+
+ try {
+ $result = $this->ossClient->deleteObjects($this->bucket, "stringtype", $options);
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals('objects must be array', $e->getMessage());
+ }
+
+ try {
+ $this->ossClient->uploadFile($this->bucket, $object, "notexist.txt", $options);
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals('notexist.txt file does not exist', $e->getMessage());
+ }
+
+ /**
+ * getObject到本地变量,检查是否match
+ */
+ try {
+ $content = $this->ossClient->getObject($this->bucket, $object);
+ $this->assertEquals($content, file_get_contents(__FILE__));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * getObject的前五个字节
+ */
+ try {
+ $options = array(OssClient::OSS_RANGE => '0-4');
+ $content = $this->ossClient->getObject($this->bucket, $object, $options);
+ $this->assertEquals($content, 'assertFalse(true);
+ }
+
+
+ /**
+ * 上传本地文件到object
+ */
+ try {
+ $this->ossClient->uploadFile($this->bucket, $object, __FILE__);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 下载文件到本地变量,检查是否match
+ */
+ try {
+ $content = $this->ossClient->getObject($this->bucket, $object);
+ $this->assertEquals($content, file_get_contents(__FILE__));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 下载文件到本地文件
+ */
+ $localfile = "upload-test-object-name.txt";
+ $options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $localfile,
+ );
+
+ try {
+ $this->ossClient->getObject($this->bucket, $object, $options);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ $this->assertTrue(file_get_contents($localfile) === file_get_contents(__FILE__));
+ if (file_exists($localfile)) {
+ unlink($localfile);
+ }
+
+ /**
+ * 下载文件到本地文件 no such key
+ */
+ $localfile = "upload-test-object-name-no-such-key.txt";
+ $options = array(
+ OssClient::OSS_FILE_DOWNLOAD => $localfile,
+ );
+
+ try {
+ $this->ossClient->getObject($this->bucket, $object . "no-such-key", $options);
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+ $this->assertTrue(true);
+ $this->assertFalse(file_exists($localfile));
+ if (strpos($e, "The specified key does not exist") == false)
+ {
+ $this->assertTrue(true);
+ }
+ }
+
+ /**
+ * 下载文件到内容 no such key
+ */
+ try {
+ $result = $this->ossClient->getObject($this->bucket, $object . "no-such-key");
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+ $this->assertTrue(true);
+ if (strpos($e, "The specified key does not exist") == false)
+ {
+ $this->assertTrue(true);
+ }
+ }
+
+ /**
+ * 复制object
+ */
+ $to_bucket = $this->bucket;
+ $to_object = $object . '.copy';
+ $options = array();
+ try {
+ $result = $this->ossClient->copyObject($this->bucket, $object, $to_bucket, $to_object, $options);
+ $this->assertFalse(empty($result));
+ $this->assertEquals(strlen("2016-11-21T03:46:58.000Z"), strlen($result[0]));
+ $this->assertEquals(strlen("\"5B3C1A2E053D763E1B002CC607C5A0FE\""), strlen($result[1]));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ var_dump($e->getMessage());
+
+ }
+
+ /**
+ * 检查复制的是否相同
+ */
+ try {
+ $content = $this->ossClient->getObject($this->bucket, $to_object);
+ $this->assertEquals($content, file_get_contents(__FILE__));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 列出bucket内的文件列表
+ */
+ $prefix = '';
+ $delimiter = '/';
+ $next_marker = '';
+ $maxkeys = 1000;
+ $options = array(
+ 'delimiter' => $delimiter,
+ 'prefix' => $prefix,
+ 'max-keys' => $maxkeys,
+ 'marker' => $next_marker,
+ );
+
+ try {
+ $listObjectInfo = $this->ossClient->listObjects($this->bucket, $options);
+ $objectList = $listObjectInfo->getObjectList();
+ $prefixList = $listObjectInfo->getPrefixList();
+ $this->assertNotNull($objectList);
+ $this->assertNotNull($prefixList);
+ $this->assertTrue(is_array($objectList));
+ $this->assertTrue(is_array($prefixList));
+
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+
+ /**
+ * 设置文件的meta信息
+ */
+ $from_bucket = $this->bucket;
+ $from_object = "oss-php-sdk-test/upload-test-object-name.txt";
+ $to_bucket = $from_bucket;
+ $to_object = $from_object;
+ $copy_options = array(
+ OssClient::OSS_HEADERS => array(
+ 'Expires' => '2012-10-01 08:00:00',
+ 'Content-Disposition' => 'attachment; filename="xxxxxx"',
+ ),
+ );
+ try {
+ $this->ossClient->copyObject($from_bucket, $from_object, $to_bucket, $to_object, $copy_options);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 获取文件的meta信息
+ */
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+ try {
+ $objectMeta = $this->ossClient->getObjectMeta($this->bucket, $object);
+ $this->assertEquals('attachment; filename="xxxxxx"', $objectMeta[strtolower('Content-Disposition')]);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 删除单个文件
+ */
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+
+ try {
+ $this->assertTrue($this->ossClient->doesObjectExist($this->bucket, $object));
+ $this->ossClient->deleteObject($this->bucket, $object);
+ $this->assertFalse($this->ossClient->doesObjectExist($this->bucket, $object));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 删除多个个文件
+ */
+ $object1 = "oss-php-sdk-test/upload-test-object-name.txt";
+ $object2 = "oss-php-sdk-test/upload-test-object-name.txt.copy";
+ $list = array($object1, $object2);
+ try {
+ $this->assertTrue($this->ossClient->doesObjectExist($this->bucket, $object2));
+
+ $result = $this->ossClient->deleteObjects($this->bucket, $list);
+ $this->assertEquals($list[1], $result[0]);
+ $this->assertEquals($list[0], $result[1]);
+
+ $result = $this->ossClient->deleteObjects($this->bucket, $list, array('quiet' => 'true'));
+ $this->assertEquals(array(), $result);
+ $this->assertFalse($this->ossClient->doesObjectExist($this->bucket, $object2));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ }
+
+ public function testAppendObject()
+ {
+ $object = "oss-php-sdk-test/append-test-object-name.txt";
+ $content_array = array('Hello OSS', 'Hi OSS', 'OSS OK');
+
+ /**
+ * 追加上传字符串
+ */
+ try {
+ $position = $this->ossClient->appendObject($this->bucket, $object, $content_array[0], 0);
+ $this->assertEquals($position, strlen($content_array[0]));
+ $position = $this->ossClient->appendObject($this->bucket, $object, $content_array[1], $position);
+ $this->assertEquals($position, strlen($content_array[0]) + strlen($content_array[1]));
+ $position = $this->ossClient->appendObject($this->bucket, $object, $content_array[2], $position);
+ $this->assertEquals($position, strlen($content_array[0]) + strlen($content_array[1]) + strlen($content_array[1]));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 检查内容的是否相同
+ */
+ try {
+ $content = $this->ossClient->getObject($this->bucket, $object);
+ $this->assertEquals($content, implode($content_array));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+
+ /**
+ * 删除测试object
+ */
+ try {
+ $this->ossClient->deleteObject($this->bucket, $object);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 追加上传本地文件
+ */
+ try {
+ $position = $this->ossClient->appendFile($this->bucket, $object, __FILE__, 0);
+ $this->assertEquals($position, filesize(__FILE__));
+ $position = $this->ossClient->appendFile($this->bucket, $object, __FILE__, $position);
+ $this->assertEquals($position, filesize(__FILE__) * 2);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 检查复制的是否相同
+ */
+ try {
+ $content = $this->ossClient->getObject($this->bucket, $object);
+ $this->assertEquals($content, file_get_contents(__FILE__) . file_get_contents(__FILE__));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 删除测试object
+ */
+ try {
+ $this->ossClient->deleteObject($this->bucket, $object);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+
+ $options = array(
+ OssClient::OSS_HEADERS => array(
+ 'Expires' => '2012-10-01 08:00:00',
+ 'Content-Disposition' => 'attachment; filename="xxxxxx"',
+ ),
+ );
+
+ /**
+ * 带option的追加上传
+ */
+ try {
+ $position = $this->ossClient->appendObject($this->bucket, $object, "Hello OSS, ", 0, $options);
+ $position = $this->ossClient->appendObject($this->bucket, $object, "Hi OSS.", $position);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 获取文件的meta信息
+ */
+ try {
+ $objectMeta = $this->ossClient->getObjectMeta($this->bucket, $object);
+ $this->assertEquals('attachment; filename="xxxxxx"', $objectMeta[strtolower('Content-Disposition')]);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 删除测试object
+ */
+ try {
+ $this->ossClient->deleteObject($this->bucket, $object);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ }
+
+ public function testPutIllelObject()
+ {
+ $object = "/ilegal.txt";
+ try {
+ $this->ossClient->putObject($this->bucket, $object, "hi", null);
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals('"/ilegal.txt" object name is invalid', $e->getMessage());
+ }
+ }
+
+ public function testCheckMD5()
+ {
+ $object = "oss-php-sdk-test/upload-test-object-name.txt";
+ $content = file_get_contents(__FILE__);
+ $options = array(OssClient::OSS_CHECK_MD5 => true);
+
+ /**
+ * 上传数据开启MD5
+ */
+ try {
+ $this->ossClient->putObject($this->bucket, $object, $content, $options);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 检查复制的是否相同
+ */
+ try {
+ $content = $this->ossClient->getObject($this->bucket, $object);
+ $this->assertEquals($content, file_get_contents(__FILE__));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 上传文件开启MD5
+ */
+ try {
+ $this->ossClient->uploadFile($this->bucket, $object, __FILE__, $options);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 检查复制的是否相同
+ */
+ try {
+ $content = $this->ossClient->getObject($this->bucket, $object);
+ $this->assertEquals($content, file_get_contents(__FILE__));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 删除测试object
+ */
+ try {
+ $this->ossClient->deleteObject($this->bucket, $object);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ $object = "oss-php-sdk-test/append-test-object-name.txt";
+ $content_array = array('Hello OSS', 'Hi OSS', 'OSS OK');
+ $options = array(OssClient::OSS_CHECK_MD5 => true);
+
+ /**
+ * 追加上传字符串
+ */
+ try {
+ $position = $this->ossClient->appendObject($this->bucket, $object, $content_array[0], 0, $options);
+ $this->assertEquals($position, strlen($content_array[0]));
+ $position = $this->ossClient->appendObject($this->bucket, $object, $content_array[1], $position, $options);
+ $this->assertEquals($position, strlen($content_array[0]) + strlen($content_array[1]));
+ $position = $this->ossClient->appendObject($this->bucket, $object, $content_array[2], $position, $options);
+ $this->assertEquals($position, strlen($content_array[0]) + strlen($content_array[1]) + strlen($content_array[1]));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 检查内容的是否相同
+ */
+ try {
+ $content = $this->ossClient->getObject($this->bucket, $object);
+ $this->assertEquals($content, implode($content_array));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 删除测试object
+ */
+ try {
+ $this->ossClient->deleteObject($this->bucket, $object);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 追加上传本地文件
+ */
+ try {
+ $position = $this->ossClient->appendFile($this->bucket, $object, __FILE__, 0, $options);
+ $this->assertEquals($position, filesize(__FILE__));
+ $position = $this->ossClient->appendFile($this->bucket, $object, __FILE__, $position, $options);
+ $this->assertEquals($position, filesize(__FILE__) * 2);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 检查复制的是否相同
+ */
+ try {
+ $content = $this->ossClient->getObject($this->bucket, $object);
+ $this->assertEquals($content, file_get_contents(__FILE__) . file_get_contents(__FILE__));
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ /**
+ * 删除测试object
+ */
+ try {
+ $this->ossClient->deleteObject($this->bucket, $object);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ }
+
+ public function setUp()
+ {
+ parent::setUp();
+ $this->ossClient->putObject($this->bucket, 'oss-php-sdk-test/upload-test-object-name.txt', file_get_contents(__FILE__));
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientSignatureTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientSignatureTest.php
new file mode 100644
index 000000000..109121d0f
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientSignatureTest.php
@@ -0,0 +1,111 @@
+ossClient->putObject($this->bucket, $object, file_get_contents(__FILE__));
+ $timeout = 3600;
+ try {
+ $signedUrl = $this->ossClient->signUrl($this->bucket, $object, $timeout);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ $request = new RequestCore($signedUrl);
+ $request->set_method('GET');
+ $request->add_header('Content-Type', '');
+ $request->send_request();
+ $res = new ResponseCore($request->get_response_header(), $request->get_response_body(), $request->get_response_code());
+ $this->assertEquals(file_get_contents(__FILE__), $res->body);
+ }
+
+ public function testGetSignedUrlForPuttingObject()
+ {
+ $object = "a.file";
+ $timeout = 3600;
+ try {
+ $signedUrl = $this->ossClient->signUrl($this->bucket, $object, $timeout, "PUT");
+ $content = file_get_contents(__FILE__);
+ $request = new RequestCore($signedUrl);
+ $request->set_method('PUT');
+ $request->add_header('Content-Type', '');
+ $request->add_header('Content-Length', strlen($content));
+ $request->set_body($content);
+ $request->send_request();
+ $res = new ResponseCore($request->get_response_header(),
+ $request->get_response_body(), $request->get_response_code());
+ $this->assertTrue($res->isOK());
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ }
+
+ public function testGetSignedUrlForPuttingObjectFromFile()
+ {
+ $file = __FILE__;
+ $object = "a.file";
+ $timeout = 3600;
+ $options = array('Content-Type' => 'txt');
+ try {
+ $signedUrl = $this->ossClient->signUrl($this->bucket, $object, $timeout, "PUT", $options);
+ $request = new RequestCore($signedUrl);
+ $request->set_method('PUT');
+ $request->add_header('Content-Type', 'txt');
+ $request->set_read_file($file);
+ $request->set_read_stream_size(filesize($file));
+ $request->send_request();
+ $res = new ResponseCore($request->get_response_header(),
+ $request->get_response_body(), $request->get_response_code());
+ $this->assertTrue($res->isOK());
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ }
+
+ public function tearDown()
+ {
+ $this->ossClient->deleteObject($this->bucket, "a.file");
+ parent::tearDown();
+ }
+
+ public function setUp()
+ {
+ parent::setUp();
+ /**
+ * 上传本地变量到bucket
+ */
+ $object = "a.file";
+ $content = file_get_contents(__FILE__);
+ $options = array(
+ OssClient::OSS_LENGTH => strlen($content),
+ OssClient::OSS_HEADERS => array(
+ 'Expires' => 'Fri, 28 Feb 2020 05:38:42 GMT',
+ 'Cache-Control' => 'no-cache',
+ 'Content-Disposition' => 'attachment;filename=oss_download.log',
+ 'Content-Encoding' => 'utf-8',
+ 'Content-Language' => 'zh-CN',
+ 'x-oss-server-side-encryption' => 'AES256',
+ 'x-oss-meta-self-define-title' => 'user define meta info',
+ ),
+ );
+
+ try {
+ $this->ossClient->putObject($this->bucket, $object, $content, $options);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientTest.php
new file mode 100644
index 000000000..72bf5cc2f
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssClientTest.php
@@ -0,0 +1,111 @@
+assertFalse($ossClient->isUseSSL());
+ $ossClient->setUseSSL(true);
+ $this->assertTrue($ossClient->isUseSSL());
+ $this->assertTrue(true);
+ $this->assertEquals(3, $ossClient->getMaxRetries());
+ $ossClient->setMaxTries(4);
+ $this->assertEquals(4, $ossClient->getMaxRetries());
+ $ossClient->setTimeout(10);
+ $ossClient->setConnectTimeout(20);
+ } catch (OssException $e) {
+ assertFalse(true);
+ }
+ }
+
+ public function testConstrunct2()
+ {
+ try {
+ $ossClient = new OssClient('id', "", 'http://oss-cn-hangzhou.aliyuncs.com');
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals("access key secret is empty", $e->getMessage());
+ }
+ }
+
+ public function testConstrunct3()
+ {
+ try {
+ $ossClient = new OssClient("", 'key', 'http://oss-cn-hangzhou.aliyuncs.com');
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals("access key id is empty", $e->getMessage());
+ }
+ }
+
+ public function testConstrunct4()
+ {
+ try {
+ $ossClient = new OssClient('id', 'key', "");
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals('endpoint is empty', $e->getMessage());
+ }
+ }
+
+ public function testConstrunct5()
+ {
+ try {
+ $ossClient = new OssClient('id', 'key', "123.123.123.1");
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ }
+
+ public function testConstrunct6()
+ {
+ try {
+ $ossClient = new OssClient('id', 'key', "https://123.123.123.1");
+ $this->assertTrue($ossClient->isUseSSL());
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ }
+
+ public function testConstrunct7()
+ {
+ try {
+ $ossClient = new OssClient('id', 'key', "http://123.123.123.1");
+ $this->assertFalse($ossClient->isUseSSL());
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ }
+
+ public function testConstrunct8()
+ {
+ try {
+ $ossClient = new OssClient('id', 'key', "http://123.123.123.1", true);
+ $ossClient->listBuckets();
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+
+ }
+ }
+
+ public function testConstrunct9()
+ {
+ try {
+ $accessKeyId = ' ' . getenv('OSS_ACCESS_KEY_ID') . ' ';
+ $accessKeySecret = ' ' . getenv('OSS_ACCESS_KEY_SECRET') . ' ';
+ $endpoint = ' ' . getenv('OSS_ENDPOINT') . '/ ';
+ $ossClient = new OssClient($accessKeyId, $accessKeySecret , $endpoint, false);
+ $ossClient->listBuckets();
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+ }
+
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssExceptionTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssExceptionTest.php
new file mode 100644
index 000000000..4a418d53e
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssExceptionTest.php
@@ -0,0 +1,19 @@
+assertTrue(false);
+ } catch (OssException $e) {
+ $this->assertNotNull($e);
+ $this->assertEquals($e->getMessage(), "ERR");
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssUtilTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssUtilTest.php
new file mode 100644
index 000000000..327941766
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/OssUtilTest.php
@@ -0,0 +1,214 @@
+assertEquals(OssUtil::chkChinese("hello,world"), 0);
+ $str = '你好,这里是卖咖啡!';
+ $strGBK = OssUtil::encodePath($str);
+ $this->assertEquals(OssUtil::chkChinese($str), 1);
+ $this->assertEquals(OssUtil::chkChinese($strGBK), 1);
+ }
+
+ public function testIsGB2312()
+ {
+ $str = '你好,这里是卖咖啡!';
+ $this->assertFalse(OssUtil::isGb2312($str));
+ }
+
+ public function testCheckChar()
+ {
+ $str = '你好,这里是卖咖啡!';
+ $this->assertFalse(OssUtil::checkChar($str));
+ $this->assertTrue(OssUtil::checkChar(iconv("UTF-8", "GB2312//IGNORE", $str)));
+ }
+
+ public function testIsIpFormat()
+ {
+ $this->assertTrue(OssUtil::isIPFormat("10.101.160.147"));
+ $this->assertTrue(OssUtil::isIPFormat("12.12.12.34"));
+ $this->assertTrue(OssUtil::isIPFormat("12.12.12.12"));
+ $this->assertTrue(OssUtil::isIPFormat("255.255.255.255"));
+ $this->assertTrue(OssUtil::isIPFormat("0.1.1.1"));
+ $this->assertFalse(OssUtil::isIPFormat("0.1.1.x"));
+ $this->assertFalse(OssUtil::isIPFormat("0.1.1.256"));
+ $this->assertFalse(OssUtil::isIPFormat("256.1.1.1"));
+ $this->assertFalse(OssUtil::isIPFormat("0.1.1.0.1"));
+ $this->assertTrue(OssUtil::isIPFormat("10.10.10.10:123"));
+ }
+
+ public function testToQueryString()
+ {
+ $option = array("a" => "b");
+ $this->assertEquals('a=b', OssUtil::toQueryString($option));
+ }
+
+ public function testSReplace()
+ {
+ $str = "<>&'\"";
+ $this->assertEquals("<>&'"", OssUtil::sReplace($str));
+ }
+
+ public function testCheckChinese()
+ {
+ $str = '你好,这里是卖咖啡!';
+ $this->assertEquals(OssUtil::chkChinese($str), 1);
+ if (OssUtil::isWin()) {
+ $strGB = OssUtil::encodePath($str);
+ $this->assertEquals($str, iconv("GB2312", "UTF-8", $strGB));
+ }
+ }
+
+ public function testValidateOption()
+ {
+ $option = 'string';
+
+ try {
+ OssUtil::validateOptions($option);
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals("string:option must be array", $e->getMessage());
+ }
+
+ $option = null;
+
+ try {
+ OssUtil::validateOptions($option);
+ $this->assertTrue(true);
+ } catch (OssException $e) {
+ $this->assertFalse(true);
+ }
+
+ }
+
+ public function testCreateDeleteObjectsXmlBody()
+ {
+ $xml = <<true obj1
+BBBB;
+ $a = array('obj1');
+ $this->assertEquals($xml, $this->cleanXml(OssUtil::createDeleteObjectsXmlBody($a, 'true')));
+ }
+
+ public function testCreateCompleteMultipartUploadXmlBody()
+ {
+ $xml = <<2 xx
+BBBB;
+ $a = array(array("PartNumber" => 2, "ETag" => "xx"));
+ $this->assertEquals($this->cleanXml(OssUtil::createCompleteMultipartUploadXmlBody($a)), $xml);
+ }
+
+ public function testValidateBucket()
+ {
+ $this->assertTrue(OssUtil::validateBucket("xxx"));
+ $this->assertFalse(OssUtil::validateBucket("XXXqwe123"));
+ $this->assertFalse(OssUtil::validateBucket("XX"));
+ $this->assertFalse(OssUtil::validateBucket("/X"));
+ $this->assertFalse(OssUtil::validateBucket(""));
+ }
+
+ public function testValidateObject()
+ {
+ $this->assertTrue(OssUtil::validateObject("xxx"));
+ $this->assertTrue(OssUtil::validateObject("xxx23"));
+ $this->assertTrue(OssUtil::validateObject("12321-xxx"));
+ $this->assertTrue(OssUtil::validateObject("x"));
+ $this->assertFalse(OssUtil::validateObject("/aa"));
+ $this->assertFalse(OssUtil::validateObject("\\aa"));
+ $this->assertFalse(OssUtil::validateObject(""));
+ }
+
+ public function testStartWith()
+ {
+ $this->assertTrue(OssUtil::startsWith("xxab", "xx"), true);
+ }
+
+ public function testReadDir()
+ {
+ $list = OssUtil::readDir("./src", ".|..|.svn|.git", true);
+ $this->assertNotNull($list);
+ }
+
+ public function testIsWin()
+ {
+ //$this->assertTrue(OssUtil::isWin());
+ }
+
+ public function testGetMd5SumForFile()
+ {
+ $this->assertEquals(OssUtil::getMd5SumForFile(__FILE__, 0, filesize(__FILE__) - 1), base64_encode(md5(file_get_contents(__FILE__), true)));
+ }
+
+ public function testGenerateFile()
+ {
+ $path = __DIR__ . DIRECTORY_SEPARATOR . "generatedFile.txt";
+ OssUtil::generateFile($path, 1024 * 1024);
+ $this->assertEquals(filesize($path), 1024 * 1024);
+ unlink($path);
+ }
+
+ public function testThrowOssExceptionWithMessageIfEmpty()
+ {
+ $null = null;
+ try {
+ OssUtil::throwOssExceptionWithMessageIfEmpty($null, "xx");
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+ $this->assertEquals('xx', $e->getMessage());
+ }
+ }
+
+ public function testThrowOssExceptionWithMessageIfEmpty2()
+ {
+ $null = "";
+ try {
+ OssUtil::throwOssExceptionWithMessageIfEmpty($null, "xx");
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+ $this->assertEquals('xx', $e->getMessage());
+ }
+ }
+
+ public function testValidContent()
+ {
+ $null = "";
+ try {
+ OssUtil::validateContent($null);
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+ $this->assertEquals('http body content is invalid', $e->getMessage());
+ }
+
+ $notnull = "x";
+ try {
+ OssUtil::validateContent($notnull);
+ $this->assertTrue(true);
+ } catch (OssException $e) {
+ $this->assertEquals('http body content is invalid', $e->getMessage());
+ }
+ }
+
+ public function testThrowOssExceptionWithMessageIfEmpty3()
+ {
+ $null = "xx";
+ try {
+ OssUtil::throwOssExceptionWithMessageIfEmpty($null, "xx");
+ $this->assertTrue(True);
+ } catch (OssException $e) {
+ $this->assertTrue(false);
+ }
+ }
+
+ private function cleanXml($xml)
+ {
+ return str_replace("\n", "", str_replace("\r", "", $xml));
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/PutSetDeleteResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/PutSetDeleteResultTest.php
new file mode 100644
index 000000000..b298e4418
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/PutSetDeleteResultTest.php
@@ -0,0 +1,66 @@
+assertFalse(true);
+ } catch (OssException $e) {
+ $this->assertEquals('raw response is null', $e->getMessage());
+ }
+ }
+
+ public function testOkResponse()
+ {
+ $header= array(
+ 'x-oss-request-id' => '582AA51E004C4550BD27E0E4',
+ 'etag' => '595FA1EA77945233921DF12427F9C7CE',
+ 'content-md5' => 'WV+h6neUUjOSHfEkJ/nHzg==',
+ 'info' => array(
+ 'http_code' => '200',
+ 'method' => 'PUT'
+ ),
+ );
+ $response = new ResponseCore($header, "this is a mock body, just for test", 200);
+ $result = new PutSetDeleteResult($response);
+ $data = $result->getData();
+ $this->assertTrue($result->isOK());
+ $this->assertEquals("this is a mock body, just for test", $data['body']);
+ $this->assertEquals('582AA51E004C4550BD27E0E4', $data['x-oss-request-id']);
+ $this->assertEquals('595FA1EA77945233921DF12427F9C7CE', $data['etag']);
+ $this->assertEquals('WV+h6neUUjOSHfEkJ/nHzg==', $data['content-md5']);
+ $this->assertEquals('200', $data['info']['http_code']);
+ $this->assertEquals('PUT', $data['info']['method']);
+ }
+
+ public function testFailResponse()
+ {
+ $response = new ResponseCore(array(), "", 301);
+ try {
+ new PutSetDeleteResult($response);
+ $this->assertFalse(true);
+ } catch (OssException $e) {
+
+ }
+ }
+
+ public function setUp()
+ {
+
+ }
+
+ public function tearDown()
+ {
+
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/RefererConfigTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/RefererConfigTest.php
new file mode 100644
index 000000000..8360a242c
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/RefererConfigTest.php
@@ -0,0 +1,54 @@
+
+
+true
+
+http://www.aliyun.com
+https://www.aliyun.com
+http://www.*.com
+https://www.?.aliyuncs.com
+
+
+BBBB;
+
+ private $validXml2 = <<
+
+true
+
+http://www.aliyun.com
+
+
+BBBB;
+
+ public function testParseValidXml()
+ {
+ $refererConfig = new RefererConfig();
+ $refererConfig->parseFromXml($this->validXml);
+ $this->assertEquals($this->cleanXml($this->validXml), $this->cleanXml($refererConfig->serializeToXml()));
+ }
+
+ public function testParseValidXml2()
+ {
+ $refererConfig = new RefererConfig();
+ $refererConfig->parseFromXml($this->validXml2);
+ $this->assertEquals(true, $refererConfig->isAllowEmptyReferer());
+ $this->assertEquals(1, count($refererConfig->getRefererList()));
+ $this->assertEquals($this->cleanXml($this->validXml2), $this->cleanXml(strval($refererConfig)));
+ }
+
+ private function cleanXml($xml)
+ {
+ return str_replace("\n", "", str_replace("\r", "", $xml));
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/TestOssClientBase.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/TestOssClientBase.php
new file mode 100644
index 000000000..4abd31f92
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/TestOssClientBase.php
@@ -0,0 +1,51 @@
+bucket = Common::getBucketName() . rand(100000, 999999);
+ $this->ossClient = Common::getOssClient();
+ $this->ossClient->createBucket($this->bucket);
+ Common::waitMetaSync();
+ }
+
+ public function tearDown()
+ {
+ if (!$this->ossClient->doesBucketExist($this->bucket)) {
+ return;
+ }
+
+ $objects = $this->ossClient->listObjects(
+ $this->bucket, array('max-keys' => 1000, 'delimiter' => ''))->getObjectList();
+ $keys = array();
+ foreach ($objects as $obj) {
+ $keys[] = $obj->getKey();
+ }
+ if (count($keys) > 0) {
+ $this->ossClient->deleteObjects($this->bucket, $keys);
+ }
+ $uploads = $this->ossClient->listMultipartUploads($this->bucket)->getUploads();
+ foreach ($uploads as $up) {
+ $this->ossClient->abortMultipartUpload($this->bucket, $up->getKey(), $up->getUploadId());
+ }
+
+ $this->ossClient->deleteBucket($this->bucket);
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/UploadPartResultTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/UploadPartResultTest.php
new file mode 100644
index 000000000..e4789efe6
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/UploadPartResultTest.php
@@ -0,0 +1,33 @@
+ '7265F4D211B56873A381D321F586E4A9');
+ private $invalidHeader = array();
+
+ public function testParseValidHeader()
+ {
+ $response = new ResponseCore($this->validHeader, "", 200);
+ $result = new UploadPartResult($response);
+ $eTag = $result->getData();
+ $this->assertEquals('7265F4D211B56873A381D321F586E4A9', $eTag);
+ }
+
+ public function testParseInvalidHeader()
+ {
+ $response = new ResponseCore($this->invalidHeader, "", 200);
+ try {
+ new UploadPartResult($response);
+ $this->assertTrue(false);
+ } catch (OssException $e) {
+ $this->assertEquals('cannot get ETag', $e->getMessage());
+ }
+ }
+}
diff --git a/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/WebsiteConfigTest.php b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/WebsiteConfigTest.php
new file mode 100644
index 000000000..2ec0fcbb5
--- /dev/null
+++ b/vendor/aliyuncs/oss-sdk-php/tests/OSS/Tests/WebsiteConfigTest.php
@@ -0,0 +1,56 @@
+
+
+
+index.html
+
+
+errorDocument.html
+
+
+BBBB;
+
+ private $nullXml = <<
+BBBB;
+ private $nullXml2 = <<
+BBBB;
+
+ public function testParseValidXml()
+ {
+ $websiteConfig = new WebsiteConfig("index");
+ $websiteConfig->parseFromXml($this->validXml);
+ $this->assertEquals($this->cleanXml($this->validXml), $this->cleanXml($websiteConfig->serializeToXml()));
+ }
+
+ public function testParsenullXml()
+ {
+ $websiteConfig = new WebsiteConfig();
+ $websiteConfig->parseFromXml($this->nullXml);
+ $this->assertTrue($this->cleanXml($this->nullXml) === $this->cleanXml($websiteConfig->serializeToXml()) ||
+ $this->cleanXml($this->nullXml2) === $this->cleanXml($websiteConfig->serializeToXml()));
+ }
+
+ public function testWebsiteConstruct()
+ {
+ $websiteConfig = new WebsiteConfig("index.html", "errorDocument.html");
+ $this->assertEquals('index.html', $websiteConfig->getIndexDocument());
+ $this->assertEquals('errorDocument.html', $websiteConfig->getErrorDocument());
+ $this->assertEquals($this->cleanXml($this->validXml), $this->cleanXml($websiteConfig->serializeToXml()));
+ }
+
+ private function cleanXml($xml)
+ {
+ return str_replace("\n", "", str_replace("\r", "", $xml));
+ }
+}
diff --git a/vendor/autoload.php b/vendor/autoload.php
index 5d49adb27..08c91059b 100644
--- a/vendor/autoload.php
+++ b/vendor/autoload.php
@@ -4,4 +4,4 @@
require_once __DIR__ . '/composer/autoload_real.php';
-return ComposerAutoloaderInitd15b7724a4339f816295e7d8e017c8aa::getLoader();
+return ComposerAutoloaderInit4885b8f51026b3a984c69470cba091c6::getLoader();
diff --git a/vendor/composer/autoload_real.php b/vendor/composer/autoload_real.php
index 3e1742a80..8c81e33b3 100644
--- a/vendor/composer/autoload_real.php
+++ b/vendor/composer/autoload_real.php
@@ -2,7 +2,7 @@
// autoload_real.php @generated by Composer
-class ComposerAutoloaderInitd15b7724a4339f816295e7d8e017c8aa
+class ComposerAutoloaderInit4885b8f51026b3a984c69470cba091c6
{
private static $loader;
@@ -19,15 +19,15 @@ class ComposerAutoloaderInitd15b7724a4339f816295e7d8e017c8aa
return self::$loader;
}
- spl_autoload_register(array('ComposerAutoloaderInitd15b7724a4339f816295e7d8e017c8aa', 'loadClassLoader'), true, true);
+ spl_autoload_register(array('ComposerAutoloaderInit4885b8f51026b3a984c69470cba091c6', 'loadClassLoader'), true, true);
self::$loader = $loader = new \Composer\Autoload\ClassLoader();
- spl_autoload_unregister(array('ComposerAutoloaderInitd15b7724a4339f816295e7d8e017c8aa', 'loadClassLoader'));
+ spl_autoload_unregister(array('ComposerAutoloaderInit4885b8f51026b3a984c69470cba091c6', 'loadClassLoader'));
$useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION');
if ($useStaticLoader) {
require_once __DIR__ . '/autoload_static.php';
- call_user_func(\Composer\Autoload\ComposerStaticInitd15b7724a4339f816295e7d8e017c8aa::getInitializer($loader));
+ call_user_func(\Composer\Autoload\ComposerStaticInit4885b8f51026b3a984c69470cba091c6::getInitializer($loader));
} else {
$map = require __DIR__ . '/autoload_namespaces.php';
foreach ($map as $namespace => $path) {
@@ -48,19 +48,19 @@ class ComposerAutoloaderInitd15b7724a4339f816295e7d8e017c8aa
$loader->register(true);
if ($useStaticLoader) {
- $includeFiles = Composer\Autoload\ComposerStaticInitd15b7724a4339f816295e7d8e017c8aa::$files;
+ $includeFiles = Composer\Autoload\ComposerStaticInit4885b8f51026b3a984c69470cba091c6::$files;
} else {
$includeFiles = require __DIR__ . '/autoload_files.php';
}
foreach ($includeFiles as $fileIdentifier => $file) {
- composerRequired15b7724a4339f816295e7d8e017c8aa($fileIdentifier, $file);
+ composerRequire4885b8f51026b3a984c69470cba091c6($fileIdentifier, $file);
}
return $loader;
}
}
-function composerRequired15b7724a4339f816295e7d8e017c8aa($fileIdentifier, $file)
+function composerRequire4885b8f51026b3a984c69470cba091c6($fileIdentifier, $file)
{
if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
require $file;
diff --git a/vendor/composer/autoload_static.php b/vendor/composer/autoload_static.php
index 321bf68da..1cc35082c 100644
--- a/vendor/composer/autoload_static.php
+++ b/vendor/composer/autoload_static.php
@@ -4,7 +4,7 @@
namespace Composer\Autoload;
-class ComposerStaticInitd15b7724a4339f816295e7d8e017c8aa
+class ComposerStaticInit4885b8f51026b3a984c69470cba091c6
{
public static $files = array (
'9b552a3cc426e3287cc811caefa3cf53' => __DIR__ . '/..' . '/topthink/think-helper/src/helper.php',
@@ -383,9 +383,9 @@ class ComposerStaticInitd15b7724a4339f816295e7d8e017c8aa
public static function getInitializer(ClassLoader $loader)
{
return \Closure::bind(function () use ($loader) {
- $loader->prefixLengthsPsr4 = ComposerStaticInitd15b7724a4339f816295e7d8e017c8aa::$prefixLengthsPsr4;
- $loader->prefixDirsPsr4 = ComposerStaticInitd15b7724a4339f816295e7d8e017c8aa::$prefixDirsPsr4;
- $loader->classMap = ComposerStaticInitd15b7724a4339f816295e7d8e017c8aa::$classMap;
+ $loader->prefixLengthsPsr4 = ComposerStaticInit4885b8f51026b3a984c69470cba091c6::$prefixLengthsPsr4;
+ $loader->prefixDirsPsr4 = ComposerStaticInit4885b8f51026b3a984c69470cba091c6::$prefixDirsPsr4;
+ $loader->classMap = ComposerStaticInit4885b8f51026b3a984c69470cba091c6::$classMap;
}, null, ClassLoader::class);
}
diff --git a/vendor/topthink/think-mongo/.gitignore b/vendor/topthink/think-mongo/.gitignore
new file mode 100644
index 000000000..485dee64b
--- /dev/null
+++ b/vendor/topthink/think-mongo/.gitignore
@@ -0,0 +1 @@
+.idea
diff --git a/vendor/zoujingli/wechat-php-sdk/Wechat/WechatHardware.php b/vendor/zoujingli/wechat-php-sdk/Wechat/WechatHardware.php
new file mode 100644
index 000000000..9ac4339c5
--- /dev/null
+++ b/vendor/zoujingli/wechat-php-sdk/Wechat/WechatHardware.php
@@ -0,0 +1,142 @@
+access_token && !$this->getAccessToken()) {
+ return false;
+ }
+ $result = Tools::httpPost(self::API_BASE_URL_PREFIX . self::DEVICE_COMPEL_UNBINDHTTPS . "access_token={$this->access_token}", Tools::json_encode($data));
+ if ($result) {
+ $json = json_decode($result, true);
+ if (!$json || !empty($json['errcode'])) {
+ $this->errCode = $json['errcode'];
+ $this->errMsg = $json['errmsg'];
+ return $this->checkRetry(__FUNCTION__, func_get_args());
+ }
+ return $json;
+ }
+ return false;
+ }
+
+
+ public function transmsg($data) {
+ if (!$this->access_token && !$this->getAccessToken()) {
+ return false;
+ }
+ $result = Tools::httpPost(self::API_BASE_URL_PREFIX . self::DEVICE_TRANSMSG . "access_token={$this->access_token}", Tools::json_encode($data));
+ //dump($result);
+ if ($result) {
+ $json = json_decode($result, true);
+ if (!$json || !empty($json['errcode'])) {
+ $this->errCode = $json['errcode'];
+ $this->errMsg = $json['errmsg'];
+ return $this->checkRetry(__FUNCTION__, func_get_args());
+ }
+ return $json;
+ }
+ return false;
+ }
+
+ public function getQrcode($product_id) {
+ if (!$this->access_token && !$this->getAccessToken()) {
+ return false;
+ }
+ $result = Tools::httpGet(self::API_BASE_URL_PREFIX . self::DEVICE_GETQRCODE . "access_token={$this->access_token}&product_id=$product_id");
+ if ($result) {
+ $json = json_decode($result, true);
+ if (!$json || !empty($json['errcode'])) {
+ $this->errCode = $json['errcode'];
+ $this->errMsg = $json['errmsg'];
+ return $this->checkRetry(__FUNCTION__, func_get_args());
+ }
+ return $json;
+ }
+ return false;
+ }
+
+ /**
+ * 设备授权
+ * @param $data
+ * @return bool|mixed
+ */
+ public function deviceAuthorize($data) {
+ if (!$this->access_token && !$this->getAccessToken()) {
+ return false;
+ }
+ $result = Tools::httpPost(self::API_BASE_URL_PREFIX . self::DEVICE_AUTHORIZE_DEVICE . "access_token={$this->access_token}", Tools::json_encode($data));
+ if ($result) {
+ $json = json_decode($result, true);
+ if (!$json || !empty($json['errcode'])) {
+ $this->errCode = $json['errcode'];
+ $this->errMsg = $json['errmsg'];
+ return $this->checkRetry(__FUNCTION__, func_get_args());
+ }
+ return $json;
+ }
+ return false;
+ }
+
+ /**
+ * 获取设备二维码
+ * @param $data
+ * @return bool|mixed
+ */
+ public function getDeviceQrcode($data) {
+ if (!$this->access_token && !$this->getAccessToken()) {
+ return false;
+ }
+ $result = Tools::httpPost(self::API_BASE_URL_PREFIX . self::DEVICE_CREATE_QRCODE . "access_token={$this->access_token}", Tools::json_encode($data));
+ //dump($result);
+ if ($result) {
+ $json = json_decode($result, true);
+ if (!$json || !empty($json['errcode'])) {
+ $this->errCode = $json['errcode'];
+ $this->errMsg = $json['errmsg'];
+ return $this->checkRetry(__FUNCTION__, func_get_args());
+ }
+ return $json;
+ }
+ return false;
+ }
+
+ /**
+ * 获取设备状态
+ * @param $device_id
+ * @return bool|mixed
+ */
+ public function getDeviceStat($device_id) {
+ if (!$this->access_token && !$this->getAccessToken()) {
+ return false;
+ }
+ $result = Tools::httpGet(self::API_BASE_URL_PREFIX . self::DEVICE_GET_STAT . "access_token={$this->access_token}&device_id=$device_id");
+ if ($result) {
+ $json = json_decode($result, true);
+ if (!$json || !empty($json['errcode'])) {
+ $this->errCode = $json['errcode'];
+ $this->errMsg = $json['errmsg'];
+ return $this->checkRetry(__FUNCTION__, func_get_args());
+ }
+ return $json;
+ }
+ return false;
+ }
+
+}
\ No newline at end of file