var COS = require('./lib/cos-wx-sdk-v5');
var wxfs = wx.getFileSystemManager();
var config = require('./config');

var TaskId;


// 签名回调
var getAuthorization = function(options, callback) {

    // 格式一、(推荐)后端通过获取临时密钥给到前端,前端计算签名
    // 服务端 JS 和 PHP 例子:https://github.com/tencentyun/cos-js-sdk-v5/blob/master/server/
    // 服务端其他语言参考 COS STS SDK :https://github.com/tencentyun/qcloud-cos-sts-sdk
    wx.request({
        method: 'GET',
        url: config.stsUrl, // 服务端签名,参考 server 目录下的两个签名例子
        dataType: 'json',
        success: function(result) {
            var data = result.data;
            var credentials = data && data.credentials;
            if (!data || !credentials) return console.error('credentials invalid');
            callback({
                TmpSecretId: credentials.tmpSecretId,
                TmpSecretKey: credentials.tmpSecretKey,
                SecurityToken: credentials.sessionToken,
                StartTime: data.startTime, // 时间戳,单位秒,如:1580000000,建议返回服务器时间作为签名的开始时间,避免用户浏览器本地时间偏差过大导致签名错误
                ExpiredTime: data.expiredTime, // 时间戳,单位秒,如:1580000900
            });
        }
    });


    // // 格式二、(推荐)【细粒度控制权限】后端通过获取临时密钥给到前端,前端只有相同请求才重复使用临时密钥,后端可以通过 Scope 细粒度控制权限
    // // 服务端例子:https://github.com/tencentyun/qcloud-cos-sts-sdk/edit/master/scope.md
    // wx.request({
    //     method: 'POST',
    //     url: 'http://127.0.0.1:3000/sts-scope',
    //     data: options.Scope,
    //     dataType: 'json',
    //     success: function(result) {
    //         var data = result.data;
    //         var credentials = data && data.credentials;
    //         if (!data || !credentials) return console.error('credentials invalid');
    //         callback({
    //             TmpSecretId: credentials.tmpSecretId,
    //             TmpSecretKey: credentials.tmpSecretKey,
    //             XCosSecurityToken: credentials.sessionToken,
    //             StartTime: data.startTime, // 时间戳,单位秒,如:1580000000,建议返回服务器时间作为签名的开始时间,避免用户浏览器本地时间偏差过大导致签名错误
    //             ExpiredTime: data.expiredTime, // 时间戳,单位秒,如:1580000900
    //             ScopeLimit: true, // 细粒度控制权限需要设为 true,会限制密钥只在相同请求时重复使用
    //         });
    //     }
    // });


    // // 格式三、(不推荐,分片上传权限不好控制)前端每次请求前都需要通过 getAuthorization 获取签名,后端使用固定密钥或临时密钥计算签名返回给前端
    // // 服务端获取签名,请参考对应语言的 COS SDK:https://cloud.tencent.com/document/product/436/6474
    // // 注意:这种有安全风险,后端需要通过 method、pathname 严格控制好权限,比如不允许 put / 等
    // wx.request({
    //     method: 'POST',
    //     url: 'https://example.com/sts-auth.php, // 服务端签名,参考 server 目录下的两个签名例子
    //     data: {
    //         method: options.Method,
    //         pathname: options.Pathname,
    //         query: options.Query,
    //         headers: options.Headers,
    //     },
    //     dataType: 'json',
    //     success: function(result) {
    //         var data = result.data;
    //         if (!data || !data.authorization) return console.error('authorization invalid');
    //         callback({
    //             Authorization: data.authorization,
    //             // XCosSecurityToken: data.sessionToken, // 如果使用临时密钥,需要传 sessionToken
    //         });
    //     }
    // });


    // // 格式四、(不推荐,适用于前端调试,避免泄露密钥)前端使用固定密钥计算签名
    // var authorization = COS.getAuthorization({
    //     SecretId: 'AKIDxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
    //     SecretKey: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
    //     Method: options.Method,
    //     Pathname: options.Pathname,
    //     Query: options.Query,
    //     Headers: options.Headers,
    //     Expires: 60,
    // });
    // callback({
    //     Authorization: authorization,
    //     // XCosSecurityToken: credentials.sessionToken, // 如果使用临时密钥,需要传 XCosSecurityToken
    // });

};

var cos = new COS({
    // path style 指正式请求时,Bucket 是在 path 里,这样用相同园区多个 bucket 只需要配置一个园区域名
    // ForcePathStyle: true,
    getAuthorization: getAuthorization,
    // 是否使用全球加速域名。开启该配置后仅以下接口支持操作:putObject、getObject、headObject、optionsObject、multipartInit、multipartListPart、multipartUpload、multipartAbort、multipartComplete、multipartList、sliceUploadFile、uploadFiles
    // UseAccelerate: true,
});


