diff options
| author | Paul Buetow <pbuetow@mimecast.com> | 2020-02-28 17:29:22 +0000 |
|---|---|---|
| committer | Paul Buetow <pbuetow@mimecast.com> | 2020-02-28 17:29:22 +0000 |
| commit | 7911b102171309dfc43bc2faccac6de9e490f175 (patch) | |
| tree | ef489750dbc3e0c31402a88dcdadddd8533377ee /internal/server/server.go | |
| parent | 3cdc86e20cbd311fb9c85cef63876a2f39e5e74d (diff) | |
| parent | 1922e448e84e218cc39d4394e9b4becfa6f0a83d (diff) | |
merge master
Diffstat (limited to 'internal/server/server.go')
| -rw-r--r-- | internal/server/server.go | 36 |
1 files changed, 33 insertions, 3 deletions
diff --git a/internal/server/server.go b/internal/server/server.go index 5ec46e7..eb0cdd7 100644 --- a/internal/server/server.go +++ b/internal/server/server.go @@ -6,6 +6,7 @@ import ( "fmt" "io" "net" + "strings" "time" "github.com/mimecast/dtail/internal/config" @@ -238,16 +239,45 @@ func (s *Server) handleRequests(ctx context.Context, sshConn gossh.Conn, in <-ch func (s *Server) backgroundUserCallback(c gossh.ConnMetadata, authPayload []byte) (*gossh.Permissions, error) { user := user.New(c.User(), c.RemoteAddr().String()) + authInfo := string(authPayload) - if user.Name == config.ControlUser && string(authPayload) == config.ControlUser { + if user.Name == config.ControlUser && authInfo == config.ControlUser { logger.Debug(user, "Granting permissions to control user") return nil, nil } - if user.Name == config.ScheduleUser && string(authPayload) == s.sched.authPayload { - logger.Debug(user, "Granting permissions to schedule user") + if user.Name == config.ScheduleUser && s.schedueleUserCanHaveSSHSession(c.RemoteAddr().String(), user, authInfo) { + logger.Debug(user, "Granting SSH connection to schedule user") return nil, nil } return nil, fmt.Errorf("user %s not authorized", user) } + +func (s *Server) schedueleUserCanHaveSSHSession(addr string, user *user.User, jobName string) bool { + logger.Debug("schedueleUserCanHaveSSHSession", user, jobName) + splitted := strings.Split(addr, ":") + ip := splitted[0] + + for _, job := range config.Server.Schedule { + if job.Name != jobName { + continue + } + for _, myAddr := range job.AllowFrom { + myIps, err := net.LookupIP(myAddr) + if err != nil { + logger.Error(user, myAddr, err) + continue + } + + for _, myIp := range myIps { + logger.Debug("schedueleUserCanHaveSSHSession", "Comparing IP addresses", ip, myIp.String()) + if ip == myIp.String() { + return true + } + } + } + } + + return false +} |
