2016-08-17 14:36:33 -04:00
|
|
|
/*
|
|
|
|
* Minio Cloud Storage, (C) 2016 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.
|
|
|
|
*/
|
|
|
|
|
2016-08-18 19:23:42 -04:00
|
|
|
package cmd
|
2016-08-17 14:36:33 -04:00
|
|
|
|
|
|
|
import (
|
|
|
|
"net/rpc"
|
|
|
|
|
|
|
|
router "github.com/gorilla/mux"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Routes paths for "minio control" commands.
|
|
|
|
const (
|
|
|
|
controlRPCPath = reservedBucket + "/control"
|
|
|
|
healPath = controlRPCPath + "/heal"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Register control RPC handlers.
|
|
|
|
func registerControlRPCRouter(mux *router.Router, objAPI ObjectLayer) {
|
|
|
|
healRPCServer := rpc.NewServer()
|
|
|
|
healRPCServer.RegisterName("Heal", &healHandler{objAPI})
|
|
|
|
mux.Path(healPath).Handler(healRPCServer)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Handler for object healing.
|
|
|
|
type healHandler struct {
|
|
|
|
ObjectAPI ObjectLayer
|
|
|
|
}
|
|
|
|
|
|
|
|
// HealListArgs - argument for ListObjects RPC.
|
|
|
|
type HealListArgs struct {
|
|
|
|
Bucket string
|
|
|
|
Prefix string
|
|
|
|
Marker string
|
|
|
|
Delimiter string
|
|
|
|
MaxKeys int
|
|
|
|
}
|
|
|
|
|
|
|
|
// HealListReply - reply by ListObjects RPC.
|
|
|
|
type HealListReply struct {
|
|
|
|
IsTruncated bool
|
|
|
|
NextMarker string
|
|
|
|
Objects []string
|
|
|
|
}
|
|
|
|
|
|
|
|
// ListObjects - list objects.
|
|
|
|
func (h healHandler) ListObjects(arg *HealListArgs, reply *HealListReply) error {
|
|
|
|
info, err := h.ObjectAPI.ListObjectsHeal(arg.Bucket, arg.Prefix, arg.Marker, arg.Delimiter, arg.MaxKeys)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
reply.IsTruncated = info.IsTruncated
|
|
|
|
reply.NextMarker = info.NextMarker
|
|
|
|
for _, obj := range info.Objects {
|
|
|
|
reply.Objects = append(reply.Objects, obj.Name)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// HealObjectArgs - argument for HealObject RPC.
|
|
|
|
type HealObjectArgs struct {
|
|
|
|
Bucket string
|
|
|
|
Object string
|
|
|
|
}
|
|
|
|
|
|
|
|
// HealObjectReply - reply by HealObject RPC.
|
|
|
|
type HealObjectReply struct{}
|
|
|
|
|
|
|
|
// HealObject - heal the object.
|
|
|
|
func (h healHandler) HealObject(arg *HealObjectArgs, reply *HealObjectReply) error {
|
|
|
|
return h.ObjectAPI.HealObject(arg.Bucket, arg.Object)
|
|
|
|
}
|