// 回调统一处理函数
var requestCallback = function(err, data) {
    console.log(err || data);
    if (err && err.error) {
        wx.showModal({
            title: '返回错误',
            content: '请求失败:' + (err.error.Message || err.error) + ';状态码:' + err.statusCode,
            showCancel: false
        });
    } else if (err) {
        wx.showModal({
            title: '请求出错',
            content: '请求出错:' + err + ';状态码:' + err.statusCode,
            showCancel: false
        });
    } else {
        wx.showToast({
            title: '请求成功',
            icon: 'success',
            duration: 3000
        });
    }
};

var mylog = function (msg) {
    wx.showToast({
        title: msg,
        icon: 'success',
        duration: 3000
    });
};

var toolsDao = {
    'request': function(){
        // 对云上数据进行图片处理
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: 'photo.png',
            Method: 'POST',
            Action: 'image_process',
            Headers: {
                // 通过 imageMogr2 接口使用图片缩放功能:指定图片宽度为 200,宽度等比压缩
                'Pic-Operations': '{"is_pic_info": 1, "rules": [{"fileid": "desample_photo.jpg", "rule": "imageMogr2/thumbnail/200x/"}]}'
            },
        }, (err, data) => {
            console.log(err || data)
        });
    },
    'uploadFile 高级上传': function() {
        var uploadFile = function(file) {
            cos.uploadFile({
                Bucket: config.Bucket,
                Region: config.Region,
                Key: file.name,
                FilePath: file.path,
                FileSize: file.size,
                SliceSize: 1024 * 1024 * 5, // 文件大于5mb自动使用分块上传
                onTaskReady: function(taskId) {
                  TaskId = taskId
                },
                onProgress: function (info) {
                    var percent = parseInt(info.percent * 10000) / 100;
                    var speed = parseInt(info.speed / 1024 / 1024 * 100) / 100;
                    console.log('进度:' + percent + '%; 速度:' + speed + 'Mb/s;');
                },
                onFileFinish: function (err, data, options) {
                    console.log(options.Key + '上传' + (err ? '失败' : '完成'));
                },
            }, function (err, data) {
                console.log(err || data);
            });
        }
        wx.chooseMessageFile({
            count: 10,
            type: 'all',
            success: function(res) {
                uploadFile(res.tempFiles[0]);
            }
        });
    },
    'uploadFiles 批量上传': function() {
        var uploadFiles = function(files) {
            const fileList = files.map(function(file) {
                return Object.assign(file, {
                    Bucket: config.Bucket,
                    Region: config.Region,
                    Key: file.name,
                    FilePath: file.path,
                });
            });
            cos.uploadFiles({
                files: fileList,
                SliceSize: 1024 * 1024 * 5, // 文件大于5mb自动使用分块上传
                onProgress: function (info) {
                    var percent = parseInt(info.percent * 10000) / 100;
                    var speed = parseInt(info.speed / 1024 / 1024 * 100) / 100;
                    console.log('进度:' + percent + '%; 速度:' + speed + 'Mb/s;');
                },
                onFileFinish: function (err, data, options) {
                    console.log(options.Key + '上传' + (err ? '失败' : '完成'));
                },
            }, function (err, data) {
                console.log(err || data);
            });
        }
        wx.chooseMessageFile({
            count: 10,
            type: 'all',
            success: function(res) {
                uploadFiles(res.tempFiles);
            }
        });
    },
    'sliceUploadFile 分片上传': function() {
        var sliceUploadFile = function (file) {
            var key = file.name;
            cos.sliceUploadFile({
                Bucket: config.Bucket,
                Region: config.Region,
                Key: key,
                FilePath: file.path,
                FileSize: file.size,
                CacheControl: 'max-age=7200',
                Headers: {
                    aa: 123,
                },
                Query: {
                    bb: 123,
                },
                onTaskReady: function(taskId) {
                    TaskId = taskId
                },
                onHashProgress: function(info) {
                    console.log('check hash', JSON.stringify(info));
                },
                onProgress: function(info) {
                    console.log(JSON.stringify(info));
                }
            }, requestCallback);
        };
        wx.chooseMessageFile({
            count: 10,
            type: 'all',
            success: function(res) {
                sliceUploadFile(res.tempFiles[0]);
            }
        });
        // wx.chooseVideo({
        //     sourceType: ['album','camera'],
        //     maxDuration: 60,
        //     camera: 'back',
        //     success(res) {
        //         var name = res.tempFilePath.replace(/^.*?([^/]{32}\.\w+)$/, '$1');
        //         sliceUploadFile({
        //             name: name,
        //             path: res.tempFilePath,
        //             size: res.size,
        //         });
        //     },
        //     fail(err) {
        //         console.log(err);
        //     }
        // })
    },
    // 上传文件适用于单请求上传大文件
    'postObject 简单上传': function() {
        wx.chooseImage({
            count: 1, // 默认9
            sizeType: ['original'], // 可以指定是原图还是压缩图,默认二者都有
            sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有
            success: function(res) {
                var file = res.tempFiles[0];
                cos.postObject({
                    Bucket: config.Bucket,
                    Region: config.Region,
                    Key: '1.png',
                    FilePath: file.path,
                    onTaskReady: function(taskId) {
                        TaskId = taskId
                    },
                    onProgress: function(info) {
                        console.log(JSON.stringify(info));
                    }
                }, requestCallback);
            }
        })
    },
    'putObject 简单上传文件': function(type) {
        wx.chooseMessageFile({
            count: 10,
            type: 'all',
            success: function(res) {
                var file = res.tempFiles[0];
                wxfs.readFile({
                    filePath: file.path,
                    success: function (res) {
                        cos.putObject({
                            Bucket: config.Bucket,
                            Region: config.Region,
                            Key: file.name,
                            Body: res.data, // 在小程序里,putObject 接口只允许传字符串的内容,不支持 TaskReady 和 onProgress,上传请使用 cos.postObject 接口
                            Headers: {
                                // 万象持久化接口,上传时持久化。例子:通过 imageMogr2 接口使用图片缩放功能:指定图片宽度为 200,宽度等比压缩
                                // 'Pic-Operations': '{"is_pic_info": 1, "rules": [{"fileid": "desample_photo.jpg", "rule": "imageMogr2/thumbnail/200x/"}]}'
                            },
                        }, requestCallback);
                    },
                    fail: err => console.error(err),
                });
            },
            fail: err => console.error(err),
        });
    },
    'putObject 上传字符串': function(type) {
        cos.putObject({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: '1.txt',
            Body: 'hello world', // 在小程序里,putObject 接口只允许传字符串的内容,不支持 TaskReady 和 onProgress,上传请使用 cos.postObject 接口
            Headers: {
                aa: 123,
            },
            Query: {
                bb: 123,
            },
        }, requestCallback);
    },
    // 上传文件
    'putObject base64 转 ArrayBuffer 上传': function() {
        var base64Url = '';
        var m = (/data:image\/(\w+);base64,(.*)/.exec(base64Url) || []);
        var format = m[1];
        var bodyData = m[2];
        var fileBuf = wx.base64ToArrayBuffer(bodyData);
        cos.putObject({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: '1.' + format,
            Body: fileBuf,
        }, requestCallback);
    },
    'getObjectUrl 获取对象访问url': function() {
        var url = cos.getObjectUrl({
            Bucket: config.Bucket, // Bucket 格式:test-1250000000
            Region: config.Region,
            Key: '1mb.zip',
            Expires: 60,
            Sign: true,
        }, function(err, data) {
            console.log(err || data);
        });
        console.log(url);
    },
};

