mirror of
https://github.com/minio/minio.git
synced 2025-03-12 20:50:11 -04:00
Merge pull request #470 from harshavardhana/pr_out_remove_bucketpolicy_handlers_and_all_references
This commit is contained in:
commit
276c02af62
@ -10,8 +10,7 @@ before_install:
|
|||||||
- cd ..
|
- cd ..
|
||||||
sudo: false
|
sudo: false
|
||||||
go:
|
go:
|
||||||
- 1.4
|
- 1.4.1
|
||||||
- release
|
|
||||||
notifications:
|
notifications:
|
||||||
slack:
|
slack:
|
||||||
secure: jlDBuqna7waJXJrl/EOeTH1fXgqJu3WrTDl0Sv7oJBNVH1Af4cGmHaa1oVWrYUMB7lEPjpuF+xcBNA+N+mcR53JbpqueR3sIKlokqHL4TPZBg4XX+1yqtmYMkL6V2woWQ7Wmtis0kDstSoVZjEUVHgk3YF8hcLlK49oMhTeqY08=
|
secure: jlDBuqna7waJXJrl/EOeTH1fXgqJu3WrTDl0Sv7oJBNVH1Af4cGmHaa1oVWrYUMB7lEPjpuF+xcBNA+N+mcR53JbpqueR3sIKlokqHL4TPZBg4XX+1yqtmYMkL6V2woWQ7Wmtis0kDstSoVZjEUVHgk3YF8hcLlK49oMhTeqY08=
|
||||||
|
@ -36,23 +36,9 @@ func (server *minioAPI) listObjectsHandler(w http.ResponseWriter, req *http.Requ
|
|||||||
bucket := vars["bucket"]
|
bucket := vars["bucket"]
|
||||||
|
|
||||||
resources := getBucketResources(req.URL.Query())
|
resources := getBucketResources(req.URL.Query())
|
||||||
if resources.Policy == true {
|
|
||||||
// TODO
|
|
||||||
// ----
|
|
||||||
// This is handled here instead of router, is only because semantically
|
|
||||||
// resource queries are not treated differently by Gorilla mux
|
|
||||||
//
|
|
||||||
// In-fact a request coming in as /bucket/?policy={} and /bucket/object are
|
|
||||||
// treated similarly. A proper fix would be to remove this comment and
|
|
||||||
// find a right regex pattern for individual requests
|
|
||||||
server.getBucketPolicyHandler(w, req)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
if resources.Maxkeys == 0 {
|
if resources.Maxkeys == 0 {
|
||||||
resources.Maxkeys = maxObjectList
|
resources.Maxkeys = maxObjectList
|
||||||
}
|
}
|
||||||
|
|
||||||
acceptsContentType := getContentType(req)
|
acceptsContentType := getContentType(req)
|
||||||
objects, resources, err := server.driver.ListObjects(bucket, resources)
|
objects, resources, err := server.driver.ListObjects(bucket, resources)
|
||||||
switch err.(type) {
|
switch err.(type) {
|
||||||
@ -121,12 +107,6 @@ func (server *minioAPI) putBucketHandler(w http.ResponseWriter, req *http.Reques
|
|||||||
bucket := vars["bucket"]
|
bucket := vars["bucket"]
|
||||||
err := server.driver.CreateBucket(bucket)
|
err := server.driver.CreateBucket(bucket)
|
||||||
|
|
||||||
resources := getBucketResources(req.URL.Query())
|
|
||||||
if resources.Policy == true {
|
|
||||||
server.putBucketPolicyHandler(w, req)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
acceptsContentType := getContentType(req)
|
acceptsContentType := getContentType(req)
|
||||||
switch err.(type) {
|
switch err.(type) {
|
||||||
case nil:
|
case nil:
|
||||||
@ -158,7 +138,6 @@ func (server *minioAPI) putBucketHandler(w http.ResponseWriter, req *http.Reques
|
|||||||
// have permission to access it. Otherwise, the operation might
|
// have permission to access it. Otherwise, the operation might
|
||||||
// return responses such as 404 Not Found and 403 Forbidden.
|
// return responses such as 404 Not Found and 403 Forbidden.
|
||||||
func (server *minioAPI) headBucketHandler(w http.ResponseWriter, req *http.Request) {
|
func (server *minioAPI) headBucketHandler(w http.ResponseWriter, req *http.Request) {
|
||||||
// TODO need to peek into bucketPolicy return appropriate checks here
|
|
||||||
vars := mux.Vars(req)
|
vars := mux.Vars(req)
|
||||||
bucket := vars["bucket"]
|
bucket := vars["bucket"]
|
||||||
acceptsContentType := getContentType(req)
|
acceptsContentType := getContentType(req)
|
||||||
|
@ -77,6 +77,7 @@ type Owner struct {
|
|||||||
// List of not implemented bucket queries
|
// List of not implemented bucket queries
|
||||||
var unimplementedBucketResourceNames = map[string]bool{
|
var unimplementedBucketResourceNames = map[string]bool{
|
||||||
"acl": true,
|
"acl": true,
|
||||||
|
"policy": true,
|
||||||
"cors": true,
|
"cors": true,
|
||||||
"lifecycle": true,
|
"lifecycle": true,
|
||||||
"location": true,
|
"location": true,
|
||||||
|
@ -134,20 +134,6 @@ func (server *minioAPI) putObjectHandler(w http.ResponseWriter, req *http.Reques
|
|||||||
bucket = vars["bucket"]
|
bucket = vars["bucket"]
|
||||||
object = vars["object"]
|
object = vars["object"]
|
||||||
|
|
||||||
resources := getBucketResources(req.URL.Query())
|
|
||||||
if resources.Policy == true && object == "" {
|
|
||||||
// TODO
|
|
||||||
// ----
|
|
||||||
// This is handled here instead of router, is only because semantically
|
|
||||||
// resource queries are not treated differently by Gorilla mux
|
|
||||||
//
|
|
||||||
// In-fact a request coming in as /bucket/?policy={} and /bucket/object are
|
|
||||||
// treated similarly. A proper fix would be to remove this comment and
|
|
||||||
// find a right regex pattern for individual requests
|
|
||||||
server.putBucketPolicyHandler(w, req)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// get Content-MD5 sent by client
|
// get Content-MD5 sent by client
|
||||||
md5 := req.Header.Get("Content-MD5")
|
md5 := req.Header.Get("Content-MD5")
|
||||||
err := server.driver.CreateObject(bucket, object, "", md5, req.Body)
|
err := server.driver.CreateObject(bucket, object, "", md5, req.Body)
|
||||||
|
@ -1,121 +0,0 @@
|
|||||||
/*
|
|
||||||
* Minimalist Object Storage, (C) 2015 Minio, Inc.
|
|
||||||
*
|
|
||||||
* 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 api
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/json"
|
|
||||||
"net/http"
|
|
||||||
|
|
||||||
"github.com/gorilla/mux"
|
|
||||||
"github.com/minio-io/minio/pkg/iodine"
|
|
||||||
"github.com/minio-io/minio/pkg/storage/drivers"
|
|
||||||
"github.com/minio-io/minio/pkg/utils/log"
|
|
||||||
)
|
|
||||||
|
|
||||||
// PUT Bucket policy
|
|
||||||
// -----------------
|
|
||||||
// This implementation of the PUT operation uses the policy subresource
|
|
||||||
// to add to or replace a policy on a bucket
|
|
||||||
func (server *minioAPI) putBucketPolicyHandler(w http.ResponseWriter, req *http.Request) {
|
|
||||||
vars := mux.Vars(req)
|
|
||||||
bucket := vars["bucket"]
|
|
||||||
acceptsContentType := getContentType(req)
|
|
||||||
|
|
||||||
policy, ok := drivers.Parsepolicy(req.Body)
|
|
||||||
if ok == false {
|
|
||||||
writeErrorResponse(w, req, InvalidPolicyDocument, acceptsContentType, req.URL.Path)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
err := server.driver.CreateBucketPolicy(bucket, policy)
|
|
||||||
switch err := err.(type) {
|
|
||||||
case nil:
|
|
||||||
{
|
|
||||||
w.WriteHeader(http.StatusNoContent)
|
|
||||||
setCommonHeaders(w, getContentTypeString(acceptsContentType))
|
|
||||||
w.Header().Set("Connection", "keep-alive")
|
|
||||||
}
|
|
||||||
case drivers.BucketNameInvalid:
|
|
||||||
{
|
|
||||||
writeErrorResponse(w, req, InvalidBucketName, acceptsContentType, req.URL.Path)
|
|
||||||
}
|
|
||||||
case drivers.BucketNotFound:
|
|
||||||
{
|
|
||||||
writeErrorResponse(w, req, NoSuchBucket, acceptsContentType, req.URL.Path)
|
|
||||||
}
|
|
||||||
case drivers.BackendCorrupted:
|
|
||||||
{
|
|
||||||
log.Error.Println(err)
|
|
||||||
writeErrorResponse(w, req, InternalError, acceptsContentType, req.URL.Path)
|
|
||||||
}
|
|
||||||
case drivers.ImplementationError:
|
|
||||||
{
|
|
||||||
log.Error.Println(err)
|
|
||||||
writeErrorResponse(w, req, InternalError, acceptsContentType, req.URL.Path)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// GET Bucket policy
|
|
||||||
// -----------------
|
|
||||||
// This implementation of the GET operation uses the policy subresource
|
|
||||||
// to return the policy of a specified bucket.
|
|
||||||
func (server *minioAPI) getBucketPolicyHandler(w http.ResponseWriter, req *http.Request) {
|
|
||||||
vars := mux.Vars(req)
|
|
||||||
bucket := vars["bucket"]
|
|
||||||
acceptsContentType := getContentType(req)
|
|
||||||
|
|
||||||
p, err := server.driver.GetBucketPolicy(bucket)
|
|
||||||
switch err := err.(type) {
|
|
||||||
case nil:
|
|
||||||
{
|
|
||||||
responsePolicy, err := json.Marshal(p)
|
|
||||||
if err != nil {
|
|
||||||
// log error
|
|
||||||
log.Error.Println(iodine.New(err, nil))
|
|
||||||
writeErrorResponse(w, req, InternalError, acceptsContentType, req.URL.Path)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
setCommonHeaders(w, getContentTypeString(acceptsContentType))
|
|
||||||
w.Header().Set("Connection", "keep-alive")
|
|
||||||
w.WriteHeader(http.StatusOK)
|
|
||||||
w.Write(responsePolicy)
|
|
||||||
}
|
|
||||||
case drivers.BucketNameInvalid:
|
|
||||||
{
|
|
||||||
writeErrorResponse(w, req, InvalidBucketName, acceptsContentType, req.URL.Path)
|
|
||||||
}
|
|
||||||
case drivers.BucketNotFound:
|
|
||||||
{
|
|
||||||
writeErrorResponse(w, req, NoSuchBucket, acceptsContentType, req.URL.Path)
|
|
||||||
}
|
|
||||||
case drivers.BucketPolicyNotFound:
|
|
||||||
{
|
|
||||||
writeErrorResponse(w, req, NoSuchBucketPolicy, acceptsContentType, req.URL.Path)
|
|
||||||
}
|
|
||||||
case drivers.BackendCorrupted:
|
|
||||||
{
|
|
||||||
log.Error.Println(err)
|
|
||||||
writeErrorResponse(w, req, InternalError, acceptsContentType, req.URL.Path)
|
|
||||||
}
|
|
||||||
case drivers.ImplementationError:
|
|
||||||
{
|
|
||||||
log.Error.Println(err)
|
|
||||||
writeErrorResponse(w, req, InternalError, acceptsContentType, req.URL.Path)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -61,8 +61,6 @@ const (
|
|||||||
RequestTimeTooSkewed
|
RequestTimeTooSkewed
|
||||||
SignatureDoesNotMatch
|
SignatureDoesNotMatch
|
||||||
TooManyBuckets
|
TooManyBuckets
|
||||||
InvalidPolicyDocument
|
|
||||||
NoSuchBucketPolicy
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// Error code to Error structure map
|
// Error code to Error structure map
|
||||||
@ -172,16 +170,6 @@ var errorCodeResponse = map[int]Error{
|
|||||||
Description: "You have attempted to create more buckets than allowed.",
|
Description: "You have attempted to create more buckets than allowed.",
|
||||||
HTTPStatusCode: http.StatusBadRequest,
|
HTTPStatusCode: http.StatusBadRequest,
|
||||||
},
|
},
|
||||||
InvalidPolicyDocument: {
|
|
||||||
Code: "InvalidPolicyDocument",
|
|
||||||
Description: "The content of the form does not meet the conditions specified in the policy document.",
|
|
||||||
HTTPStatusCode: http.StatusBadRequest,
|
|
||||||
},
|
|
||||||
NoSuchBucketPolicy: {
|
|
||||||
Code: "NoSuchBucketPolicy",
|
|
||||||
Description: "The specified bucket does not have a bucket policy.",
|
|
||||||
HTTPStatusCode: http.StatusNotFound,
|
|
||||||
},
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// errorCodeError provides errorCode to Error. It returns empty if the code provided is unknown
|
// errorCodeError provides errorCode to Error. It returns empty if the code provided is unknown
|
||||||
|
@ -33,8 +33,6 @@ func getBucketResources(values url.Values) (v drivers.BucketResourcesMetadata) {
|
|||||||
v.Marker = value[0]
|
v.Marker = value[0]
|
||||||
case key == "max-keys":
|
case key == "max-keys":
|
||||||
v.Maxkeys, _ = strconv.Atoi(value[0])
|
v.Maxkeys, _ = strconv.Atoi(value[0])
|
||||||
case key == "policy":
|
|
||||||
v.Policy = true
|
|
||||||
case key == "delimiter":
|
case key == "delimiter":
|
||||||
v.Delimiter = value[0]
|
v.Delimiter = value[0]
|
||||||
}
|
}
|
||||||
|
@ -1,199 +0,0 @@
|
|||||||
/*
|
|
||||||
* Minimalist Object Storage, (C) 2015 Minio, Inc.
|
|
||||||
*
|
|
||||||
* 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 drivers
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/json"
|
|
||||||
"io"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
// User - canonical
|
|
||||||
type User struct {
|
|
||||||
AWS string
|
|
||||||
}
|
|
||||||
|
|
||||||
// Statement - minio policy statement
|
|
||||||
type Statement struct {
|
|
||||||
Sid string
|
|
||||||
Effect string
|
|
||||||
Principal User
|
|
||||||
Action []string
|
|
||||||
Resource []string
|
|
||||||
// add Condition struct/var TODO - fix it in future if necessary
|
|
||||||
}
|
|
||||||
|
|
||||||
// BucketPolicy - minio policy collection
|
|
||||||
type BucketPolicy struct {
|
|
||||||
Version string // date in 0000-00-00 format
|
|
||||||
Statement []Statement
|
|
||||||
}
|
|
||||||
|
|
||||||
// Resource delimiter
|
|
||||||
const (
|
|
||||||
MinioResource = "minio:::"
|
|
||||||
)
|
|
||||||
|
|
||||||
// TODO support canonical user
|
|
||||||
// Principal delimiter
|
|
||||||
const (
|
|
||||||
MinioPrincipal = "minio::"
|
|
||||||
)
|
|
||||||
|
|
||||||
// Action map
|
|
||||||
var SupportedActionMap = map[string]bool{
|
|
||||||
"*": true,
|
|
||||||
"minio:GetObject": true,
|
|
||||||
"minio:ListBucket": true,
|
|
||||||
"minio:PutObject": true,
|
|
||||||
"minio:CreateBucket": true,
|
|
||||||
"minio:GetBucketPolicy": true,
|
|
||||||
"minio:DeleteBucketPolicy": true,
|
|
||||||
"minio:ListAllMyBuckets": true,
|
|
||||||
"minio:PutBucketPolicy": true,
|
|
||||||
}
|
|
||||||
|
|
||||||
// Effect map
|
|
||||||
var SupportedEffectMap = map[string]bool{
|
|
||||||
"Allow": true,
|
|
||||||
"Deny": true,
|
|
||||||
}
|
|
||||||
|
|
||||||
func isValidAction(action []string) bool {
|
|
||||||
for _, a := range action {
|
|
||||||
if !SupportedActionMap[a] {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
func isValidEffect(effect string) bool {
|
|
||||||
if SupportedEffectMap[effect] {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
func isValidResource(resources []string) bool {
|
|
||||||
var ok bool
|
|
||||||
for _, resource := range resources {
|
|
||||||
switch true {
|
|
||||||
case strings.HasPrefix(resource, AwsResource):
|
|
||||||
bucket := strings.SplitAfter(resource, AwsResource)[1]
|
|
||||||
ok = true
|
|
||||||
if len(bucket) == 0 {
|
|
||||||
ok = false
|
|
||||||
}
|
|
||||||
case strings.HasPrefix(resource, MinioResource):
|
|
||||||
bucket := strings.SplitAfter(resource, MinioResource)[1]
|
|
||||||
ok = true
|
|
||||||
if len(bucket) == 0 {
|
|
||||||
ok = false
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
ok = false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return ok
|
|
||||||
}
|
|
||||||
|
|
||||||
func isValidPrincipal(principal string) bool {
|
|
||||||
var ok bool
|
|
||||||
if principal == "*" {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
switch true {
|
|
||||||
case strings.HasPrefix(principal, AwsPrincipal):
|
|
||||||
username := strings.SplitAfter(principal, AwsPrincipal)[1]
|
|
||||||
ok = true
|
|
||||||
if len(username) == 0 {
|
|
||||||
ok = false
|
|
||||||
}
|
|
||||||
|
|
||||||
case strings.HasPrefix(principal, MinioPrincipal):
|
|
||||||
username := strings.SplitAfter(principal, MinioPrincipal)[1]
|
|
||||||
ok = true
|
|
||||||
if len(username) == 0 {
|
|
||||||
ok = false
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
ok = false
|
|
||||||
}
|
|
||||||
return ok
|
|
||||||
}
|
|
||||||
|
|
||||||
func parseStatement(statement Statement) bool {
|
|
||||||
if len(statement.Sid) == 0 {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
if len(statement.Effect) == 0 {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
if !isValidEffect(statement.Effect) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
if len(statement.Principal.AWS) == 0 {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
if !isValidPrincipal(statement.Principal.AWS) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
if len(statement.Action) == 0 {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
if !isValidAction(statement.Action) && !isValidActionS3(statement.Action) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
if len(statement.Resource) == 0 {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
if !isValidResource(statement.Resource) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
// Parsepolicy - validate request body is proper JSON and in accordance with policy standards
|
|
||||||
func Parsepolicy(data io.Reader) (BucketPolicy, bool) {
|
|
||||||
var policy BucketPolicy
|
|
||||||
decoder := json.NewDecoder(data)
|
|
||||||
err := decoder.Decode(&policy)
|
|
||||||
if err != nil {
|
|
||||||
goto error
|
|
||||||
}
|
|
||||||
if len(policy.Version) == 0 {
|
|
||||||
goto error
|
|
||||||
}
|
|
||||||
_, err = parseDate(policy.Version)
|
|
||||||
if err != nil {
|
|
||||||
goto error
|
|
||||||
}
|
|
||||||
if len(policy.Statement) == 0 {
|
|
||||||
goto error
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, statement := range policy.Statement {
|
|
||||||
if !parseStatement(statement) {
|
|
||||||
goto error
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return policy, true
|
|
||||||
|
|
||||||
error:
|
|
||||||
return BucketPolicy{}, false
|
|
||||||
}
|
|
@ -1,52 +0,0 @@
|
|||||||
/*
|
|
||||||
* Minimalist Object Storage, (C) 2015 Minio, Inc.
|
|
||||||
*
|
|
||||||
* 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 drivers
|
|
||||||
|
|
||||||
// This file implements compatability layer for AWS clients
|
|
||||||
|
|
||||||
// Resource delimiter
|
|
||||||
const (
|
|
||||||
AwsResource = "arn:aws:s3:::"
|
|
||||||
)
|
|
||||||
|
|
||||||
// TODO support canonical user
|
|
||||||
// Principal delimiter
|
|
||||||
const (
|
|
||||||
AwsPrincipal = "arn:aws:iam::"
|
|
||||||
)
|
|
||||||
|
|
||||||
// Action map
|
|
||||||
var SupportedActionMapCompat = map[string]bool{
|
|
||||||
"*": true,
|
|
||||||
"s3:GetObject": true,
|
|
||||||
"s3:ListBucket": true,
|
|
||||||
"s3:PutObject": true,
|
|
||||||
"s3:CreateBucket": true,
|
|
||||||
"s3:GetBucketPolicy": true,
|
|
||||||
"s3:DeleteBucketPolicy": true,
|
|
||||||
"s3:ListAllMyBuckets": true,
|
|
||||||
"s3:PutBucketPolicy": true,
|
|
||||||
}
|
|
||||||
|
|
||||||
func isValidActionS3(action []string) bool {
|
|
||||||
for _, a := range action {
|
|
||||||
if !SupportedActionMapCompat[a] {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true
|
|
||||||
}
|
|
@ -144,16 +144,6 @@ func (d donutDriver) GetBucketMetadata(bucketName string) (drivers.BucketMetadat
|
|||||||
return bucketMetadata, nil
|
return bucketMetadata, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// CreateBucketPolicy sets a bucket's access policy
|
|
||||||
func (d donutDriver) CreateBucketPolicy(bucket string, p drivers.BucketPolicy) error {
|
|
||||||
return iodine.New(errors.New("Not Implemented"), nil)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetBucketPolicy returns a bucket's access policy
|
|
||||||
func (d donutDriver) GetBucketPolicy(bucket string) (drivers.BucketPolicy, error) {
|
|
||||||
return drivers.BucketPolicy{}, iodine.New(errors.New("Not Implemented"), nil)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetObject retrieves an object and writes it to a writer
|
// GetObject retrieves an object and writes it to a writer
|
||||||
func (d donutDriver) GetObject(target io.Writer, bucketName, objectName string) (int64, error) {
|
func (d donutDriver) GetObject(target io.Writer, bucketName, objectName string) (int64, error) {
|
||||||
errParams := map[string]string{
|
errParams := map[string]string{
|
||||||
|
@ -29,8 +29,6 @@ type Driver interface {
|
|||||||
ListBuckets() ([]BucketMetadata, error)
|
ListBuckets() ([]BucketMetadata, error)
|
||||||
CreateBucket(bucket string) error
|
CreateBucket(bucket string) error
|
||||||
GetBucketMetadata(bucket string) (BucketMetadata, error)
|
GetBucketMetadata(bucket string) (BucketMetadata, error)
|
||||||
CreateBucketPolicy(bucket string, p BucketPolicy) error
|
|
||||||
GetBucketPolicy(bucket string) (BucketPolicy, error)
|
|
||||||
|
|
||||||
// Object Operations
|
// Object Operations
|
||||||
GetObject(w io.Writer, bucket, object string) (int64, error)
|
GetObject(w io.Writer, bucket, object string) (int64, error)
|
||||||
@ -78,7 +76,6 @@ type BucketResourcesMetadata struct {
|
|||||||
CommonPrefixes []string
|
CommonPrefixes []string
|
||||||
Mode FilterMode
|
Mode FilterMode
|
||||||
|
|
||||||
Policy bool
|
|
||||||
// TODO
|
// TODO
|
||||||
Logging string
|
Logging string
|
||||||
Notification string
|
Notification string
|
||||||
|
@ -56,9 +56,6 @@ type DigestError struct {
|
|||||||
|
|
||||||
/// Bucket related errors
|
/// Bucket related errors
|
||||||
|
|
||||||
// BucketPolicyNotFound - missing bucket policy
|
|
||||||
type BucketPolicyNotFound GenericBucketError
|
|
||||||
|
|
||||||
// BucketNameInvalid - bucketname provided is invalid
|
// BucketNameInvalid - bucketname provided is invalid
|
||||||
type BucketNameInvalid GenericBucketError
|
type BucketNameInvalid GenericBucketError
|
||||||
|
|
||||||
@ -107,11 +104,6 @@ func EmbedError(bucket, object string, err error) ImplementationError {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return string an error formatted as the given text
|
|
||||||
func (e BucketPolicyNotFound) Error() string {
|
|
||||||
return "Bucket policy not found for: " + e.Bucket
|
|
||||||
}
|
|
||||||
|
|
||||||
// Return string an error formatted as the given text
|
// Return string an error formatted as the given text
|
||||||
func (e ObjectNotFound) Error() string {
|
func (e ObjectNotFound) Error() string {
|
||||||
return "Object not Found: " + e.Bucket + "#" + e.Object
|
return "Object not Found: " + e.Bucket + "#" + e.Object
|
||||||
|
@ -30,8 +30,9 @@ import (
|
|||||||
"crypto/md5"
|
"crypto/md5"
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
|
|
||||||
"github.com/golang/groupcache/lru"
|
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
|
|
||||||
|
"github.com/golang/groupcache/lru"
|
||||||
)
|
)
|
||||||
|
|
||||||
// memoryDriver - local variables
|
// memoryDriver - local variables
|
||||||
@ -117,16 +118,6 @@ func (memory memoryDriver) GetBucketMetadata(bucket string) (drivers.BucketMetad
|
|||||||
return memory.bucketMetadata[bucket].metadata, nil
|
return memory.bucketMetadata[bucket].metadata, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// CreateBucketPolicy - Not implemented
|
|
||||||
func (memory memoryDriver) CreateBucketPolicy(bucket string, policy drivers.BucketPolicy) error {
|
|
||||||
return drivers.APINotImplemented{API: "PutBucketPolicy"}
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetBucketPolicy - Not implemented
|
|
||||||
func (memory memoryDriver) GetBucketPolicy(bucket string) (drivers.BucketPolicy, error) {
|
|
||||||
return drivers.BucketPolicy{}, drivers.APINotImplemented{API: "GetBucketPolicy"}
|
|
||||||
}
|
|
||||||
|
|
||||||
// CreateObject - PUT object to memory buffer
|
// CreateObject - PUT object to memory buffer
|
||||||
func (memory memoryDriver) CreateObject(bucket, key, contentType, md5sum string, data io.Reader) error {
|
func (memory memoryDriver) CreateObject(bucket, key, contentType, md5sum string, data io.Reader) error {
|
||||||
memory.lock.RLock()
|
memory.lock.RLock()
|
||||||
|
@ -44,25 +44,6 @@ func (m *Driver) GetBucketMetadata(bucket string) (drivers.BucketMetadata, error
|
|||||||
return r0, r1
|
return r0, r1
|
||||||
}
|
}
|
||||||
|
|
||||||
// CreateBucketPolicy is a mock
|
|
||||||
func (m *Driver) CreateBucketPolicy(bucket string, p drivers.BucketPolicy) error {
|
|
||||||
ret := m.Called(bucket, p)
|
|
||||||
|
|
||||||
r0 := ret.Error(0)
|
|
||||||
|
|
||||||
return r0
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetBucketPolicy is a mock
|
|
||||||
func (m *Driver) GetBucketPolicy(bucket string) (drivers.BucketPolicy, error) {
|
|
||||||
ret := m.Called(bucket)
|
|
||||||
|
|
||||||
r0 := ret.Get(0).(drivers.BucketPolicy)
|
|
||||||
r1 := ret.Error(1)
|
|
||||||
|
|
||||||
return r0, r1
|
|
||||||
}
|
|
||||||
|
|
||||||
// SetGetObjectWriter is a mock
|
// SetGetObjectWriter is a mock
|
||||||
func (m *Driver) SetGetObjectWriter(bucket, object string, data []byte) {
|
func (m *Driver) SetGetObjectWriter(bucket, object string, data []byte) {
|
||||||
m.ObjectWriterData[bucket+":"+object] = data
|
m.ObjectWriterData[bucket+":"+object] = data
|
||||||
|
Loading…
x
Reference in New Issue
Block a user