Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
7b799aff21 | ||
|
|
a0ab0eb0f8 | ||
|
|
1cc49706b4 | ||
|
|
bcc1ed2b83 | ||
|
|
517ae20fdc |
58
bucket.go
58
bucket.go
@@ -102,3 +102,61 @@ type Bucket struct {
|
|||||||
Region string `xml:"Location,omitempty"`
|
Region string `xml:"Location,omitempty"`
|
||||||
CreationDate string `xml:",omitempty"`
|
CreationDate string `xml:",omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type BucketGetObjectVersionsOptions struct {
|
||||||
|
Prefix string `url:"prefix,omitempty"`
|
||||||
|
Delimiter string `url:"delimiter,omitempty"`
|
||||||
|
EncodingType string `url:"encoding-type,omitempty"`
|
||||||
|
KeyMarker string `url:"key-marker,omitempty"`
|
||||||
|
VersionIdMarker string `url:"version-id-marker,omitempty"`
|
||||||
|
MaxKeys int `url:"max-keys,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type BucketGetObjectVersionsResult struct {
|
||||||
|
XMLName xml.Name `xml:"ListVersionsResult"`
|
||||||
|
Name string `xml:"Name,omitempty"`
|
||||||
|
EncodingType string `xml:"EncodingType,omitempty"`
|
||||||
|
Prefix string `xml:"Prefix,omitempty"`
|
||||||
|
KeyMarker string `xml:"KeyMarker,omitempty"`
|
||||||
|
VersionIdMarker string `xml:"VersionIdMarker,omitempty"`
|
||||||
|
MaxKeys int `xml:"MaxKeys,omitempty"`
|
||||||
|
Delimiter string `xml:"Delimiter,omitempty"`
|
||||||
|
IsTruncated bool `xml:"IsTruncated,omitempty"`
|
||||||
|
NextKeyMarker string `xml:"NextKeyMarker,omitempty"`
|
||||||
|
NextVersionIdMarker string `xml:"NextVersionIdMarker,omitempty"`
|
||||||
|
CommonPrefixes []string `xml:"CommonPrefixes>Prefix,omitempty"`
|
||||||
|
Version []ListVersionsResultVersion `xml:"Version,omitempty"`
|
||||||
|
DeleteMarker []ListVersionsResultDeleteMarker `xml:"DeleteMarker,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type ListVersionsResultVersion struct {
|
||||||
|
Key string `xml:"Key,omitempty"`
|
||||||
|
VersionId string `xml:"VersionId,omitempty"`
|
||||||
|
IsLatest bool `xml:"IsLatest,omitempty"`
|
||||||
|
LastModified string `xml:"LastModified,omitempty"`
|
||||||
|
ETag string `xml:"ETag,omitempty"`
|
||||||
|
Size int `xml:"Size,omitempty"`
|
||||||
|
StorageClass string `xml:"StorageClass,omitempty"`
|
||||||
|
Owner *Owner `xml:"Owner,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type ListVersionsResultDeleteMarker struct {
|
||||||
|
Key string `xml:"Key,omitempty"`
|
||||||
|
VersionId string `xml:"VersionId,omitempty"`
|
||||||
|
IsLatest bool `xml:"IsLatest,omitempty"`
|
||||||
|
LastModified string `xml:"LastModified,omitempty"`
|
||||||
|
Owner *Owner `xml:"Owner,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *BucketService) GetObjectVersions(ctx context.Context, opt *BucketGetObjectVersionsOptions) (*BucketGetObjectVersionsResult, *Response, error) {
|
||||||
|
var res BucketGetObjectVersionsResult
|
||||||
|
sendOpt := sendOptions{
|
||||||
|
baseURL: s.client.BaseURL.BucketURL,
|
||||||
|
uri: "/?versions",
|
||||||
|
method: http.MethodGet,
|
||||||
|
optQuery: opt,
|
||||||
|
result: &res,
|
||||||
|
}
|
||||||
|
resp, err := s.client.send(ctx, &sendOpt)
|
||||||
|
return &res, resp, err
|
||||||
|
}
|
||||||
|
|||||||
90
bucket_origin.go
Normal file
90
bucket_origin.go
Normal file
@@ -0,0 +1,90 @@
|
|||||||
|
package cos
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"encoding/xml"
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
type BucketPutOriginOptions struct {
|
||||||
|
XMLName xml.Name `xml:"OriginConfiguration"`
|
||||||
|
Rule []BucketOriginRule `xml:"OriginRule"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type BucketOriginRule struct {
|
||||||
|
OriginType string `xml:"OriginType"`
|
||||||
|
OriginCondition *BucketOriginCondition `xml:"OriginCondition"`
|
||||||
|
OriginParameter *BucketOriginParameter `xml:"OriginParameter"`
|
||||||
|
OriginInfo *BucketOriginInfo `xml:"OriginInfo"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type BucketOriginCondition struct {
|
||||||
|
HTTPStatusCode string `xml:"HTTPStatusCode,omitempty"`
|
||||||
|
Prefix string `xml:"Prefix,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type BucketOriginParameter struct {
|
||||||
|
Protocol string `xml:"Protocol,omitempty"`
|
||||||
|
FollowQueryString bool `xml:"FollowQueryString,omitempty"`
|
||||||
|
HttpHeader *BucketOriginHttpHeader `xml:"HttpHeader,omitempty"`
|
||||||
|
FollowRedirection bool `xml:"FollowRedirection,omitempty"`
|
||||||
|
HttpRedirectCode string `xml:"HttpRedirectCode,omitempty"`
|
||||||
|
CopyOriginData bool `xml:"CopyOriginData,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type BucketOriginHttpHeader struct {
|
||||||
|
// 目前还不支持 FollowAllHeaders
|
||||||
|
// FollowAllHeaders bool `xml:"FollowAllHeaders,omitempty"`
|
||||||
|
NewHttpHeaders []OriginHttpHeader `xml:"NewHttpHeaders>Header,omitempty"`
|
||||||
|
FollowHttpHeaders []OriginHttpHeader `xml:"FollowHttpHeaders>Header,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type OriginHttpHeader struct {
|
||||||
|
Key string `xml:"Key,omitempty"`
|
||||||
|
Value string `xml:"Value,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type BucketOriginInfo struct {
|
||||||
|
HostInfo string `xml:"HostInfo>HostName,omitempty"`
|
||||||
|
FileInfo *BucketOriginFileInfo `xml:"FileInfo,omitempty"`
|
||||||
|
}
|
||||||
|
type BucketOriginFileInfo struct {
|
||||||
|
PrefixDirective bool `xml:"PrefixDirective,omitempty"`
|
||||||
|
Prefix string `xml:"Prefix,omitempty"`
|
||||||
|
Suffix string `xml:"Suffix,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type BucketGetOriginResult BucketPutOriginOptions
|
||||||
|
|
||||||
|
func (s *BucketService) PutOrigin(ctx context.Context, opt *BucketPutOriginOptions) (*Response, error) {
|
||||||
|
sendOpt := &sendOptions{
|
||||||
|
baseURL: s.client.BaseURL.BucketURL,
|
||||||
|
uri: "/?origin",
|
||||||
|
method: http.MethodPut,
|
||||||
|
body: opt,
|
||||||
|
}
|
||||||
|
resp, err := s.client.send(ctx, sendOpt)
|
||||||
|
return resp, err
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *BucketService) GetOrigin(ctx context.Context) (*BucketGetOriginResult, *Response, error) {
|
||||||
|
var res BucketGetOriginResult
|
||||||
|
sendOpt := &sendOptions{
|
||||||
|
baseURL: s.client.BaseURL.BucketURL,
|
||||||
|
uri: "/?origin",
|
||||||
|
method: http.MethodGet,
|
||||||
|
result: &res,
|
||||||
|
}
|
||||||
|
resp, err := s.client.send(ctx, sendOpt)
|
||||||
|
return &res, resp, err
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *BucketService) DeleteOrigin(ctx context.Context) (*Response, error) {
|
||||||
|
sendOpt := &sendOptions{
|
||||||
|
baseURL: s.client.BaseURL.BucketURL,
|
||||||
|
uri: "/?origin",
|
||||||
|
method: http.MethodDelete,
|
||||||
|
}
|
||||||
|
resp, err := s.client.send(ctx, sendOpt)
|
||||||
|
return resp, err
|
||||||
|
}
|
||||||
105
bucket_test.go
105
bucket_test.go
@@ -150,3 +150,108 @@ func TestBucketService_Head(t *testing.T) {
|
|||||||
t.Fatalf("Bucket.Head returned error: %v", err)
|
t.Fatalf("Bucket.Head returned error: %v", err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestBucketService_GetObjectVersions(t *testing.T) {
|
||||||
|
setup()
|
||||||
|
defer teardown()
|
||||||
|
|
||||||
|
mux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
testMethod(t, r, http.MethodGet)
|
||||||
|
w.WriteHeader(http.StatusOK)
|
||||||
|
vs := values{
|
||||||
|
"versions": "",
|
||||||
|
"delimiter": "/",
|
||||||
|
}
|
||||||
|
testFormValues(t, r, vs)
|
||||||
|
|
||||||
|
fmt.Fprint(w, `<?xml version='1.0' encoding='utf-8' ?>
|
||||||
|
<ListVersionsResult>
|
||||||
|
<Name>examplebucket-1250000000</Name>
|
||||||
|
<Prefix/>
|
||||||
|
<KeyMarker/>
|
||||||
|
<VersionIdMarker/>
|
||||||
|
<MaxKeys>1000</MaxKeys>
|
||||||
|
<IsTruncated>false</IsTruncated>
|
||||||
|
<Delimiter>/</Delimiter>
|
||||||
|
<CommonPrefixes>
|
||||||
|
<Prefix>example-folder-1/</Prefix>
|
||||||
|
</CommonPrefixes>
|
||||||
|
<CommonPrefixes>
|
||||||
|
<Prefix>example-folder-2/</Prefix>
|
||||||
|
</CommonPrefixes>
|
||||||
|
<Version>
|
||||||
|
<Key>example-object-1.jpg</Key>
|
||||||
|
<VersionId>MTg0NDUxNzgxMjEzNTU3NTk1Mjg</VersionId>
|
||||||
|
<IsLatest>true</IsLatest>
|
||||||
|
<LastModified>2019-08-16T10:45:53.000Z</LastModified>
|
||||||
|
<ETag>"5d1143df07a17b23320d0da161e2819e"</ETag>
|
||||||
|
<Size>30</Size>
|
||||||
|
<StorageClass>STANDARD</StorageClass>
|
||||||
|
<Owner>
|
||||||
|
<ID>1250000000</ID>
|
||||||
|
<DisplayName>1250000000</DisplayName>
|
||||||
|
</Owner>
|
||||||
|
</Version>
|
||||||
|
<DeleteMarker>
|
||||||
|
<Key>example-object-1.jpg</Key>
|
||||||
|
<VersionId>MTg0NDUxNzgxMjEzNjE1OTcxMzM</VersionId>
|
||||||
|
<IsLatest>false</IsLatest>
|
||||||
|
<LastModified>2019-08-16T10:45:47.000Z</LastModified>
|
||||||
|
<Owner>
|
||||||
|
<ID>1250000000</ID>
|
||||||
|
<DisplayName>1250000000</DisplayName>
|
||||||
|
</Owner>
|
||||||
|
</DeleteMarker>
|
||||||
|
</ListVersionsResult>`)
|
||||||
|
})
|
||||||
|
|
||||||
|
want := &BucketGetObjectVersionsResult {
|
||||||
|
XMLName: xml.Name { Local: "ListVersionsResult" },
|
||||||
|
Name: "examplebucket-1250000000",
|
||||||
|
MaxKeys: 1000,
|
||||||
|
IsTruncated: false,
|
||||||
|
Delimiter: "/",
|
||||||
|
CommonPrefixes: []string {
|
||||||
|
"example-folder-1/",
|
||||||
|
"example-folder-2/",
|
||||||
|
},
|
||||||
|
Version: []ListVersionsResultVersion {
|
||||||
|
{
|
||||||
|
Key: "example-object-1.jpg",
|
||||||
|
VersionId: "MTg0NDUxNzgxMjEzNTU3NTk1Mjg",
|
||||||
|
IsLatest: true,
|
||||||
|
LastModified: "2019-08-16T10:45:53.000Z",
|
||||||
|
ETag: "\"5d1143df07a17b23320d0da161e2819e\"",
|
||||||
|
Size: 30,
|
||||||
|
StorageClass: "STANDARD",
|
||||||
|
Owner: &Owner {
|
||||||
|
ID: "1250000000",
|
||||||
|
DisplayName: "1250000000",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
DeleteMarker: []ListVersionsResultDeleteMarker {
|
||||||
|
{
|
||||||
|
Key: "example-object-1.jpg",
|
||||||
|
VersionId: "MTg0NDUxNzgxMjEzNjE1OTcxMzM",
|
||||||
|
IsLatest: false,
|
||||||
|
LastModified: "2019-08-16T10:45:47.000Z",
|
||||||
|
Owner: &Owner {
|
||||||
|
ID: "1250000000",
|
||||||
|
DisplayName: "1250000000",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
opt := &BucketGetObjectVersionsOptions {
|
||||||
|
Delimiter: "/",
|
||||||
|
}
|
||||||
|
res, _, err := client.Bucket.GetObjectVersions(context.Background(), opt)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Bucket.GetObjectVersions returned error: %v", err)
|
||||||
|
}
|
||||||
|
if !reflect.DeepEqual(res, want) {
|
||||||
|
t.Errorf("Bucket.GetObjectVersions returned\n%+v\nwant\n%+v", res, want)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|||||||
4
cos.go
4
cos.go
@@ -21,7 +21,7 @@ import (
|
|||||||
|
|
||||||
const (
|
const (
|
||||||
// Version current go sdk version
|
// Version current go sdk version
|
||||||
Version = "0.7.5"
|
Version = "0.7.7"
|
||||||
userAgent = "cos-go-sdk-v5/" + Version
|
userAgent = "cos-go-sdk-v5/" + Version
|
||||||
contentTypeXML = "application/xml"
|
contentTypeXML = "application/xml"
|
||||||
defaultServiceBaseURL = "http://service.cos.myqcloud.com"
|
defaultServiceBaseURL = "http://service.cos.myqcloud.com"
|
||||||
@@ -329,6 +329,8 @@ type ACLHeaderOptions struct {
|
|||||||
XCosGrantRead string `header:"x-cos-grant-read,omitempty" url:"-" xml:"-"`
|
XCosGrantRead string `header:"x-cos-grant-read,omitempty" url:"-" xml:"-"`
|
||||||
XCosGrantWrite string `header:"x-cos-grant-write,omitempty" url:"-" xml:"-"`
|
XCosGrantWrite string `header:"x-cos-grant-write,omitempty" url:"-" xml:"-"`
|
||||||
XCosGrantFullControl string `header:"x-cos-grant-full-control,omitempty" url:"-" xml:"-"`
|
XCosGrantFullControl string `header:"x-cos-grant-full-control,omitempty" url:"-" xml:"-"`
|
||||||
|
XCosGrantReadACP string `header:"x-cos-grant-read-acp,omitempty" url:"-" xml:"-"`
|
||||||
|
XCosGrantWriteACP string `header:"x-cos-grant-write-acp,omitempty" url:"-" xml:"-"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// ACLGrantee is the param of ACLGrant
|
// ACLGrantee is the param of ACLGrant
|
||||||
|
|||||||
@@ -184,6 +184,15 @@ func (s *CosTestSuite) TestGetBucket() {
|
|||||||
assert.Nil(s.T(), err, "GetBucket Failed")
|
assert.Nil(s.T(), err, "GetBucket Failed")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *CosTestSuite) TestGetObjectVersions() {
|
||||||
|
opt := &cos.BucketGetObjectVersionsOptions {
|
||||||
|
Prefix: "中文",
|
||||||
|
MaxKeys: 3,
|
||||||
|
}
|
||||||
|
_, _, err := s.Client.Bucket.GetObjectVersions(context.Background(), opt)
|
||||||
|
assert.Nil(s.T(), err, "GetObjectVersions Failed")
|
||||||
|
}
|
||||||
|
|
||||||
func (s *CosTestSuite) TestGetBucketLocation() {
|
func (s *CosTestSuite) TestGetBucketLocation() {
|
||||||
v, _, err := s.Client.Bucket.GetLocation(context.Background())
|
v, _, err := s.Client.Bucket.GetLocation(context.Background())
|
||||||
assert.Nil(s.T(), err, "GetLocation Failed")
|
assert.Nil(s.T(), err, "GetLocation Failed")
|
||||||
|
|||||||
38
example/bucket/getLogging.go
Normal file
38
example/bucket/getLogging.go
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
"net/url"
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5"
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
u, _ := url.Parse("https://bj-1259654469.cos.ap-beijing.myqcloud.com")
|
||||||
|
b := &cos.BaseURL{
|
||||||
|
BucketURL: u,
|
||||||
|
}
|
||||||
|
c := cos.NewClient(b, &http.Client{
|
||||||
|
Transport: &cos.AuthorizationTransport{
|
||||||
|
SecretID: os.Getenv("COS_SECRETID"),
|
||||||
|
SecretKey: os.Getenv("COS_SECRETKEY"),
|
||||||
|
Transport: &debug.DebugRequestTransport{
|
||||||
|
RequestHeader: true,
|
||||||
|
RequestBody: true,
|
||||||
|
ResponseHeader: true,
|
||||||
|
ResponseBody: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
v, _, err := c.Bucket.GetLogging(context.Background())
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
fmt.Printf("%+v\n", v.LoggingEnabled)
|
||||||
|
}
|
||||||
64
example/bucket/getObjectVersion.go
Normal file
64
example/bucket/getObjectVersion.go
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"net/url"
|
||||||
|
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5"
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
u, _ := url.Parse("https://test-1259654469.cos.ap-guangzhou.myqcloud.com")
|
||||||
|
b := &cos.BaseURL{
|
||||||
|
BucketURL: u,
|
||||||
|
}
|
||||||
|
c := cos.NewClient(b, &http.Client{
|
||||||
|
Transport: &cos.AuthorizationTransport{
|
||||||
|
SecretID: os.Getenv("COS_SECRETID"),
|
||||||
|
SecretKey: os.Getenv("COS_SECRETKEY"),
|
||||||
|
Transport: &debug.DebugRequestTransport{
|
||||||
|
RequestHeader: true,
|
||||||
|
RequestBody: true,
|
||||||
|
ResponseHeader: true,
|
||||||
|
ResponseBody: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
opt := &cos.BucketGetObjectVersionsOptions{
|
||||||
|
Delimiter: "/",
|
||||||
|
MaxKeys: 1,
|
||||||
|
}
|
||||||
|
v, _, err := c.Bucket.GetObjectVersions(context.Background(), opt)
|
||||||
|
log_status(err)
|
||||||
|
|
||||||
|
for _, c := range v.Version {
|
||||||
|
fmt.Printf("%v, %v, %v\n", c.Key, c.Size, c.IsLatest)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
92
example/bucket/origin.go
Normal file
92
example/bucket/origin.go
Normal file
@@ -0,0 +1,92 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
"net/http"
|
||||||
|
"net/url"
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5"
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Println(err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
u, _ := url.Parse("https://test-1259654469.cos.ap-guangzhou.myqcloud.com")
|
||||||
|
b := &cos.BaseURL{
|
||||||
|
BucketURL: u,
|
||||||
|
}
|
||||||
|
c := cos.NewClient(b, &http.Client{
|
||||||
|
Transport: &cos.AuthorizationTransport{
|
||||||
|
SecretID: os.Getenv("COS_SECRETID"),
|
||||||
|
SecretKey: os.Getenv("COS_SECRETKEY"),
|
||||||
|
Transport: &debug.DebugRequestTransport{
|
||||||
|
RequestHeader: true,
|
||||||
|
RequestBody: true,
|
||||||
|
ResponseHeader: true,
|
||||||
|
ResponseBody: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
opt := &cos.BucketPutOriginOptions{
|
||||||
|
Rule: []cos.BucketOriginRule{
|
||||||
|
{
|
||||||
|
OriginType: "Proxy",
|
||||||
|
OriginCondition: &cos.BucketOriginCondition{
|
||||||
|
HTTPStatusCode: "404",
|
||||||
|
Prefix: "",
|
||||||
|
},
|
||||||
|
OriginParameter: &cos.BucketOriginParameter{
|
||||||
|
Protocol: "FOLLOW",
|
||||||
|
FollowQueryString: true,
|
||||||
|
HttpHeader: &cos.BucketOriginHttpHeader{
|
||||||
|
NewHttpHeaders: []cos.OriginHttpHeader{
|
||||||
|
{
|
||||||
|
Key: "x-cos-ContentType",
|
||||||
|
Value: "csv",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
FollowHttpHeaders: []cos.OriginHttpHeader{
|
||||||
|
{
|
||||||
|
Key: "Content-Type",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
FollowRedirection: true,
|
||||||
|
},
|
||||||
|
OriginInfo: &cos.BucketOriginInfo{
|
||||||
|
HostInfo: "examplebucket-1250000000.cos.ap-shanghai.myqcloud.com",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err := c.Bucket.PutOrigin(context.Background(), opt)
|
||||||
|
log_status(err)
|
||||||
|
res, _, err := c.Bucket.GetOrigin(context.Background())
|
||||||
|
log_status(err)
|
||||||
|
fmt.Printf("%+v\n", res)
|
||||||
|
fmt.Printf("%+v\n", res.Rule)
|
||||||
|
_, err = c.Bucket.DeleteOrigin(context.Background())
|
||||||
|
log_status(err)
|
||||||
|
}
|
||||||
@@ -12,6 +12,25 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("http://alanbj-1251668577.cos.ap-beijing.myqcloud.com")
|
u, _ := url.Parse("http://alanbj-1251668577.cos.ap-beijing.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
@@ -37,8 +56,6 @@ func main() {
|
|||||||
v, _, err := c.Object.MultiUpload(
|
v, _, err := c.Object.MultiUpload(
|
||||||
context.Background(), "test/gomulput1G", "./test1G", opt,
|
context.Background(), "test/gomulput1G", "./test1G", opt,
|
||||||
)
|
)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Println(v)
|
fmt.Println(v)
|
||||||
}
|
}
|
||||||
@@ -12,6 +12,25 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
@@ -30,14 +49,10 @@ func main() {
|
|||||||
|
|
||||||
name := "test_multipart.txt"
|
name := "test_multipart.txt"
|
||||||
v, _, err := c.Object.InitiateMultipartUpload(context.Background(), name, nil)
|
v, _, err := c.Object.InitiateMultipartUpload(context.Background(), name, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Printf("%s\n", v.UploadID)
|
fmt.Printf("%s\n", v.UploadID)
|
||||||
|
|
||||||
resp, err := c.Object.AbortMultipartUpload(context.Background(), name, v.UploadID)
|
resp, err := c.Object.AbortMultipartUpload(context.Background(), name, v.UploadID)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Printf("%s\n", resp.Status)
|
fmt.Printf("%s\n", resp.Status)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,15 +17,15 @@ func log_status(err error) {
|
|||||||
}
|
}
|
||||||
if cos.IsNotFoundError(err) {
|
if cos.IsNotFoundError(err) {
|
||||||
// WARN
|
// WARN
|
||||||
fmt.Println("Resource is not existed")
|
fmt.Println("WARN: Resource is not existed")
|
||||||
} else if e, ok := cos.IsCOSError(err); ok {
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
fmt.Printf("Code: %v\n", e.Code)
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
fmt.Printf("Message: %v\n", e.Message)
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
fmt.Printf("Resource: %v\n", e.Resource)
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
fmt.Printf("RequestId: %v\n", e.RequestID)
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
// ERROR
|
// ERROR
|
||||||
} else {
|
} else {
|
||||||
fmt.Println(err)
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
// ERROR
|
// ERROR
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,11 +14,28 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func initUpload(c *cos.Client, name string) *cos.InitiateMultipartUploadResult {
|
func initUpload(c *cos.Client, name string) *cos.InitiateMultipartUploadResult {
|
||||||
v, _, err := c.Object.InitiateMultipartUpload(context.Background(), name, nil)
|
v, _, err := c.Object.InitiateMultipartUpload(context.Background(), name, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Printf("%#v\n", v)
|
fmt.Printf("%#v\n", v)
|
||||||
return v
|
return v
|
||||||
}
|
}
|
||||||
@@ -27,7 +44,7 @@ func uploadPart(c *cos.Client, name string, uploadID string, blockSize, n int) s
|
|||||||
|
|
||||||
b := make([]byte, blockSize)
|
b := make([]byte, blockSize)
|
||||||
if _, err := rand.Read(b); err != nil {
|
if _, err := rand.Read(b); err != nil {
|
||||||
panic(err)
|
log_status(err)
|
||||||
}
|
}
|
||||||
s := fmt.Sprintf("%X", b)
|
s := fmt.Sprintf("%X", b)
|
||||||
f := strings.NewReader(s)
|
f := strings.NewReader(s)
|
||||||
@@ -35,15 +52,13 @@ func uploadPart(c *cos.Client, name string, uploadID string, blockSize, n int) s
|
|||||||
resp, err := c.Object.UploadPart(
|
resp, err := c.Object.UploadPart(
|
||||||
context.Background(), name, uploadID, n, f, nil,
|
context.Background(), name, uploadID, n, f, nil,
|
||||||
)
|
)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Printf("%s\n", resp.Status)
|
fmt.Printf("%s\n", resp.Status)
|
||||||
return resp.Header.Get("Etag")
|
return resp.Header.Get("Etag")
|
||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1259654469.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
c := cos.NewClient(b, &http.Client{
|
c := cos.NewClient(b, &http.Client{
|
||||||
Transport: &cos.AuthorizationTransport{
|
Transport: &cos.AuthorizationTransport{
|
||||||
@@ -86,9 +101,7 @@ func main() {
|
|||||||
v, resp, err := c.Object.CompleteMultipartUpload(
|
v, resp, err := c.Object.CompleteMultipartUpload(
|
||||||
context.Background(), name, uploadID, opt,
|
context.Background(), name, uploadID, opt,
|
||||||
)
|
)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Printf("%s\n", resp.Status)
|
fmt.Printf("%s\n", resp.Status)
|
||||||
fmt.Printf("%#v\n", v)
|
fmt.Printf("%#v\n", v)
|
||||||
fmt.Printf("%s\n", v.Location)
|
fmt.Printf("%s\n", v.Location)
|
||||||
|
|||||||
@@ -16,8 +16,27 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1259654469.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
c := cos.NewClient(b, &http.Client{
|
c := cos.NewClient(b, &http.Client{
|
||||||
Transport: &cos.AuthorizationTransport{
|
Transport: &cos.AuthorizationTransport{
|
||||||
@@ -37,23 +56,18 @@ func main() {
|
|||||||
f := strings.NewReader(expected)
|
f := strings.NewReader(expected)
|
||||||
|
|
||||||
_, err := c.Object.Put(context.Background(), source, f, nil)
|
_, err := c.Object.Put(context.Background(), source, f, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
soruceURL := fmt.Sprintf("%s/%s", u.Host, source)
|
soruceURL := fmt.Sprintf("%s/%s", u.Host, source)
|
||||||
dest := fmt.Sprintf("test/objectMove_%d.go", time.Now().Nanosecond())
|
dest := fmt.Sprintf("test/objectMove_%d.go", time.Now().Nanosecond())
|
||||||
//opt := &cos.ObjectCopyOptions{}
|
//opt := &cos.ObjectCopyOptions{}
|
||||||
res, _, err := c.Object.Copy(context.Background(), dest, soruceURL, nil)
|
res, _, err := c.Object.Copy(context.Background(), dest, soruceURL, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Printf("%+v\n\n", res)
|
fmt.Printf("%+v\n\n", res)
|
||||||
|
|
||||||
resp, err := c.Object.Get(context.Background(), dest, nil)
|
resp, err := c.Object.Get(context.Background(), dest, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
bs, _ := ioutil.ReadAll(resp.Body)
|
bs, _ := ioutil.ReadAll(resp.Body)
|
||||||
resp.Body.Close()
|
resp.Body.Close()
|
||||||
result := string(bs)
|
result := string(bs)
|
||||||
|
|||||||
@@ -13,11 +13,28 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func initUpload(c *cos.Client, name string) *cos.InitiateMultipartUploadResult {
|
func initUpload(c *cos.Client, name string) *cos.InitiateMultipartUploadResult {
|
||||||
v, _, err := c.Object.InitiateMultipartUpload(context.Background(), name, nil)
|
v, _, err := c.Object.InitiateMultipartUpload(context.Background(), name, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Printf("%#v\n", v)
|
fmt.Printf("%#v\n", v)
|
||||||
return v
|
return v
|
||||||
}
|
}
|
||||||
@@ -46,9 +63,7 @@ func main() {
|
|||||||
opt := &cos.ObjectCopyPartOptions{}
|
opt := &cos.ObjectCopyPartOptions{}
|
||||||
res, _, err := c.Object.CopyPart(
|
res, _, err := c.Object.CopyPart(
|
||||||
context.Background(), name, uploadID, 1, sourceUrl, opt)
|
context.Background(), name, uploadID, 1, sourceUrl, opt)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Println("ETag:", res.ETag)
|
fmt.Println("ETag:", res.ETag)
|
||||||
|
|
||||||
completeOpt := &cos.CompleteMultipartUploadOptions{}
|
completeOpt := &cos.CompleteMultipartUploadOptions{}
|
||||||
@@ -59,9 +74,7 @@ func main() {
|
|||||||
v, resp, err := c.Object.CompleteMultipartUpload(
|
v, resp, err := c.Object.CompleteMultipartUpload(
|
||||||
context.Background(), name, uploadID, completeOpt,
|
context.Background(), name, uploadID, completeOpt,
|
||||||
)
|
)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Printf("%s\n", resp.Status)
|
fmt.Printf("%s\n", resp.Status)
|
||||||
fmt.Printf("%#v\n", v)
|
fmt.Printf("%#v\n", v)
|
||||||
fmt.Printf("%s\n", v.Location)
|
fmt.Printf("%s\n", v.Location)
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"fmt"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
@@ -11,6 +12,25 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
@@ -30,7 +50,5 @@ func main() {
|
|||||||
name := "test/objectPut.go"
|
name := "test/objectPut.go"
|
||||||
|
|
||||||
_, err := c.Object.Delete(context.Background(), name, nil)
|
_, err := c.Object.Delete(context.Background(), name, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -18,10 +18,29 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func genBigData(blockSize int) []byte {
|
func genBigData(blockSize int) []byte {
|
||||||
b := make([]byte, blockSize)
|
b := make([]byte, blockSize)
|
||||||
if _, err := rand.Read(b); err != nil {
|
if _, err := rand.Read(b); err != nil {
|
||||||
panic(err)
|
log_status(err)
|
||||||
}
|
}
|
||||||
return b
|
return b
|
||||||
}
|
}
|
||||||
@@ -46,7 +65,7 @@ func uploadMulti(c *cos.Client) []string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1259654469.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
c := cos.NewClient(b, &http.Client{
|
c := cos.NewClient(b, &http.Client{
|
||||||
Transport: &cos.AuthorizationTransport{
|
Transport: &cos.AuthorizationTransport{
|
||||||
@@ -89,9 +108,7 @@ func main() {
|
|||||||
})
|
})
|
||||||
|
|
||||||
v, _, err := c.Object.DeleteMulti(ctx, opt)
|
v, _, err := c.Object.DeleteMulti(ctx, opt)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, x := range v.DeletedObjects {
|
for _, x := range v.DeletedObjects {
|
||||||
fmt.Printf("deleted %s\n", x.Key)
|
fmt.Printf("deleted %s\n", x.Key)
|
||||||
|
|||||||
@@ -13,6 +13,25 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
@@ -32,31 +51,26 @@ func main() {
|
|||||||
// Case1 Download object into ReadCloser(). the body needs to be closed
|
// Case1 Download object into ReadCloser(). the body needs to be closed
|
||||||
name := "test/hello.txt"
|
name := "test/hello.txt"
|
||||||
resp, err := c.Object.Get(context.Background(), name, nil)
|
resp, err := c.Object.Get(context.Background(), name, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
bs, _ := ioutil.ReadAll(resp.Body)
|
bs, _ := ioutil.ReadAll(resp.Body)
|
||||||
resp.Body.Close()
|
resp.Body.Close()
|
||||||
fmt.Printf("%s\n", string(bs))
|
fmt.Printf("%s\n", string(bs))
|
||||||
|
|
||||||
// Case2 Download object to local file. the body needs to be closed
|
// Case2 Download object to local file. the body needs to be closed
|
||||||
fd, err := os.OpenFile("hello.txt", os.O_WRONLY|os.O_CREATE, 0660)
|
fd, err := os.OpenFile("hello.txt", os.O_WRONLY|os.O_CREATE, 0660)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
defer fd.Close()
|
defer fd.Close()
|
||||||
resp, err = c.Object.Get(context.Background(), name, nil)
|
resp, err = c.Object.Get(context.Background(), name, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
io.Copy(fd, resp.Body)
|
io.Copy(fd, resp.Body)
|
||||||
resp.Body.Close()
|
resp.Body.Close()
|
||||||
|
|
||||||
// Case3 Download object to local file path
|
// Case3 Download object to local file path
|
||||||
_, err = c.Object.GetToFile(context.Background(), name, "hello_1.txt", nil)
|
_, err = c.Object.GetToFile(context.Background(), name, "hello_1.txt", nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Case4 Download object with range header, can used to concurrent download
|
// Case4 Download object with range header, can used to concurrent download
|
||||||
opt := &cos.ObjectGetOptions{
|
opt := &cos.ObjectGetOptions{
|
||||||
@@ -64,9 +78,7 @@ func main() {
|
|||||||
Range: "bytes=0-3",
|
Range: "bytes=0-3",
|
||||||
}
|
}
|
||||||
resp, err = c.Object.Get(context.Background(), name, opt)
|
resp, err = c.Object.Get(context.Background(), name, opt)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
bs, _ = ioutil.ReadAll(resp.Body)
|
bs, _ = ioutil.ReadAll(resp.Body)
|
||||||
resp.Body.Close()
|
resp.Body.Close()
|
||||||
fmt.Printf("%s\n", string(bs))
|
fmt.Printf("%s\n", string(bs))
|
||||||
|
|||||||
@@ -12,8 +12,27 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1259654469.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
c := cos.NewClient(b, &http.Client{
|
c := cos.NewClient(b, &http.Client{
|
||||||
Transport: &cos.AuthorizationTransport{
|
Transport: &cos.AuthorizationTransport{
|
||||||
@@ -30,9 +49,7 @@ func main() {
|
|||||||
|
|
||||||
name := "test/hello.txt"
|
name := "test/hello.txt"
|
||||||
v, _, err := c.Object.GetACL(context.Background(), name)
|
v, _, err := c.Object.GetACL(context.Background(), name)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
for _, a := range v.AccessControlList {
|
for _, a := range v.AccessControlList {
|
||||||
fmt.Printf("%s, %s, %s\n", a.Grantee.Type, a.Grantee.ID, a.Permission)
|
fmt.Printf("%s, %s, %s\n", a.Grantee.Type, a.Grantee.ID, a.Permission)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,6 +11,25 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5"
|
"github.com/tencentyun/cos-go-sdk-v5"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func upload(c *cos.Client, name string) {
|
func upload(c *cos.Client, name string) {
|
||||||
f := strings.NewReader("test")
|
f := strings.NewReader("test")
|
||||||
f = strings.NewReader("test xxx")
|
f = strings.NewReader("test xxx")
|
||||||
@@ -35,10 +54,7 @@ func main() {
|
|||||||
upload(c, name)
|
upload(c, name)
|
||||||
|
|
||||||
resp, err := c.Object.Get(context.Background(), name, nil)
|
resp, err := c.Object.Get(context.Background(), name, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
bs, _ := ioutil.ReadAll(resp.Body)
|
bs, _ := ioutil.ReadAll(resp.Body)
|
||||||
defer resp.Body.Close()
|
defer resp.Body.Close()
|
||||||
fmt.Printf("%s\n", string(bs))
|
fmt.Printf("%s\n", string(bs))
|
||||||
|
|||||||
@@ -14,6 +14,25 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
ak := os.Getenv("COS_SECRETID")
|
ak := os.Getenv("COS_SECRETID")
|
||||||
sk := os.Getenv("COS_SECRETKEY")
|
sk := os.Getenv("COS_SECRETKEY")
|
||||||
@@ -38,22 +57,17 @@ func main() {
|
|||||||
|
|
||||||
// Normal header way to get object
|
// Normal header way to get object
|
||||||
resp, err := c.Object.Get(ctx, name, nil)
|
resp, err := c.Object.Get(ctx, name, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
bs, _ := ioutil.ReadAll(resp.Body)
|
bs, _ := ioutil.ReadAll(resp.Body)
|
||||||
resp.Body.Close()
|
resp.Body.Close()
|
||||||
|
|
||||||
// Get presigned
|
// Get presigned
|
||||||
presignedURL, err := c.Object.GetPresignedURL(ctx, http.MethodGet, name, ak, sk, time.Hour, nil)
|
presignedURL, err := c.Object.GetPresignedURL(ctx, http.MethodGet, name, ak, sk, time.Hour, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
// Get object by presinged url
|
// Get object by presinged url
|
||||||
resp2, err := http.Get(presignedURL.String())
|
resp2, err := http.Get(presignedURL.String())
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
bs2, _ := ioutil.ReadAll(resp2.Body)
|
bs2, _ := ioutil.ReadAll(resp2.Body)
|
||||||
resp2.Body.Close()
|
resp2.Body.Close()
|
||||||
fmt.Printf("result2 is : %s\n", string(bs2))
|
fmt.Printf("result2 is : %s\n", string(bs2))
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"fmt"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
@@ -11,6 +12,25 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
@@ -29,7 +49,5 @@ func main() {
|
|||||||
|
|
||||||
name := "test/hello.txt"
|
name := "test/hello.txt"
|
||||||
_, err := c.Object.Head(context.Background(), name, nil)
|
_, err := c.Object.Head(context.Background(), name, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,6 +13,25 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
@@ -31,8 +50,6 @@ func main() {
|
|||||||
|
|
||||||
name := "test_multipart" + time.Now().Format(time.RFC3339)
|
name := "test_multipart" + time.Now().Format(time.RFC3339)
|
||||||
v, _, err := c.Object.InitiateMultipartUpload(context.Background(), name, nil)
|
v, _, err := c.Object.InitiateMultipartUpload(context.Background(), name, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Printf("%s\n", v.UploadID)
|
fmt.Printf("%s\n", v.UploadID)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,11 +14,28 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func initUpload(c *cos.Client, name string) *cos.InitiateMultipartUploadResult {
|
func initUpload(c *cos.Client, name string) *cos.InitiateMultipartUploadResult {
|
||||||
v, _, err := c.Object.InitiateMultipartUpload(context.Background(), name, nil)
|
v, _, err := c.Object.InitiateMultipartUpload(context.Background(), name, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Printf("%#v\n", v)
|
fmt.Printf("%#v\n", v)
|
||||||
return v
|
return v
|
||||||
}
|
}
|
||||||
@@ -27,7 +44,7 @@ func uploadPart(c *cos.Client, name string, uploadID string, blockSize, n int) s
|
|||||||
|
|
||||||
b := make([]byte, blockSize)
|
b := make([]byte, blockSize)
|
||||||
if _, err := rand.Read(b); err != nil {
|
if _, err := rand.Read(b); err != nil {
|
||||||
panic(err)
|
log_status(err)
|
||||||
}
|
}
|
||||||
s := fmt.Sprintf("%X", b)
|
s := fmt.Sprintf("%X", b)
|
||||||
f := strings.NewReader(s)
|
f := strings.NewReader(s)
|
||||||
@@ -35,9 +52,7 @@ func uploadPart(c *cos.Client, name string, uploadID string, blockSize, n int) s
|
|||||||
resp, err := c.Object.UploadPart(
|
resp, err := c.Object.UploadPart(
|
||||||
context.Background(), name, uploadID, n, f, nil,
|
context.Background(), name, uploadID, n, f, nil,
|
||||||
)
|
)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Printf("%s\n", resp.Status)
|
fmt.Printf("%s\n", resp.Status)
|
||||||
return resp.Header.Get("Etag")
|
return resp.Header.Get("Etag")
|
||||||
}
|
}
|
||||||
@@ -73,7 +88,7 @@ func main() {
|
|||||||
// }
|
// }
|
||||||
v, _, err := c.Object.ListParts(ctx, name, uploadID, nil)
|
v, _, err := c.Object.ListParts(ctx, name, uploadID, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
log_status(err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
for _, p := range v.Parts {
|
for _, p := range v.Parts {
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"fmt"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
@@ -11,6 +12,25 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
@@ -33,7 +53,5 @@ func main() {
|
|||||||
AccessControlRequestMethod: "PUT",
|
AccessControlRequestMethod: "PUT",
|
||||||
}
|
}
|
||||||
_, err := c.Object.Options(context.Background(), name, opt)
|
_, err := c.Object.Options(context.Background(), name, opt)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
44
example/object/presigned_url_with_token.go
Normal file
44
example/object/presigned_url_with_token.go
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
"net/http"
|
||||||
|
"net/url"
|
||||||
|
"os"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5"
|
||||||
|
)
|
||||||
|
|
||||||
|
type URLToken struct {
|
||||||
|
SessionToken string `url:"x-cos-security-token,omitempty" header:"-"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
// 替换成您的临时密钥
|
||||||
|
tak := os.Getenv("COS_SECRETID")
|
||||||
|
tsk := os.Getenv("COS_SECRETKEY")
|
||||||
|
token := &URLToken{
|
||||||
|
SessionToken: "<token>",
|
||||||
|
}
|
||||||
|
u, _ := url.Parse("https://test-1259654469.cos.ap-guangzhou.myqcloud.com")
|
||||||
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
|
c := cos.NewClient(b, &http.Client{})
|
||||||
|
|
||||||
|
name := "exampleobject"
|
||||||
|
ctx := context.Background()
|
||||||
|
|
||||||
|
// Get presigned
|
||||||
|
presignedURL, err := c.Object.GetPresignedURL(ctx, http.MethodGet, name, tak, tsk, time.Hour, token)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Printf("Error: %v\n", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
// Get object by presinged url
|
||||||
|
_, err = http.Get(presignedURL.String())
|
||||||
|
if err != nil {
|
||||||
|
fmt.Printf("Error: %v\n", err)
|
||||||
|
}
|
||||||
|
fmt.Println(presignedURL.String())
|
||||||
|
}
|
||||||
@@ -2,6 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"fmt"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
"strings"
|
"strings"
|
||||||
@@ -12,8 +13,27 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1259654469.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
c := cos.NewClient(b, &http.Client{
|
c := cos.NewClient(b, &http.Client{
|
||||||
Transport: &cos.AuthorizationTransport{
|
Transport: &cos.AuthorizationTransport{
|
||||||
@@ -34,9 +54,7 @@ func main() {
|
|||||||
f := strings.NewReader("test")
|
f := strings.NewReader("test")
|
||||||
|
|
||||||
_, err := c.Object.Put(context.Background(), name, f, nil)
|
_, err := c.Object.Put(context.Background(), name, f, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Case2 put object with the options
|
// Case2 put object with the options
|
||||||
name = "test/put_option.go"
|
name = "test/put_option.go"
|
||||||
@@ -51,14 +69,9 @@ func main() {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
_, err = c.Object.Put(context.Background(), name, f, opt)
|
_, err = c.Object.Put(context.Background(), name, f, opt)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Case3 put object by local file path
|
// Case3 put object by local file path
|
||||||
_, err = c.Object.PutFromFile(context.Background(), name, "./test", nil)
|
_, err = c.Object.PutFromFile(context.Background(), name, "./test", nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"fmt"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
@@ -11,6 +12,25 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
@@ -34,9 +54,7 @@ func main() {
|
|||||||
}
|
}
|
||||||
name := "test/hello.txt"
|
name := "test/hello.txt"
|
||||||
_, err := c.Object.PutACL(context.Background(), name, opt)
|
_, err := c.Object.PutACL(context.Background(), name, opt)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// with body
|
// with body
|
||||||
opt = &cos.ObjectPutACLOptions{
|
opt = &cos.ObjectPutACLOptions{
|
||||||
@@ -58,7 +76,5 @@ func main() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
_, err = c.Object.PutACL(context.Background(), name, opt)
|
_, err = c.Object.PutACL(context.Background(), name, opt)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
@@ -10,6 +11,25 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
@@ -35,7 +55,5 @@ func main() {
|
|||||||
}
|
}
|
||||||
name := "archivetest"
|
name := "archivetest"
|
||||||
_, err := c.Object.PostRestore(context.Background(), name, opt)
|
_, err := c.Object.PostRestore(context.Background(), name, opt)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
81
example/object/sse_c.go
Normal file
81
example/object/sse_c.go
Normal file
@@ -0,0 +1,81 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"net/http"
|
||||||
|
"net/url"
|
||||||
|
"os"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5"
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
u, _ := url.Parse("https://testcd-1259654469.cos.ap-chengdu.myqcloud.com")
|
||||||
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
|
c := cos.NewClient(b, &http.Client{
|
||||||
|
Transport: &cos.AuthorizationTransport{
|
||||||
|
SecretID: os.Getenv("COS_SECRETID"),
|
||||||
|
SecretKey: os.Getenv("COS_SECRETKEY"),
|
||||||
|
Transport: &debug.DebugRequestTransport{
|
||||||
|
RequestHeader: true,
|
||||||
|
// Notice when put a large file and set need the request body, might happend out of memory error.
|
||||||
|
RequestBody: false,
|
||||||
|
ResponseHeader: true,
|
||||||
|
ResponseBody: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
opt := &cos.ObjectPutOptions{
|
||||||
|
ObjectPutHeaderOptions: &cos.ObjectPutHeaderOptions{
|
||||||
|
ContentType: "text/html",
|
||||||
|
XCosSSECustomerAglo: "AES256",
|
||||||
|
XCosSSECustomerKey: "MDEyMzQ1Njc4OUFCQ0RFRjAxMjM0NTY3ODlBQkNERUY=",
|
||||||
|
XCosSSECustomerKeyMD5: "U5L61r7jcwdNvT7frmUG8g==",
|
||||||
|
},
|
||||||
|
ACLHeaderOptions: &cos.ACLHeaderOptions{},
|
||||||
|
}
|
||||||
|
name := "PutFromGoWithSSE-C"
|
||||||
|
content := "Put Object From Go With SSE-C"
|
||||||
|
f := strings.NewReader(content)
|
||||||
|
_, err := c.Object.Put(context.Background(), name, f, opt)
|
||||||
|
log_status(err)
|
||||||
|
|
||||||
|
getopt := &cos.ObjectGetOptions{
|
||||||
|
XCosSSECustomerAglo: "AES256",
|
||||||
|
XCosSSECustomerKey: "MDEyMzQ1Njc4OUFCQ0RFRjAxMjM0NTY3ODlBQkNERUY=",
|
||||||
|
XCosSSECustomerKeyMD5: "U5L61r7jcwdNvT7frmUG8g==",
|
||||||
|
}
|
||||||
|
var resp *cos.Response
|
||||||
|
resp, err = c.Object.Get(context.Background(), name, getopt)
|
||||||
|
log_status(err)
|
||||||
|
|
||||||
|
bodyBytes, _ := ioutil.ReadAll(resp.Body)
|
||||||
|
bodyContent := string(bodyBytes)
|
||||||
|
if bodyContent != content {
|
||||||
|
log_status(errors.New("Content inconsistency"))
|
||||||
|
}
|
||||||
|
}
|
||||||
75
example/object/sse_cos.go
Normal file
75
example/object/sse_cos.go
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"net/http"
|
||||||
|
"net/url"
|
||||||
|
"os"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5"
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
u, _ := url.Parse("https://test-1259654469.cos.ap-guangzhou.myqcloud.com")
|
||||||
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
|
c := cos.NewClient(b, &http.Client{
|
||||||
|
Transport: &cos.AuthorizationTransport{
|
||||||
|
SecretID: os.Getenv("COS_SECRETID"),
|
||||||
|
SecretKey: os.Getenv("COS_SECRETKEY"),
|
||||||
|
Transport: &debug.DebugRequestTransport{
|
||||||
|
RequestHeader: true,
|
||||||
|
// Notice when put a large file and set need the request body, might happend out of memory error.
|
||||||
|
RequestBody: false,
|
||||||
|
ResponseHeader: true,
|
||||||
|
ResponseBody: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
opt := &cos.ObjectPutOptions{
|
||||||
|
ObjectPutHeaderOptions: &cos.ObjectPutHeaderOptions{
|
||||||
|
ContentType: "text/html",
|
||||||
|
XCosServerSideEncryption: "AES256",
|
||||||
|
},
|
||||||
|
ACLHeaderOptions: &cos.ACLHeaderOptions{},
|
||||||
|
}
|
||||||
|
name := "PutFromGoWithSSE-COS"
|
||||||
|
content := "Put Object From Go With SSE-COS"
|
||||||
|
f := strings.NewReader(content)
|
||||||
|
_, err := c.Object.Put(context.Background(), name, f, opt)
|
||||||
|
log_status(err)
|
||||||
|
|
||||||
|
getopt := &cos.ObjectGetOptions{}
|
||||||
|
var resp *cos.Response
|
||||||
|
resp, err = c.Object.Get(context.Background(), name, getopt)
|
||||||
|
log_status(err)
|
||||||
|
|
||||||
|
bodyBytes, _ := ioutil.ReadAll(resp.Body)
|
||||||
|
bodyContent := string(bodyBytes)
|
||||||
|
if bodyContent != content {
|
||||||
|
log_status(errors.New("Content inconsistency"))
|
||||||
|
}
|
||||||
|
}
|
||||||
75
example/object/tagging.go
Normal file
75
example/object/tagging.go
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
"net/url"
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5"
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
u, _ := url.Parse("https://test-1259654469.cos.ap-guangzhou.myqcloud.com")
|
||||||
|
b := &cos.BaseURL{
|
||||||
|
BucketURL: u,
|
||||||
|
}
|
||||||
|
c := cos.NewClient(b, &http.Client{
|
||||||
|
Transport: &cos.AuthorizationTransport{
|
||||||
|
SecretID: os.Getenv("COS_SECRETID"),
|
||||||
|
SecretKey: os.Getenv("COS_SECRETKEY"),
|
||||||
|
Transport: &debug.DebugRequestTransport{
|
||||||
|
RequestHeader: true,
|
||||||
|
RequestBody: true,
|
||||||
|
ResponseHeader: true,
|
||||||
|
ResponseBody: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
name := "test"
|
||||||
|
|
||||||
|
opt := &cos.ObjectPutTaggingOptions{
|
||||||
|
TagSet: []cos.ObjectTaggingTag{
|
||||||
|
{
|
||||||
|
Key: "test_k2",
|
||||||
|
Value: "test_v2",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Key: "test_k3",
|
||||||
|
Value: "test_v3",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err := c.Object.PutTagging(context.Background(), name, opt)
|
||||||
|
log_status(err)
|
||||||
|
|
||||||
|
res, _, err := c.Object.GetTagging(context.Background(), name)
|
||||||
|
log_status(err)
|
||||||
|
fmt.Printf("%v\n", res.TagSet)
|
||||||
|
|
||||||
|
_, err = c.Object.DeleteTagging(context.Background(), name)
|
||||||
|
log_status(err)
|
||||||
|
}
|
||||||
@@ -12,6 +12,25 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1259654469.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1259654469.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
@@ -33,8 +52,6 @@ func main() {
|
|||||||
v, _, err := c.Object.Upload(
|
v, _, err := c.Object.Upload(
|
||||||
context.Background(), "gomulput1G", "./test1G", nil,
|
context.Background(), "gomulput1G", "./test1G", nil,
|
||||||
)
|
)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Println(v)
|
fmt.Println(v)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,6 +13,25 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
u, _ := url.Parse("https://test-1253846586.cos.ap-guangzhou.myqcloud.com")
|
||||||
b := &cos.BaseURL{BucketURL: u}
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
@@ -32,11 +51,13 @@ func main() {
|
|||||||
name := "test/uploadFile.go"
|
name := "test/uploadFile.go"
|
||||||
f, err := os.Open(os.Args[0])
|
f, err := os.Open(os.Args[0])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
log_status(err)
|
||||||
|
return
|
||||||
}
|
}
|
||||||
s, err := f.Stat()
|
s, err := f.Stat()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
log_status(err)
|
||||||
|
return
|
||||||
}
|
}
|
||||||
fmt.Println(s.Size())
|
fmt.Println(s.Size())
|
||||||
opt := &cos.ObjectPutOptions{
|
opt := &cos.ObjectPutOptions{
|
||||||
@@ -47,7 +68,5 @@ func main() {
|
|||||||
//opt.ContentLength = int(s.Size())
|
//opt.ContentLength = int(s.Size())
|
||||||
|
|
||||||
_, err = c.Object.Put(context.Background(), name, f, opt)
|
_, err = c.Object.Put(context.Background(), name, f, opt)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,11 +14,28 @@ import (
|
|||||||
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func log_status(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cos.IsNotFoundError(err) {
|
||||||
|
// WARN
|
||||||
|
fmt.Println("WARN: Resource is not existed")
|
||||||
|
} else if e, ok := cos.IsCOSError(err); ok {
|
||||||
|
fmt.Printf("ERROR: Code: %v\n", e.Code)
|
||||||
|
fmt.Printf("ERROR: Message: %v\n", e.Message)
|
||||||
|
fmt.Printf("ERROR: Resource: %v\n", e.Resource)
|
||||||
|
fmt.Printf("ERROR: RequestId: %v\n", e.RequestID)
|
||||||
|
// ERROR
|
||||||
|
} else {
|
||||||
|
fmt.Printf("ERROR: %v\n", err)
|
||||||
|
// ERROR
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func initUpload(c *cos.Client, name string) *cos.InitiateMultipartUploadResult {
|
func initUpload(c *cos.Client, name string) *cos.InitiateMultipartUploadResult {
|
||||||
v, _, err := c.Object.InitiateMultipartUpload(context.Background(), name, nil)
|
v, _, err := c.Object.InitiateMultipartUpload(context.Background(), name, nil)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
fmt.Printf("%#v\n", v)
|
fmt.Printf("%#v\n", v)
|
||||||
return v
|
return v
|
||||||
}
|
}
|
||||||
@@ -47,7 +64,5 @@ func main() {
|
|||||||
_, err := c.Object.UploadPart(
|
_, err := c.Object.UploadPart(
|
||||||
context.Background(), name, uploadID, 1, f, nil,
|
context.Background(), name, uploadID, 1, f, nil,
|
||||||
)
|
)
|
||||||
if err != nil {
|
log_status(err)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
96
example/sts/sts_v3.go
Normal file
96
example/sts/sts_v3.go
Normal file
@@ -0,0 +1,96 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5"
|
||||||
|
"github.com/tencentyun/cos-go-sdk-v5/debug"
|
||||||
|
"github.com/tencentyun/qcloud-cos-sts-sdk/go"
|
||||||
|
"net/http"
|
||||||
|
"net/url"
|
||||||
|
"os"
|
||||||
|
"strings"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
appid := "1259654469"
|
||||||
|
bucket := "test-1259654469"
|
||||||
|
c := sts.NewClient(
|
||||||
|
os.Getenv("COS_SECRETID"),
|
||||||
|
os.Getenv("COS_SECRETKEY"),
|
||||||
|
nil,
|
||||||
|
)
|
||||||
|
opt := &sts.CredentialOptions{
|
||||||
|
DurationSeconds: int64(time.Hour.Seconds()),
|
||||||
|
Region: "ap-guangzhou",
|
||||||
|
Policy: &sts.CredentialPolicy{
|
||||||
|
Statement: []sts.CredentialPolicyStatement{
|
||||||
|
{
|
||||||
|
Action: []string{
|
||||||
|
"name/cos:PostObject",
|
||||||
|
"name/cos:PutObject",
|
||||||
|
"name/cos:GetObject",
|
||||||
|
},
|
||||||
|
Effect: "allow",
|
||||||
|
Resource: []string{
|
||||||
|
//这里改成允许的路径前缀,可以根据自己网站的用户登录态判断允许上传的具体路径,例子: a.jpg 或者 a/* 或者 * (使用通配符*存在重大安全风险, 请谨慎评估使用)
|
||||||
|
"qcs::cos:ap-guangzhou:uid/" + appid + ":" + bucket + "/exampleobject",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
res, err := c.GetCredential(opt)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
fmt.Printf("%+v\n", res.Credentials)
|
||||||
|
|
||||||
|
//获取临时ak、sk、token
|
||||||
|
tAk := res.Credentials.TmpSecretID
|
||||||
|
tSk := res.Credentials.TmpSecretKey
|
||||||
|
token := res.Credentials.SessionToken
|
||||||
|
|
||||||
|
u, _ := url.Parse("https://" + bucket + ".cos.ap-guangzhou.myqcloud.com")
|
||||||
|
b := &cos.BaseURL{BucketURL: u}
|
||||||
|
client := cos.NewClient(b, &http.Client{
|
||||||
|
Transport: &cos.AuthorizationTransport{
|
||||||
|
// 使用临时密钥
|
||||||
|
SecretID: tAk,
|
||||||
|
SecretKey: tSk,
|
||||||
|
SessionToken: token,
|
||||||
|
Transport: &debug.DebugRequestTransport{
|
||||||
|
RequestHeader: true,
|
||||||
|
RequestBody: true,
|
||||||
|
ResponseHeader: true,
|
||||||
|
ResponseBody: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
name := "exampleobject"
|
||||||
|
f := strings.NewReader("test")
|
||||||
|
|
||||||
|
_, err = client.Object.Put(context.Background(), name, f, nil)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
name = "exampleobject"
|
||||||
|
f = strings.NewReader("test xxx")
|
||||||
|
optc := &cos.ObjectPutOptions{
|
||||||
|
ObjectPutHeaderOptions: &cos.ObjectPutHeaderOptions{
|
||||||
|
ContentType: "text/html",
|
||||||
|
},
|
||||||
|
ACLHeaderOptions: &cos.ACLHeaderOptions{
|
||||||
|
//XCosACL: "public-read",
|
||||||
|
XCosACL: "private",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
_, err = client.Object.Put(context.Background(), name, f, optc)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
67
object.go
67
object.go
@@ -280,6 +280,7 @@ type ObjectDeleteOptions struct {
|
|||||||
//兼容其他自定义头部
|
//兼容其他自定义头部
|
||||||
XOptionHeader *http.Header `header:"-,omitempty" url:"-" xml:"-"`
|
XOptionHeader *http.Header `header:"-,omitempty" url:"-" xml:"-"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// Delete Object请求可以将一个文件(Object)删除。
|
// Delete Object请求可以将一个文件(Object)删除。
|
||||||
//
|
//
|
||||||
// https://www.qcloud.com/document/product/436/7743
|
// https://www.qcloud.com/document/product/436/7743
|
||||||
@@ -675,3 +676,69 @@ func (s *ObjectService) Upload(ctx context.Context, name string, filepath string
|
|||||||
|
|
||||||
return v, resp, err
|
return v, resp, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type ObjectPutTaggingOptions struct {
|
||||||
|
XMLName xml.Name `xml:"Tagging"`
|
||||||
|
TagSet []ObjectTaggingTag `xml:"TagSet>Tag,omitempty"`
|
||||||
|
}
|
||||||
|
type ObjectTaggingTag BucketTaggingTag
|
||||||
|
type ObjectGetTaggingResult ObjectPutTaggingOptions
|
||||||
|
|
||||||
|
func (s *ObjectService) PutTagging(ctx context.Context, name string, opt *ObjectPutTaggingOptions, id ...string) (*Response, error) {
|
||||||
|
var u string
|
||||||
|
if len(id) == 1 {
|
||||||
|
u = fmt.Sprintf("/%s?tagging&versionId=%s", encodeURIComponent(name), id[0])
|
||||||
|
} else if len(id) == 0 {
|
||||||
|
u = fmt.Sprintf("/%s?tagging", encodeURIComponent(name))
|
||||||
|
} else {
|
||||||
|
return nil, errors.New("wrong params")
|
||||||
|
}
|
||||||
|
sendOpt := &sendOptions{
|
||||||
|
baseURL: s.client.BaseURL.BucketURL,
|
||||||
|
uri: u,
|
||||||
|
method: http.MethodPut,
|
||||||
|
body: opt,
|
||||||
|
}
|
||||||
|
resp, err := s.client.send(ctx, sendOpt)
|
||||||
|
return resp, err
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *ObjectService) GetTagging(ctx context.Context, name string, id ...string) (*ObjectGetTaggingResult, *Response, error) {
|
||||||
|
var u string
|
||||||
|
if len(id) == 1 {
|
||||||
|
u = fmt.Sprintf("/%s?tagging&versionId=%s", encodeURIComponent(name), id[0])
|
||||||
|
} else if len(id) == 0 {
|
||||||
|
u = fmt.Sprintf("/%s?tagging", encodeURIComponent(name))
|
||||||
|
} else {
|
||||||
|
return nil, nil, errors.New("wrong params")
|
||||||
|
}
|
||||||
|
|
||||||
|
var res ObjectGetTaggingResult
|
||||||
|
sendOpt := &sendOptions{
|
||||||
|
baseURL: s.client.BaseURL.BucketURL,
|
||||||
|
uri: u,
|
||||||
|
method: http.MethodGet,
|
||||||
|
result: &res,
|
||||||
|
}
|
||||||
|
resp, err := s.client.send(ctx, sendOpt)
|
||||||
|
return &res, resp, err
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *ObjectService) DeleteTagging(ctx context.Context, name string, id ...string) (*Response, error) {
|
||||||
|
var u string
|
||||||
|
if len(id) == 1 {
|
||||||
|
u = fmt.Sprintf("/%s?tagging&versionId=%s", encodeURIComponent(name), id[0])
|
||||||
|
} else if len(id) == 0 {
|
||||||
|
u = fmt.Sprintf("/%s?tagging", encodeURIComponent(name))
|
||||||
|
} else {
|
||||||
|
return nil, errors.New("wrong params")
|
||||||
|
}
|
||||||
|
|
||||||
|
sendOpt := &sendOptions{
|
||||||
|
baseURL: s.client.BaseURL.BucketURL,
|
||||||
|
uri: u,
|
||||||
|
method: http.MethodDelete,
|
||||||
|
}
|
||||||
|
resp, err := s.client.send(ctx, sendOpt)
|
||||||
|
return resp, err
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user