var bucketDao = {
    // Service
    'getService 获取存储桶列表': function() {
        cos.getService(requestCallback);
    },
    // 简单 Bucket 操作
    'putBucket 创建存储桶': function() {
        cos.putBucket({
            Bucket: config.Bucket,
            Region: config.Region,
        }, requestCallback);
    },
    'headBucket 检索存储桶及其权限': function() {
        cos.headBucket({
            Bucket: config.Bucket,
            Region: config.Region
        }, requestCallback);
    },
    'deleteBucket 删除存储桶': function() {
        cos.deleteBucket({
            Bucket: config.Bucket,
            Region: config.Region
        }, requestCallback);
    },
    'getBucketACL 查询存储桶 ACL': function() {
        cos.getBucketAcl({
            Bucket: config.Bucket,
            Region: config.Region
        }, requestCallback);
    },
    'putBucketACL 设置存储桶 ACL': function() {
        cos.putBucketAcl({
            Bucket: config.Bucket,
            Region: config.Region,
            ACL: 'public-read'
        }, requestCallback);
    },
    'getBucketCors 查询跨域配置': function() {
        cos.getBucketCors({
            Bucket: config.Bucket,
            Region: config.Region
        }, requestCallback);
    },
    'putBucketCors 设置跨域配置': function() {
        cos.putBucketCors({
            Bucket: config.Bucket,
            Region: config.Region,
            ResponseVary: "true",
            CORSRules: [{
                "AllowedOrigin": ["*"],
                "AllowedMethod": ["GET", "POST", "PUT", "DELETE", "HEAD"],
                "AllowedHeader": ["*"],
                "ExposeHeader": ["ETag", "Content-Length"],
                "MaxAgeSeconds": "5"
            }]
        }, requestCallback);
    },
    'deleteBucketCors 删除跨域配置': function() {
        cos.deleteBucketCors({
            Bucket: config.Bucket,
            Region: config.Region
        }, requestCallback);
    },
    'putBucketPolicy 设置存储桶策略': function() {
        var AppId = config.Bucket.substr(config.Bucket.lastIndexOf('-') + 1);
        cos.putBucketPolicy({
            Bucket: config.Bucket,
            Region: config.Region,
            Policy: {
                "version": "2.0",
                "principal": {
                    "qcs": ["qcs::cam::uin/10001:uin/10001"]
                }, // 这里的 10001 是 QQ 号
                "statement": [{
                    "effect": "allow",
                    "action": [
                        "name/cos:GetBucket",
                        "name/cos:PutObject",
                        "name/cos:PostObject",
                        "name/cos:PutObjectCopy",
                        "name/cos:InitiateMultipartUpload",
                        "name/cos:UploadPart",
                        "name/cos:UploadPartCopy",
                        "name/cos:CompleteMultipartUpload",
                        "name/cos:AbortMultipartUpload",
                        "name/cos:AppendObject"
                    ],
                    // "resource": ["qcs::cos:ap-guangzhou:uid/1250000000:test-1250000000/*"] // 1250000000 是 appid
                    "resource": ["qcs::cos:" + config.Region + ":uid/" + AppId + ":" + config.Bucket + "/*"] // 1250000000 是 appid
                }]
            },
        }, requestCallback);
    },
    'getBucketPolicy 查询存储桶策略': function() {
        cos.getBucketPolicy({
            Bucket: config.Bucket,
            Region: config.Region
        }, requestCallback);
    },
    'deleteBucketPolicy 删除存储桶策略': function() {
        cos.deleteBucketPolicy({
            Bucket: config.Bucket,
            Region: config.Region
        }, requestCallback);
    },
    'getBucketLocation 获取Bucket的地域信息': function() {
        cos.getBucketLocation({
            Bucket: config.Bucket,
            Region: config.Region
        }, requestCallback);
    },
    'getBucketTagging 获取Bucket标签': function() {
        cos.getBucketTagging({
            Bucket: config.Bucket,
            Region: config.Region
        }, requestCallback);
    },
    'putBucketTagging 设置Bucket标签': function() {
        cos.putBucketTagging({
            Bucket: config.Bucket,
            Region: config.Region,
            Tagging: {
                "Tags": [
                    {
                        "Key": "k1",
                        "Value": "v1"
                    },
                    {
                        "Key": "k2",
                        "Value": "v2"
                    }
                ]
            }
        }, requestCallback);
    },
    'deleteBucketTagging 删除存储桶标签': function() {
        cos.deleteBucketTagging({
            Bucket: config.Bucket,
            Region: config.Region
        }, requestCallback);
    },
};

