mirror of
https://github.com/crowdsecurity/crowdsec.git
synced 2025-05-11 12:25:53 +02:00
80 lines
2.1 KiB
Go
80 lines
2.1 KiB
Go
package v1
|
|
|
|
import (
|
|
"errors"
|
|
"net"
|
|
"net/http"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
"github.com/go-openapi/strfmt"
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
"github.com/crowdsecurity/crowdsec/pkg/models"
|
|
"github.com/crowdsecurity/crowdsec/pkg/types"
|
|
)
|
|
|
|
func (c *Controller) shouldAutoRegister(token string, gctx *gin.Context) (bool, error) {
|
|
if !*c.AutoRegisterCfg.Enable {
|
|
return false, nil
|
|
}
|
|
|
|
clientIP := net.ParseIP(gctx.ClientIP())
|
|
|
|
// Can probaby happen if using unix socket ?
|
|
if clientIP == nil {
|
|
log.Warnf("Failed to parse client IP for watcher self registration: %s", gctx.ClientIP())
|
|
return false, nil
|
|
}
|
|
|
|
if token == "" || c.AutoRegisterCfg == nil {
|
|
return false, nil
|
|
}
|
|
|
|
// Check the token
|
|
if token != c.AutoRegisterCfg.Token {
|
|
return false, errors.New("invalid token for auto registration")
|
|
}
|
|
|
|
// Check the source IP
|
|
for _, ipRange := range c.AutoRegisterCfg.AllowedRangesParsed {
|
|
if ipRange.Contains(clientIP) {
|
|
return true, nil
|
|
}
|
|
}
|
|
|
|
return false, errors.New("IP not in allowed range for auto registration")
|
|
}
|
|
|
|
func (c *Controller) CreateMachine(gctx *gin.Context) {
|
|
var input models.WatcherRegistrationRequest
|
|
|
|
if err := gctx.ShouldBindJSON(&input); err != nil {
|
|
gctx.JSON(http.StatusBadRequest, gin.H{"message": err.Error()})
|
|
return
|
|
}
|
|
|
|
if err := input.Validate(strfmt.Default); err != nil {
|
|
gctx.JSON(http.StatusUnprocessableEntity, gin.H{"message": err.Error()})
|
|
return
|
|
}
|
|
|
|
autoRegister, err := c.shouldAutoRegister(input.RegistrationToken, gctx)
|
|
if err != nil {
|
|
log.WithFields(log.Fields{"ip": gctx.ClientIP(), "machine_id": *input.MachineID}).Errorf("Auto-register failed: %s", err)
|
|
gctx.JSON(http.StatusUnauthorized, gin.H{"message": err.Error()})
|
|
|
|
return
|
|
}
|
|
|
|
if _, err := c.DBClient.CreateMachine(input.MachineID, input.Password, gctx.ClientIP(), autoRegister, false, types.PasswordAuthType); err != nil {
|
|
c.HandleDBErrors(gctx, err)
|
|
return
|
|
}
|
|
|
|
if autoRegister {
|
|
log.WithFields(log.Fields{"ip": gctx.ClientIP(), "machine_id": *input.MachineID}).Info("Auto-registered machine")
|
|
gctx.Status(http.StatusAccepted)
|
|
} else {
|
|
gctx.Status(http.StatusCreated)
|
|
}
|
|
}
|