ipn/ipnlocal: use presence of NodeID to identify logins

The profileManager was using the LoginName as a proxy to figure out if the profile
had logged in, however the LoginName is not present if the node was created with an
Auth Key that does not have an associated user.

Signed-off-by: Maisem Ali <maisem@tailscale.com>
This commit is contained in:
Maisem Ali 2023-02-06 21:18:21 -08:00 committed by Maisem Ali
parent 2a094181df
commit 0fd2f71a1e
3 changed files with 6 additions and 1 deletions

View File

@ -185,7 +185,7 @@ func init() {
func (pm *profileManager) SetPrefs(prefsIn ipn.PrefsView) error { func (pm *profileManager) SetPrefs(prefsIn ipn.PrefsView) error {
prefs := prefsIn.AsStruct().View() prefs := prefsIn.AsStruct().View()
newPersist := prefs.Persist().AsStruct() newPersist := prefs.Persist().AsStruct()
if newPersist == nil || newPersist.LoginName == "" { if newPersist == nil || newPersist.NodeID == "" {
return pm.setPrefsLocked(prefs) return pm.setPrefsLocked(prefs)
} }
up := newPersist.UserProfile up := newPersist.UserProfile

View File

@ -5,6 +5,7 @@
import ( import (
"fmt" "fmt"
"strconv"
"testing" "testing"
"tailscale.com/ipn" "tailscale.com/ipn"
@ -337,6 +338,7 @@ func TestProfileManagementWindows(t *testing.T) {
ID: id, ID: id,
LoginName: loginName, LoginName: loginName,
}, },
NodeID: tailcfg.StableNodeID(strconv.Itoa(int(id))),
} }
if err := pm.SetPrefs(p.View()); err != nil { if err := pm.SetPrefs(p.View()); err != nil {
t.Fatal(err) t.Fatal(err)

View File

@ -473,6 +473,7 @@ func TestStateMachine(t *testing.T) {
notifies.expect(3) notifies.expect(3)
cc.persist.LoginName = "user1" cc.persist.LoginName = "user1"
cc.persist.UserProfile.LoginName = "user1" cc.persist.UserProfile.LoginName = "user1"
cc.persist.NodeID = "node1"
cc.send(nil, "", true, &netmap.NetworkMap{}) cc.send(nil, "", true, &netmap.NetworkMap{})
{ {
nn := notifies.drain(3) nn := notifies.drain(3)
@ -699,6 +700,7 @@ func TestStateMachine(t *testing.T) {
notifies.expect(3) notifies.expect(3)
cc.persist.LoginName = "user2" cc.persist.LoginName = "user2"
cc.persist.UserProfile.LoginName = "user2" cc.persist.UserProfile.LoginName = "user2"
cc.persist.NodeID = "node2"
cc.send(nil, "", true, &netmap.NetworkMap{ cc.send(nil, "", true, &netmap.NetworkMap{
MachineStatus: tailcfg.MachineAuthorized, MachineStatus: tailcfg.MachineAuthorized,
}) })
@ -835,6 +837,7 @@ func TestStateMachine(t *testing.T) {
notifies.expect(3) notifies.expect(3)
cc.persist.LoginName = "user3" cc.persist.LoginName = "user3"
cc.persist.UserProfile.LoginName = "user3" cc.persist.UserProfile.LoginName = "user3"
cc.persist.NodeID = "node3"
cc.send(nil, "", true, &netmap.NetworkMap{ cc.send(nil, "", true, &netmap.NetworkMap{
MachineStatus: tailcfg.MachineAuthorized, MachineStatus: tailcfg.MachineAuthorized,
}) })