var objectDao = {
    'getBucket 获取对象列表': function() {
        cos.getBucket({
            Bucket: config.Bucket,
            Region: config.Region
        }, requestCallback);
    },
    // 上传文件适用于单请求上传大文件
    'postObject 表单上传对象': function() {
        wx.chooseImage({
            count: 1, // 默认9
            sizeType: ['original'], // 可以指定是原图还是压缩图,默认二者都有
            sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有
            success: function(res) {
                var file = res.tempFiles[0];
                cos.postObject({
                    Bucket: config.Bucket,
                    Region: config.Region,
                    Key: '1.png',
                    FilePath: file.path,
                    onTaskReady: function(taskId) {
                        TaskId = taskId
                    },
                    onProgress: function(info) {
                        console.log(JSON.stringify(info));
                    }
                }, requestCallback);
            }
        })
    },
    'putObject 简单上传文件': function(type) {
        wx.chooseMessageFile({
            count: 10,
            type: 'all',
            success: function(res) {
                var file = res.tempFiles[0];
                wxfs.readFile({
                    filePath: file.path,
                    success: function (res) {
                        cos.putObject({
                            Bucket: config.Bucket,
                            Region: config.Region,
                            Key: file.name,
                            Body: res.data, // 在小程序里,putObject 接口只允许传字符串的内容,不支持 TaskReady 和 onProgress,上传请使用 cos.postObject 接口
                            Headers: {
                                // 万象持久化接口,上传时持久化。例子:通过 imageMogr2 接口使用图片缩放功能:指定图片宽度为 200,宽度等比压缩
                                // 'Pic-Operations': '{"is_pic_info": 1, "rules": [{"fileid": "desample_photo.jpg", "rule": "imageMogr2/thumbnail/200x/"}]}'
                            },
                        }, requestCallback);
                    },
                    fail: err => console.error(err),
                });
            },
            fail: err => console.error(err),
        });
    },
    'putObject 上传字符串': function(type) {
        cos.putObject({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: '1.txt',
            Body: 'hello world', // 在小程序里,putObject 接口只允许传字符串的内容,不支持 TaskReady 和 onProgress,上传请使用 cos.postObject 接口
            Headers: {
                aa: 123,
            },
            Query: {
                bb: 123,
            },
        }, requestCallback);
    },
    // 上传文件
    'putObject base64 转 ArrayBuffer 上传': function() {
        var base64Url = '';
        var m = (/data:image\/(\w+);base64,(.*)/.exec(base64Url) || []);
        var format = m[1];
        var bodyData = m[2];
        var fileBuf = wx.base64ToArrayBuffer(bodyData);
        cos.putObject({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: '1.' + format,
            Body: fileBuf,
        }, requestCallback);
    },
    'getObject 下载对象': function() {
        cos.getObject({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: '1.png',
            // 下载时使用图片处理
            // QueryString: `imageMogr2/thumbnail/200x/`,
        }, requestCallback);
    },
    'headObject 检索对象': function() {
        cos.headObject({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: '1.txt'
        }, requestCallback);
    },
    'deleteObject 删除对象': function() {
        cos.deleteObject({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: '1.txt'
        }, requestCallback);
    },
    'getObjectACL 获取对象ACL': function() {
        cos.getObjectAcl({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: '1.txt'
        }, requestCallback);
    },
    'putObjectACL 设置对象ACL': function() {
        cos.putObjectAcl({
            Bucket: config.Bucket, // Bucket 格式:test-1250000000
            Region: config.Region,
            Key: '1.txt',
            // GrantFullControl: 'id="qcs::cam::uin/1001:uin/1001",id="qcs::cam::uin/1002:uin/1002"',
            // GrantWrite: 'id="qcs::cam::uin/1001:uin/1001",id="qcs::cam::uin/1002:uin/1002"',
            // GrantRead: 'id="qcs::cam::uin/1001:uin/1001",id="qcs::cam::uin/1002:uin/1002"',
            // ACL: 'public-read-write',
            // ACL: 'public-read',
            // ACL: 'private',
            ACL: 'default', // 继承上一级目录权限
            // AccessControlPolicy: {
            //     "Owner": { // AccessControlPolicy 里必须有 owner
            //         "ID": 'qcs::cam::uin/459000000:uin/459000000' // 459000000 是 Bucket 所属用户的 QQ 号
            //     },
            //     "Grants": [{
            //         "Grantee": {
            //             "ID": "qcs::cam::uin/10002:uin/10002", // 10002 是 QQ 号
            //         },
            //         "Permission": "READ"
            //     }]
            // }
        }, requestCallback);
    },
    'deleteMultipleObject 批量删除对象': function() {
        cos.deleteMultipleObject({
            Bucket: config.Bucket, // Bucket 格式:test-1250000000
            Region: config.Region,
            Objects: [{
                    Key: '1.txt'
                },
                {
                    Key: '1.copy.txt'
                },
            ]
        }, requestCallback);
    },
    'putObjectCopy 复制对象': function() {
        cos.putObjectCopy({
            Bucket: config.Bucket, // Bucket 格式:test-1250000000
            Region: config.Region,
            Key: '1.copy.txt',
            CopySource: config.Bucket + '.cos.' + config.Region + '.myqcloud.com/1.txt',
        }, requestCallback);
    },
    'restoreObject 恢复归档对象': function() {
        cos.restoreObject({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: '1.txt',
            RestoreRequest: {
                Days: 1,
                CASJobParameters: {
                    Tier: 'Expedited'
                }
            }
        }, requestCallback);
    },
    'appendObject 追加上传': function() {
        // 初始化一个可追加上传的对象append.txt
        cos.appendObject({
            Bucket: config.Bucket, // Bucket 格式:test-1250000000
            Region: config.Region,
            Key: 'append.txt', /* 必须 */
            Body: '12345',
            Position: 0,
        },
        function(err, data) {
            console.log('putObject:', err || data);
        })
    },
    'appendObject_continue 继续追加上传': function() {
        // append.txt必须是一个可追加上传的对象,参考文档:https://cloud.tencent.com/document/product/436/7741
        cos.headObject({
            Bucket: config.Bucket, // Bucket 格式:test-1250000000
            Region: config.Region,
            Key: 'append.txt', /* 必须 */
        }, function(err, data) {
            if (err) return console.log(err);
            // 首先取到要追加的文件当前长度,即需要上送的Position
            var position = data.headers['content-length'];
            cos.appendObject({
                Bucket: config.Bucket, // Bucket 格式:test-1250000000
                Region: config.Region,
                Key: 'append.txt', /* 必须 */
                Body: '66666',
                Position: position,
            },
            function(err, data) {
                // 也可以取到下一次上传的position继续追加上传
                // var nextPosition = data.headers['x-cos-next-append-position'];
                console.log('putObject:', err || data);
            })
        });
    },
    'abortUploadTask 抛弃分块上传任务': function() {
        cos.abortUploadTask({
            Bucket: config.Bucket,
            /* 必须 */ // Bucket 格式:test-1250000000
            Region: config.Region,
            /* 必须 */
            // 格式1,删除单个上传任务
            // Level: 'task',
            // Key: '10mb.zip',
            // UploadId: '14985543913e4e2642e31db217b9a1a3d9b3cd6cf62abfda23372c8d36ffa38585492681e3',
            // 格式2,删除单个文件所有未完成上传任务
            Level: 'file',
            Key: '10mb.zip',
            // 格式3,删除 Bucket 下所有未完成上传任务
            // Level: 'bucket',
        }, requestCallback);
    },
}

