forked from sodafoundation/strato
/
objectput.go
106 lines (94 loc) · 3.31 KB
/
objectput.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
// Copyright 2019 The OpenSDS Authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package s3
import (
"net/http"
"strconv"
"strings"
"time"
"github.com/emicklei/go-restful"
"github.com/micro/go-log"
"github.com/opensds/multi-cloud/api/pkg/policy"
"github.com/opensds/multi-cloud/api/pkg/s3/datastore"
"github.com/opensds/multi-cloud/api/pkg/utils/constants"
. "github.com/opensds/multi-cloud/s3/pkg/exception"
"github.com/opensds/multi-cloud/s3/pkg/utils"
s3 "github.com/opensds/multi-cloud/s3/proto"
"golang.org/x/net/context"
)
//ObjectPut -
func (s *APIService) ObjectPut(request *restful.Request, response *restful.Response) {
if !policy.Authorize(request, response, "object:put") {
return
}
url := request.Request.URL
log.Logf("URL is %v", request.Request.URL.String())
log.Logf("request is %v\n", request)
bucketName := request.PathParameter("bucketName")
log.Logf("bucketName is %v\n:", bucketName)
objectKey := request.PathParameter("objectKey")
if strings.HasSuffix(url.String(), "/") {
objectKey = objectKey + "/"
}
log.Logf("objectKey is %v:\n", objectKey)
contentLenght := request.HeaderParameter("content-length")
backendName := request.HeaderParameter("x-amz-storage-class")
log.Logf("backendName is :%v\n", backendName)
// Currently, only support tier1 as default
tier := int32(utils.Tier1)
object := s3.Object{}
object.BucketName = bucketName
size, _ := strconv.ParseInt(contentLenght, 10, 64)
log.Logf("object.size is %v\n", size)
object.Size = size
object.IsDeleteMarker = ""
object.InitFlag = ""
object.LastModified = time.Now().Unix()
object.Tier = tier
// standard as default
object.StorageClass = constants.StorageClassOpenSDSStandard
ctx := context.WithValue(request.Request.Context(), "operation", "upload")
log.Logf("Received request for create bucket: %s", bucketName)
log.Logf("objectKey is %v:\n", objectKey)
object.ObjectKey = objectKey
var client datastore.DataStoreAdapter
if backendName != "" {
object.Backend = backendName
client = getBackendByName(s, backendName)
} else {
bucket, _ := s.s3Client.GetBucket(ctx, &s3.Bucket{Name: bucketName})
object.Backend = bucket.Backend
client = getBackendClient(s, bucketName)
}
if client == nil {
response.WriteError(http.StatusInternalServerError, NoSuchBackend.Error())
return
}
log.Logf("enter the PUT method")
s3err := client.PUT(request.Request.Body, &object, ctx)
log.Logf("LastModified is %v\n", object.LastModified)
if s3err != NoError {
response.WriteError(http.StatusInternalServerError, s3err.Error())
return
}
res, err := s.s3Client.CreateObject(ctx, &object)
if err != nil {
log.Logf("err is %v\n", err)
response.WriteError(http.StatusInternalServerError, err)
return
}
log.Logf("object.size2 = %v \n", object.Size)
log.Log("Upload object successfully.")
response.WriteEntity(res)
}