mirror of
https://github.com/minio/minio.git
synced 2025-01-11 23:13:23 -05:00
parent
669783f875
commit
1c941fd787
@ -53,8 +53,8 @@ type RPCLoginArgs struct {
|
|||||||
// with subsequent requests.
|
// with subsequent requests.
|
||||||
type RPCLoginReply struct {
|
type RPCLoginReply struct {
|
||||||
Token string
|
Token string
|
||||||
ServerVersion string
|
|
||||||
Timestamp time.Time
|
Timestamp time.Time
|
||||||
|
ServerVersion string
|
||||||
}
|
}
|
||||||
|
|
||||||
// Validates if incoming token is valid.
|
// Validates if incoming token is valid.
|
||||||
@ -95,6 +95,7 @@ type AuthRPCClient struct {
|
|||||||
isLoggedIn bool // Indicates if the auth client has been logged in and token is valid.
|
isLoggedIn bool // Indicates if the auth client has been logged in and token is valid.
|
||||||
token string // JWT based token
|
token string // JWT based token
|
||||||
tstamp time.Time // Timestamp as received on Login RPC.
|
tstamp time.Time // Timestamp as received on Login RPC.
|
||||||
|
serverVerison string // Server version exchanged by the RPC.
|
||||||
}
|
}
|
||||||
|
|
||||||
// newAuthClient - returns a jwt based authenticated (go) rpc client, which does automatic reconnect.
|
// newAuthClient - returns a jwt based authenticated (go) rpc client, which does automatic reconnect.
|
||||||
@ -129,9 +130,14 @@ func (authClient *AuthRPCClient) Login() error {
|
|||||||
}, &reply); err != nil {
|
}, &reply); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
// Validate if version do indeed match.
|
||||||
|
if reply.ServerVersion != Version {
|
||||||
|
return errServerVersionMismatch
|
||||||
|
}
|
||||||
// Set token, time stamp as received from a successful login call.
|
// Set token, time stamp as received from a successful login call.
|
||||||
authClient.token = reply.Token
|
authClient.token = reply.Token
|
||||||
authClient.tstamp = reply.Timestamp
|
authClient.tstamp = reply.Timestamp
|
||||||
|
authClient.serverVerison = reply.ServerVersion
|
||||||
authClient.isLoggedIn = true
|
authClient.isLoggedIn = true
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -21,6 +21,9 @@ import "errors"
|
|||||||
// errServerNotInitialized - server not initialized.
|
// errServerNotInitialized - server not initialized.
|
||||||
var errServerNotInitialized = errors.New("Server not initialized, please try again.")
|
var errServerNotInitialized = errors.New("Server not initialized, please try again.")
|
||||||
|
|
||||||
|
// errServerVersionMismatch - server versions do not match.
|
||||||
|
var errServerVersionMismatch = errors.New("Server versions do not match.")
|
||||||
|
|
||||||
/// Auth operations
|
/// Auth operations
|
||||||
|
|
||||||
// Login - login handler.
|
// Login - login handler.
|
||||||
|
@ -154,6 +154,7 @@ func (l *lockServer) LoginHandler(args *RPCLoginArgs, reply *RPCLoginReply) erro
|
|||||||
}
|
}
|
||||||
reply.Token = token
|
reply.Token = token
|
||||||
reply.Timestamp = l.timestamp
|
reply.Timestamp = l.timestamp
|
||||||
|
reply.ServerVersion = Version
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -50,7 +50,6 @@ func initDsyncNodes(disks []string, port int) error {
|
|||||||
path: pathutil.Join(lockRPCPath, disk[idx+1:]),
|
path: pathutil.Join(lockRPCPath, disk[idx+1:]),
|
||||||
loginMethod: "Dsync.LoginHandler",
|
loginMethod: "Dsync.LoginHandler",
|
||||||
}))
|
}))
|
||||||
|
|
||||||
if isLocalStorage(disk) && myNode == -1 {
|
if isLocalStorage(disk) && myNode == -1 {
|
||||||
myNode = len(clnts) - 1
|
myNode = len(clnts) - 1
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,7 @@ import (
|
|||||||
"net/rpc"
|
"net/rpc"
|
||||||
"path"
|
"path"
|
||||||
"strings"
|
"strings"
|
||||||
|
"time"
|
||||||
|
|
||||||
router "github.com/gorilla/mux"
|
router "github.com/gorilla/mux"
|
||||||
"github.com/minio/minio/pkg/disk"
|
"github.com/minio/minio/pkg/disk"
|
||||||
@ -32,6 +33,7 @@ import (
|
|||||||
type storageServer struct {
|
type storageServer struct {
|
||||||
storage StorageAPI
|
storage StorageAPI
|
||||||
path string
|
path string
|
||||||
|
timestamp time.Time
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Auth operations
|
/// Auth operations
|
||||||
@ -50,6 +52,7 @@ func (s *storageServer) LoginHandler(args *RPCLoginArgs, reply *RPCLoginReply) e
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
reply.Token = token
|
reply.Token = token
|
||||||
|
reply.Timestamp = s.timestamp
|
||||||
reply.ServerVersion = Version
|
reply.ServerVersion = Version
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -213,6 +216,7 @@ func newRPCServer(serverConfig serverCmdConfig) (servers []*storageServer, err e
|
|||||||
for _, ignoredExport := range ignoredExports {
|
for _, ignoredExport := range ignoredExports {
|
||||||
skipDisks[ignoredExport] = true
|
skipDisks[ignoredExport] = true
|
||||||
}
|
}
|
||||||
|
t := time.Now().UTC()
|
||||||
for _, export := range exports {
|
for _, export := range exports {
|
||||||
if skipDisks[export] {
|
if skipDisks[export] {
|
||||||
continue
|
continue
|
||||||
@ -233,6 +237,7 @@ func newRPCServer(serverConfig serverCmdConfig) (servers []*storageServer, err e
|
|||||||
servers = append(servers, &storageServer{
|
servers = append(servers, &storageServer{
|
||||||
storage: storage,
|
storage: storage,
|
||||||
path: export,
|
path: export,
|
||||||
|
timestamp: t,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user