var advanceObjectDao = {
    'sliceUploadFile 分块上传': function() {
        var sliceUploadFile = function (file) {
            var key = file.name;
            cos.sliceUploadFile({
                Bucket: config.Bucket,
                Region: config.Region,
                Key: key,
                FilePath: file.path,
                FileSize: file.size,
                CacheControl: 'max-age=7200',
                Headers: {
                    aa: 123,
                },
                Query: {
                    bb: 123,
                },
                onTaskReady: function(taskId) {
                    TaskId = taskId
                },
                onHashProgress: function(info) {
                    console.log('check hash', JSON.stringify(info));
                },
                onProgress: function(info) {
                    console.log(JSON.stringify(info));
                }
            }, requestCallback);
        };
        wx.chooseMessageFile({
            count: 10,
            type: 'all',
            success: function(res) {
                sliceUploadFile(res.tempFiles[0]);
            }
        });
        // wx.chooseVideo({
        //     sourceType: ['album','camera'],
        //     maxDuration: 60,
        //     camera: 'back',
        //     success(res) {
        //         var name = res.tempFilePath.replace(/^.*?([^/]{32}\.\w+)$/, '$1');
        //         sliceUploadFile({
        //             name: name,
        //             path: res.tempFilePath,
        //             size: res.size,
        //         });
        //     },
        //     fail(err) {
        //         console.log(err);
        //     }
        // })
    },
    'sliceCopyFile 分块复制对象': function() {
        // 创建测试文件
        var sourceName = '1.txt';
        var Key = '1.slicecopy.exe';

        var sourcePath = config.Bucket + '.cos.' + config.Region + '.myqcloud.com/' + sourceName;

        cos.sliceCopyFile({
            Bucket: config.Bucket, // Bucket 格式:test-1250000000
            Region: config.Region,
            Key: Key,
            CopySource: sourcePath,
            SliceSize: 20 * 1024 * 1024, // 大于20M的文件用分片复制,小于则用单片复制
            onProgress: function(info) {
                var percent = parseInt(info.percent * 10000) / 100;
                var speed = parseInt(info.speed / 1024 / 1024 * 100) / 100;
                console.log('进度:' + percent + '%; 速度:' + speed + 'Mb/s;');
            }
        }, requestCallback);
    },
    cancelTask: function() {
        cos.cancelTask(TaskId);
        console.log('canceled');
    },
    pauseTask: function() {
        cos.pauseTask(TaskId);
        console.log('paused');
    },
    restartTask: function() {
        cos.restartTask(TaskId);
        console.log('restart');
    },
};

