Peer/rpc should never honor RPC calls without object-layer (#6486)

Fixes #6484
master
Harshavardhana 6 years ago committed by Nitish Tiwari
parent 052a7b8eec
commit 3d060f8b64
  1. 40
      cmd/peer-rpc-server.go

@ -45,6 +45,11 @@ type DeleteBucketArgs struct {
// DeleteBucket - handles delete bucket RPC call which removes all values of given bucket in global NotificationSys object. // DeleteBucket - handles delete bucket RPC call which removes all values of given bucket in global NotificationSys object.
func (receiver *peerRPCReceiver) DeleteBucket(args *DeleteBucketArgs, reply *VoidReply) error { func (receiver *peerRPCReceiver) DeleteBucket(args *DeleteBucketArgs, reply *VoidReply) error {
objAPI := newObjectLayerFn()
if objAPI == nil {
return errServerNotInitialized
}
globalNotificationSys.RemoveNotification(args.BucketName) globalNotificationSys.RemoveNotification(args.BucketName)
globalPolicySys.Remove(args.BucketName) globalPolicySys.Remove(args.BucketName)
return nil return nil
@ -59,6 +64,11 @@ type SetBucketPolicyArgs struct {
// SetBucketPolicy - handles set bucket policy RPC call which adds bucket policy to globalPolicySys. // SetBucketPolicy - handles set bucket policy RPC call which adds bucket policy to globalPolicySys.
func (receiver *peerRPCReceiver) SetBucketPolicy(args *SetBucketPolicyArgs, reply *VoidReply) error { func (receiver *peerRPCReceiver) SetBucketPolicy(args *SetBucketPolicyArgs, reply *VoidReply) error {
objAPI := newObjectLayerFn()
if objAPI == nil {
return errServerNotInitialized
}
globalPolicySys.Set(args.BucketName, args.Policy) globalPolicySys.Set(args.BucketName, args.Policy)
return nil return nil
} }
@ -71,6 +81,11 @@ type RemoveBucketPolicyArgs struct {
// RemoveBucketPolicy - handles delete bucket policy RPC call which removes bucket policy to globalPolicySys. // RemoveBucketPolicy - handles delete bucket policy RPC call which removes bucket policy to globalPolicySys.
func (receiver *peerRPCReceiver) RemoveBucketPolicy(args *RemoveBucketPolicyArgs, reply *VoidReply) error { func (receiver *peerRPCReceiver) RemoveBucketPolicy(args *RemoveBucketPolicyArgs, reply *VoidReply) error {
objAPI := newObjectLayerFn()
if objAPI == nil {
return errServerNotInitialized
}
globalPolicySys.Remove(args.BucketName) globalPolicySys.Remove(args.BucketName)
return nil return nil
} }
@ -84,6 +99,11 @@ type PutBucketNotificationArgs struct {
// PutBucketNotification - handles put bucket notification RPC call which adds rules to given bucket to global NotificationSys object. // PutBucketNotification - handles put bucket notification RPC call which adds rules to given bucket to global NotificationSys object.
func (receiver *peerRPCReceiver) PutBucketNotification(args *PutBucketNotificationArgs, reply *VoidReply) error { func (receiver *peerRPCReceiver) PutBucketNotification(args *PutBucketNotificationArgs, reply *VoidReply) error {
objAPI := newObjectLayerFn()
if objAPI == nil {
return errServerNotInitialized
}
globalNotificationSys.AddRulesMap(args.BucketName, args.RulesMap) globalNotificationSys.AddRulesMap(args.BucketName, args.RulesMap)
return nil return nil
} }
@ -100,6 +120,11 @@ type ListenBucketNotificationArgs struct {
// ListenBucketNotification - handles listen bucket notification RPC call. It creates PeerRPCClient target which pushes requested events to target in remote peer. // ListenBucketNotification - handles listen bucket notification RPC call. It creates PeerRPCClient target which pushes requested events to target in remote peer.
func (receiver *peerRPCReceiver) ListenBucketNotification(args *ListenBucketNotificationArgs, reply *VoidReply) error { func (receiver *peerRPCReceiver) ListenBucketNotification(args *ListenBucketNotificationArgs, reply *VoidReply) error {
objAPI := newObjectLayerFn()
if objAPI == nil {
return errServerNotInitialized
}
rpcClient := globalNotificationSys.GetPeerRPCClient(args.Addr) rpcClient := globalNotificationSys.GetPeerRPCClient(args.Addr)
if rpcClient == nil { if rpcClient == nil {
return fmt.Errorf("unable to find PeerRPCClient for provided address %v. This happens only if remote and this minio run with different set of endpoints", args.Addr) return fmt.Errorf("unable to find PeerRPCClient for provided address %v. This happens only if remote and this minio run with different set of endpoints", args.Addr)
@ -126,6 +151,11 @@ type RemoteTargetExistArgs struct {
// RemoteTargetExist - handles target ID exist RPC call which checks whether given target ID is a HTTP client target or not. // RemoteTargetExist - handles target ID exist RPC call which checks whether given target ID is a HTTP client target or not.
func (receiver *peerRPCReceiver) RemoteTargetExist(args *RemoteTargetExistArgs, reply *bool) error { func (receiver *peerRPCReceiver) RemoteTargetExist(args *RemoteTargetExistArgs, reply *bool) error {
objAPI := newObjectLayerFn()
if objAPI == nil {
return errServerNotInitialized
}
*reply = globalNotificationSys.RemoteTargetExist(args.BucketName, args.TargetID) *reply = globalNotificationSys.RemoteTargetExist(args.BucketName, args.TargetID)
return nil return nil
} }
@ -140,6 +170,11 @@ type SendEventArgs struct {
// SendEvent - handles send event RPC call which sends given event to target by given target ID. // SendEvent - handles send event RPC call which sends given event to target by given target ID.
func (receiver *peerRPCReceiver) SendEvent(args *SendEventArgs, reply *bool) error { func (receiver *peerRPCReceiver) SendEvent(args *SendEventArgs, reply *bool) error {
objAPI := newObjectLayerFn()
if objAPI == nil {
return errServerNotInitialized
}
// Set default to true to keep the target. // Set default to true to keep the target.
*reply = true *reply = true
errs := globalNotificationSys.send(args.BucketName, args.Event, args.TargetID) errs := globalNotificationSys.send(args.BucketName, args.Event, args.TargetID)
@ -159,6 +194,11 @@ func (receiver *peerRPCReceiver) SendEvent(args *SendEventArgs, reply *bool) err
// LoadCredentials - handles load credentials RPC call. // LoadCredentials - handles load credentials RPC call.
func (receiver *peerRPCReceiver) LoadCredentials(args *AuthArgs, reply *VoidReply) error { func (receiver *peerRPCReceiver) LoadCredentials(args *AuthArgs, reply *VoidReply) error {
objAPI := newObjectLayerFn()
if objAPI == nil {
return errServerNotInitialized
}
// Construct path to config.json for the given bucket. // Construct path to config.json for the given bucket.
configFile := path.Join(bucketConfigPrefix, minioConfigFile) configFile := path.Join(bucketConfigPrefix, minioConfigFile)
transactionConfigFile := configFile + ".transaction" transactionConfigFile := configFile + ".transaction"

Loading…
Cancel
Save