1
0
mirror of https://github.com/juanfont/headscale.git synced 2025-01-04 00:09:34 +01:00

Add missing iff to handle expired preauthkey machines

This commit is contained in:
Kristoffer Dalby 2021-11-24 12:15:32 +00:00
parent 9968992be0
commit fdd64d98c8

20
api.go
View File

@ -364,15 +364,21 @@ func (h *Headscale) handleMachineExpired(
Str("machine", machine.Name). Str("machine", machine.Name).
Msg("Machine registration has expired. Sending a authurl to register") Msg("Machine registration has expired. Sending a authurl to register")
if h.cfg.OIDC.Issuer != "" { if registerRequest.Auth.AuthKey != "" {
resp.AuthURL = fmt.Sprintf("%s/oidc/register/%s", h.handleAuthKey(ctx, machineKey, registerRequest, machine)
strings.TrimSuffix(h.cfg.ServerURL, "/"), idKey.HexString())
} else { return
resp.AuthURL = fmt.Sprintf("%s/register?key=%s",
strings.TrimSuffix(h.cfg.ServerURL, "/"), idKey.HexString())
} }
respBody, err := encode(resp, &idKey, h.privateKey) if h.cfg.OIDC.Issuer != "" {
resp.AuthURL = fmt.Sprintf("%s/oidc/register/%s",
strings.TrimSuffix(h.cfg.ServerURL, "/"), machineKey.HexString())
} else {
resp.AuthURL = fmt.Sprintf("%s/register?key=%s",
strings.TrimSuffix(h.cfg.ServerURL, "/"), machineKey.HexString())
}
respBody, err := encode(resp, &machineKey, h.privateKey)
if err != nil { if err != nil {
log.Error(). log.Error().
Str("handler", "Registration"). Str("handler", "Registration").