var ciObjectDao = {
    '上传时使用图片处理': function(){
        wx.chooseMessageFile({
            count: 10,
            type: 'all',
            success: function (res) {
              var file = res.tempFiles[0];
              wxfs.readFile({
                filePath: file.path,
                success: function (res) {
                  cos.putObject({
                        Bucket: config.Bucket, // Bucket 格式:test-1250000000
                        Region: config.Region,
                        Key: file.name,
                        Body: res.data,
                        Headers: {
                            // 通过 imageMogr2 接口使用图片缩放功能:指定图片宽度为 200,宽度等比压缩
                            'Pic-Operations':
                            '{"is_pic_info": 1, "rules": [{"fileid": "desample_photo.jpg", "rule": "imageMogr2/thumbnail/200x/"}]}',
                        },
                    },
                    requestCallback,
                  );
                },
                fail: (err) => console.error(err),
              });
            },
            fail: (err) => console.error(err),
          });
    },
    '对云上数据进行图片处理': function(){
        // 对云上数据进行图片处理
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: 'photo.png',
            Method: 'POST',
            Action: 'image_process',
            Headers: {
                // 通过 imageMogr2 接口使用图片缩放功能:指定图片宽度为 200,宽度等比压缩
                'Pic-Operations': '{"is_pic_info": 1, "rules": [{"fileid": "desample_photo.jpg", "rule": "imageMogr2/thumbnail/200x/"}]}'
            },
        }, requestCallback);
    },
    '下载时使用图片处理': function(){
        cos.getObject({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: '1.png',
            QueryString: `imageMogr2/thumbnail/200x/`,
        }, requestCallback);
    },
    '生成带图片处理参数的签名 URL': function(){
        // 生成带图片处理参数的文件签名URL,过期时间设置为 30 分钟。
        cos.getObjectUrl({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: 'photo.png',
            QueryString: `imageMogr2/thumbnail/200x/`,
            Expires: 1800,
            Sign: true,
        },
        (err, data) => {
            console.log('带签名', err || data);
        });

        // 生成带图片处理参数的文件URL,不带签名。
        cos.getObjectUrl({
            Bucket: config.Bucket,
            Region: config.Region,
            Key: 'photo.png',
            QueryString: `imageMogr2/thumbnail/200x/`,
            Sign: false,
        },
        (err, data) => {
            console.log('不带签名', err || data);
        });
    },
    'describeMediaBuckets 查询已经开通数据万象功能的存储桶': function() {
        var host = 'ci.' + config.Region + '.myqcloud.com';
        var url = 'https://' + host + '/mediabucket';
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'GET',
            Key: 'mediabucket', /** 固定值,必须 */
            Url: url,
            Query: {
                pageNumber: '1', /** 第几页,非必须 */
                pageSize: '10', /** 每页个数,非必须 */
                // regions: 'ap-chengdu', /** 地域信息,例如'ap-beijing',支持多个值用逗号分隔如'ap-shanghai,ap-beijing',非必须 */
                // bucketNames: 'test-1250000000', /** 存储桶名称,精确搜索,例如'test-1250000000',支持多个值用逗号分隔如'test1-1250000000,test2-1250000000',非必须 */
                // bucketName: 'test', /** 存储桶名称前缀,前缀搜索,例如'test',支持多个值用逗号分隔如'test1,test2',非必须 */
            }
        },
        function(err, data){
            console.log(err || data);
        });
    },
    'getMediaInfo 获取媒体文件信息': function() {
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'GET',
            Key: 'test.mp4',
            Query: {
                'ci-process': 'videoinfo' /** 固定值,必须 */
            }
        },
        function(err, data){
            console.log(err || data);
        });
    },
    'getSnapshot 获取媒体文件某个时间的截图': function() {
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'GET',
            Key: 'test.mp4',
            Query: {
                'ci-process': 'snapshot', /** 固定值,必须 */
                time: 1, /** 截图的时间点,单位为秒,必须 */
                // width: 0, /** 截图的宽,非必须 */
                // height: 0, /** 截图的高,非必须 */
                // format: 'jpg', /** 截图的格式,支持 jpg 和 png,默认 jpg,非必须 */
                // rotate: 'auto', /** 图片旋转方式,默认为'auto',非必须 */
                // mode: 'exactframe', /** 截帧方式,默认为'exactframe',非必须 */
            },
            RawBody: true,
        },
        function(err, data){
            console.log(err || data);
        });
    },
    '图片同步审核 getImageAuditing': function () {
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'GET',
            Key: '1.png',
            Query: {
                'ci-process': 'sensitive-content-recognition', /** 固定值,必须 */
                'biz-type': '', /** 审核类型,非必须 */
                'detect-type': 'porn,ads', /** 审核策略,不填写则使用默认策略,非必须 */
                'detect-url': '', /** 审核任意公网可访问的图片链接,非必须 */
                'interval': 5, /** 审核 GIF 动图时,每隔interval帧截取一帧,非必须 */
                'max-frames': 5,  /** 审核 GIF 动图时,最大截帧数,非必须 */
                'large-image-detect': '0', /** 是否需要压缩图片后再审核,非必须 */
            },
        },
        function(err, data){
            console.log(err || data);
        });
      },
    '图片批量审核 postImagesAuditing': function () {
        var host = config.Bucket + '.ci.' + config.Region + '.myqcloud.com';
        var url = 'https://' + host + '/image/auditing';
        var body = COS.util.json2xml({
          Request: {
            Input: [{
              Object: '1.png',
            }, {
              Object: '6.png',
            }],
            Conf: {
              BizType: '',
              DetectType: 'Porn'
            }
          }
        });
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'POST',
            Url: url,
            Key: '/image/auditing',
            ContentType: 'application/xml',
            Body: body
        },
        function(err, data){
            console.log(err || data);
        });
    },
    '查询图片审核任务结果 getImageAuditingResult': function () {
        var jobId = 'si8263213daf3711eca0d1525400d88xxx'; // jobId可以通过图片批量审核返回
        var host = config.Bucket + '.ci.' + config.Region + '.myqcloud.com';
        var url = 'https://' + host + '/image/auditing/' + jobId;
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'GET',
            Key: '/image/auditing/' + jobId,
            Url: url,
        },
        function(err, data){
            console.log(err || data);
        });
    },
    '提交视频审核任务 postVideoAuditing': function() {
        var host = config.Bucket + '.ci.' + config.Region + '.myqcloud.com';
        var url = 'https://' + host + '/video/auditing';
        var body = COS.util.json2xml({
          Request: {
            Input: {
              Object: '1.mp4',
            },
            Conf: {
              BizType: '',
              DetectType: 'Porn',
              Snapshot: {
                Count: 1000, // 视频截帧数量
              },
              DetectContent: 1, // 是否审核视频声音,0-只审核视频不审核声音;1-审核视频+声音
            }
          }
        });
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'POST',
            Url: url,
            Key: '/video/auditing',
            ContentType: 'application/xml',
            Body: body
        },
        function(err, data){
            console.log(err || data);
        });
    },
    '查询视频审核任务结果 getVideoAuditingResult': function () {
        var jobId = 'av5bd873d9f39011ecb6c95254009a49da'; // jobId可以通过提交视频审核任务返回
        var host = config.Bucket + '.ci.' + config.Region + '.myqcloud.com';
        var url = 'https://' + host + '/video/auditing/' + jobId;
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'GET',
            Key: '/video/auditing/' + jobId,
            Url: url,
        },
        function(err, data){
            console.log(err || data);
        });
    },
    '提交音频审核任务 postAudioAuditing': function () {
        var host = config.Bucket + '.ci.' + config.Region + '.myqcloud.com';
        var url = 'https://' + host + '/audio/auditing';
        var body = COS.util.json2xml({
          Request: {
            Input: {
              Object: '1.mp3',
            },
            Conf: {
              BizType: '',
              DetectType: 'Porn',
            }
          }
        });
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'POST',
            Url: url,
            Key: '/audio/auditing',
            ContentType: 'application/xml',
            Body: body
        },
        function(err, data){
            console.log(err || data);
        });
    },
    '查询音频审核任务结果 getAudioAuditingResult': function () {
        var jobId = 'sa0c28d41daff411ecb23352540078cxxx'; // jobId可以通过提交音频审核任务返回
        var host = config.Bucket + '.ci.' + config.Region + '.myqcloud.com';
        var url = 'https://' + host + '/audio/auditing/' + jobId;
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'GET',
            Key: '/audio/auditing/' + jobId,
            Url: url,
        },
        function(err, data){
            console.log(err || data);
        });
    },
    '提交文本审核任务 postTextAuditing': function () {
        var host = config.Bucket + '.ci.' + config.Region + '.myqcloud.com';
        var url = 'https://' + host + '/text/auditing';
        var body = COS.util.json2xml({
          Request: {
            Input: {
              // Object: 'hello.txt', // 存在cos里的资源,审核结果异步返回,可以调用查询文本审核结果api查询
              Content: '5Lmz5rKf', // 经过base64编码过的文本”乳沟“,查询结果同步返回
            },
            Conf: {
              BizType: '',
              DetectType: 'Porn',
            }
          }
        });
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'POST',
            Url: url,
            Key: '/text/auditing',
            ContentType: 'application/xml',
            Body: body
        },
        function(err, data){
            console.log(err || data);
        });
    },
    '查询文本审核任务结果 getTextAuditingResult': function () {
        var jobId = 'st8d88c664aff511ecb23352540078cxxx'; // jobId可以通过提交文本审核任务返回(Input传入Object)
        var host = config.Bucket + '.ci.' + config.Region + '.myqcloud.com';
        var url = 'https://' + host + '/text/auditing/' + jobId;
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'GET',
            Key: '/text/auditing/' + jobId,
            Url: url,
        },
        function(err, data){
            console.log(err || data);
        });
    },
    '提交文档审核任务 postDocumentAuditing': function () {
        var host = config.Bucket + '.ci.' + config.Region + '.myqcloud.com';
        var url = 'https://' + host + '/document/auditing';
        var body = COS.util.json2xml({
          Request: {
            Input: {
              Object: 'test.xlsx', // 存在cos里的资源,审核结果异步返回,可以调用查询文本审核结果api查询
            },
            Conf: {
              BizType: '',
              DetectType: 'Porn',
            }
          }
        });
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'POST',
            Url: url,
            Key: '/document/auditing',
            ContentType: 'application/xml',
            Body: body
        },
        function(err, data){
            console.log(err || data);
        });
    },
    '查询文档审核任务结果 getDocumentAuditingResult': function () {
        var jobId = 'sd7815c21caff611eca12f525400d88560'; // jobId可以通过提交文档审核任务返回
        var host = config.Bucket + '.ci.' + config.Region + '.myqcloud.com';
        var url = 'https://' + host + '/document/auditing/' + jobId;
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'GET',
            Key: '/document/auditing/' + jobId,
            Url: url,
        },
        function(err, data){
            console.log(err || data);
        });
    },
    '提交网页审核任务 postWebpageAuditing': function () {
        var host = config.Bucket + '.ci.' + config.Region + '.myqcloud.com';
        var url = 'https://' + host + '/webpage/auditing';
        var body = COS.util.json2xml({
          Request: {
            Input: {
              Url: 'https://cloud.tencent.com/', // 存在cos里的资源,审核结果异步返回,可以调用查询文本审核结果api查询
            },
            Conf: {
              BizType: '',
              DetectType: 'Porn,Ads',
            }
          }
        });
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'POST',
            Url: url,
            Key: '/webpage/auditing',
            ContentType: 'application/xml',
            Body: body
        },
        function(err, data){
            console.log(err || data);
        });
    },
    '查询网页审核任务结果 getWebpageAuditingResult': function () {
        var jobId = 'shce868019aff611ecb1155254009a4xxx'; // jobId可以通过提交网页审核任务返回
        var host = config.Bucket + '.ci.' + config.Region + '.myqcloud.com';
        var url = 'https://' + host + '/webpage/auditing/' + jobId;
        cos.request({
            Bucket: config.Bucket,
            Region: config.Region,
            Method: 'GET',
            Key: '/webpage/auditing/' + jobId,
            Url: url,
        },
        function(err, data){
            console.log(err || data);
        });
    },
}

// require('./test');

module.exports = {
    toolsDao: toolsDao,
    bucketDao: bucketDao,
    objectDao: objectDao,
    advanceObjectDao: advanceObjectDao,
    ciObjectDao: ciObjectDao,
};