mirror of
https://github.com/versity/versitygw.git
synced 2026-02-04 09:22:02 +00:00
Closes #1731 Implements the admin `CreateBucket` (`PATCH /:bucket/create`) endpoint and CLI command, which create a new bucket with the provided owner access key ID. The endpoint internally calls the S3 `CreateBucket` API, storing the new owner information in the request context under the `bucket-owner` key. This value is then retrieved by the S3 API layer and the backends. The endpoint uses the custom `x-vgw-owner` HTTP header to pass the bucket owner access key ID. The admin CLI command mirrors `aws s3api create-bucket` and supports all flags implemented by the gateway (for example, `--create-bucket-configuration`, `--acl`, `--object-ownership`, etc.).
119 lines
4.4 KiB
Go
119 lines
4.4 KiB
Go
// Copyright 2023 Versity Software
|
|
// This file is 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 s3api
|
|
|
|
import (
|
|
"github.com/gofiber/fiber/v2"
|
|
"github.com/versity/versitygw/auth"
|
|
"github.com/versity/versitygw/backend"
|
|
"github.com/versity/versitygw/metrics"
|
|
"github.com/versity/versitygw/s3api/controllers"
|
|
"github.com/versity/versitygw/s3api/middlewares"
|
|
"github.com/versity/versitygw/s3log"
|
|
)
|
|
|
|
type S3AdminRouter struct {
|
|
s3api controllers.S3ApiController
|
|
}
|
|
|
|
func (ar *S3AdminRouter) Init(app *fiber.App, be backend.Backend, iam auth.IAMService, logger s3log.AuditLogger, root middlewares.RootUserConfig, region string, debug bool, corsAllowOrigin string) {
|
|
ctrl := controllers.NewAdminController(iam, be, logger, ar.s3api)
|
|
services := &controllers.Services{
|
|
Logger: logger,
|
|
}
|
|
|
|
// CreateUser admin api
|
|
app.Patch("/create-user",
|
|
controllers.ProcessHandlers(ctrl.CreateUser, metrics.ActionAdminCreateUser, services,
|
|
middlewares.VerifyV4Signature(root, iam, region, false, true),
|
|
middlewares.IsAdmin(metrics.ActionAdminCreateUser),
|
|
middlewares.ApplyDefaultCORS(corsAllowOrigin),
|
|
))
|
|
app.Options("/create-user",
|
|
middlewares.ApplyDefaultCORSPreflight(corsAllowOrigin),
|
|
middlewares.ApplyDefaultCORS(corsAllowOrigin),
|
|
)
|
|
|
|
// DeleteUsers admin api
|
|
app.Patch("/delete-user",
|
|
controllers.ProcessHandlers(ctrl.DeleteUser, metrics.ActionAdminDeleteUser, services,
|
|
middlewares.VerifyV4Signature(root, iam, region, false, true),
|
|
middlewares.IsAdmin(metrics.ActionAdminDeleteUser),
|
|
middlewares.ApplyDefaultCORS(corsAllowOrigin),
|
|
))
|
|
app.Options("/delete-user",
|
|
middlewares.ApplyDefaultCORSPreflight(corsAllowOrigin),
|
|
middlewares.ApplyDefaultCORS(corsAllowOrigin),
|
|
)
|
|
|
|
// UpdateUser admin api
|
|
app.Patch("/update-user",
|
|
controllers.ProcessHandlers(ctrl.UpdateUser, metrics.ActionAdminUpdateUser, services,
|
|
middlewares.VerifyV4Signature(root, iam, region, false, true),
|
|
middlewares.IsAdmin(metrics.ActionAdminUpdateUser),
|
|
middlewares.ApplyDefaultCORS(corsAllowOrigin),
|
|
))
|
|
app.Options("/update-user",
|
|
middlewares.ApplyDefaultCORSPreflight(corsAllowOrigin),
|
|
middlewares.ApplyDefaultCORS(corsAllowOrigin),
|
|
)
|
|
|
|
// ListUsers admin api
|
|
app.Patch("/list-users",
|
|
controllers.ProcessHandlers(ctrl.ListUsers, metrics.ActionAdminListUsers, services,
|
|
middlewares.VerifyV4Signature(root, iam, region, false, true),
|
|
middlewares.IsAdmin(metrics.ActionAdminListUsers),
|
|
middlewares.ApplyDefaultCORS(corsAllowOrigin),
|
|
))
|
|
app.Options("/list-users",
|
|
middlewares.ApplyDefaultCORSPreflight(corsAllowOrigin),
|
|
middlewares.ApplyDefaultCORS(corsAllowOrigin),
|
|
)
|
|
|
|
// ChangeBucketOwner admin api
|
|
app.Patch("/change-bucket-owner",
|
|
controllers.ProcessHandlers(ctrl.ChangeBucketOwner, metrics.ActionAdminChangeBucketOwner, services,
|
|
middlewares.VerifyV4Signature(root, iam, region, false, true),
|
|
middlewares.IsAdmin(metrics.ActionAdminChangeBucketOwner),
|
|
middlewares.ApplyDefaultCORS(corsAllowOrigin),
|
|
))
|
|
app.Options("/change-bucket-owner",
|
|
middlewares.ApplyDefaultCORSPreflight(corsAllowOrigin),
|
|
middlewares.ApplyDefaultCORS(corsAllowOrigin),
|
|
)
|
|
|
|
// ListBucketsAndOwners admin api
|
|
app.Patch("/list-buckets",
|
|
controllers.ProcessHandlers(ctrl.ListBuckets, metrics.ActionAdminListBuckets, services,
|
|
middlewares.VerifyV4Signature(root, iam, region, false, true),
|
|
middlewares.IsAdmin(metrics.ActionAdminListBuckets),
|
|
middlewares.ApplyDefaultCORS(corsAllowOrigin),
|
|
))
|
|
app.Options("/list-buckets",
|
|
middlewares.ApplyDefaultCORSPreflight(corsAllowOrigin),
|
|
middlewares.ApplyDefaultCORS(corsAllowOrigin),
|
|
)
|
|
|
|
app.Patch("/:bucket/create",
|
|
controllers.ProcessHandlers(ctrl.CreateBucket, metrics.ActionAdminListBuckets, services,
|
|
middlewares.VerifyV4Signature(root, iam, region, false, true),
|
|
middlewares.IsAdmin(metrics.ActionAdminCreateBucket),
|
|
))
|
|
app.Options("/:bucket/create",
|
|
middlewares.ApplyDefaultCORSPreflight(corsAllowOrigin),
|
|
middlewares.ApplyDefaultCORS(corsAllowOrigin),
|
|
)
|
|
}
|