#cos #object-storage #tencent-cloud #tengxunyun #cloud-storage

tencent-qcloud-cos-rs

provide basic interface encapsulation of Tencent Cloud Object Storage (cos)

1 unstable release

0.1.0 Mar 4, 2023

#8 in #tencent-cloud

MIT license

66KB
1.5K SLoC

Crates.io qcos

异步版本 async/await

本包提供腾讯云对象存储(cos) 基本的操作,包括bucket创建及删除,对象的上传(支持分块传输)、下载、删除等。后续有时间会补充其他接口的实现。

How to use

use tencent_qcloud_cos_rs::acl::{AclHeader, ObjectAcl};
use tencent_qcloud_cos_rs::client::Client;
use tencent_qcloud_cos_rs::objects::{mime, ErrNo, Objects};

#[tokio::main]
async fn main() {
    let client = Client::new(
        "Your secrect id",
        "Your secrect key",
        Some(String::from("Your security token")), // or None
        "bucket name",
        "region",
    );
    let mut acl_header = AclHeader::new();
    acl_header.insert_object_x_cos_acl(ObjectAcl::PublicRead);
    let res = client.put_object("test.png", "test.png", mime::IMAGE_PNG, Some(&acl_header)).await;
    if res.error_no == ErrNo::SUCCESS {
        println!("success");
    } else {
        println!("{}", res.error_message);
    }
}

如果操作成功,会打印出success, 否则会打印出失败原因。

更多的例子请参考examples

Installation

insert into your project's cargo.toml block next line

[dependencies]
tencent-qcloud-cos-rs = "0.1.0"

Other

fork base: https://github.com/bujnlc8/qcos

Dependencies

~14–27MB
~492K SLoC