mirror of
				https://github.com/tailscale/tailscale.git
				synced 2025-10-25 10:09:17 +00:00 
			
		
		
		
	ipn: replace SetWantRunning(bool) with EditPrefs(MaskedPrefs)
This adds a new ipn.MaskedPrefs embedding a ipn.Prefs, along with a
bunch of "has bits", kept in sync with tests & reflect.
Then it adds a Prefs.ApplyEdits(MaskedPrefs) method.
Then the ipn.Backend interface loses its weirdo SetWantRunning(bool)
method (that I added in 483141094c for "tailscale down")
and replaces it with EditPrefs (alongside the existing SetPrefs for now).
Then updates 'tailscale down' to use EditPrefs instead of SetWantRunning.
In the future, we can use this to do more interesting things with the
CLI, reconfiguring only certain properties without the reset-the-world
"tailscale up".
Updates #1436
Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>
			
			
This commit is contained in:
		 Brad Fitzpatrick
					Brad Fitzpatrick
				
			
				
					committed by
					
						 Brad Fitzpatrick
						Brad Fitzpatrick
					
				
			
			
				
	
			
			
			 Brad Fitzpatrick
						Brad Fitzpatrick
					
				
			
						parent
						
							4ed6b62c7a
						
					
				
				
					commit
					53cfff109b
				
			| @@ -1260,16 +1260,17 @@ func (b *LocalBackend) SetCurrentUserID(uid string) { | ||||
| 	b.mu.Unlock() | ||||
| } | ||||
|  | ||||
| func (b *LocalBackend) SetWantRunning(wantRunning bool) { | ||||
| func (b *LocalBackend) EditPrefs(mp *ipn.MaskedPrefs) { | ||||
| 	b.mu.Lock() | ||||
| 	new := b.prefs.Clone() | ||||
| 	b.mu.Unlock() | ||||
| 	if new.WantRunning == wantRunning { | ||||
| 	p0 := b.prefs.Clone() | ||||
| 	p1 := b.prefs.Clone() | ||||
| 	p1.ApplyEdits(mp) | ||||
| 	if p1.Equals(p0) { | ||||
| 		b.mu.Unlock() | ||||
| 		return | ||||
| 	} | ||||
| 	new.WantRunning = wantRunning | ||||
| 	b.logf("SetWantRunning: %v", wantRunning) | ||||
| 	b.SetPrefs(new) | ||||
| 	b.logf("EditPrefs: %v", mp.Pretty()) | ||||
| 	b.setPrefsLockedOnEntry("EditPrefs", p1) | ||||
| } | ||||
|  | ||||
| // SetPrefs saves new user preferences and propagates them throughout | ||||
| @@ -1278,9 +1279,13 @@ func (b *LocalBackend) SetPrefs(newp *ipn.Prefs) { | ||||
| 	if newp == nil { | ||||
| 		panic("SetPrefs got nil prefs") | ||||
| 	} | ||||
|  | ||||
| 	b.mu.Lock() | ||||
| 	b.setPrefsLockedOnEntry("SetPrefs", newp) | ||||
| } | ||||
|  | ||||
| // setPrefsLockedOnEntry requires b.mu be held to call it, but it | ||||
| // unlocks b.mu when done. | ||||
| func (b *LocalBackend) setPrefsLockedOnEntry(caller string, newp *ipn.Prefs) { | ||||
| 	netMap := b.netMap | ||||
| 	stateKey := b.stateKey | ||||
|  | ||||
| @@ -1303,13 +1308,15 @@ func (b *LocalBackend) SetPrefs(newp *ipn.Prefs) { | ||||
|  | ||||
| 	if stateKey != "" { | ||||
| 		if err := b.store.WriteState(stateKey, newp.ToBytes()); err != nil { | ||||
| 			b.logf("Failed to save new controlclient state: %v", err) | ||||
| 			b.logf("failed to save new controlclient state: %v", err) | ||||
| 		} | ||||
| 	} | ||||
| 	b.writeServerModeStartState(userID, newp) | ||||
|  | ||||
| 	// [GRINDER STATS LINE] - please don't remove (used for log parsing) | ||||
| 	b.logf("SetPrefs: %v", newp.Pretty()) | ||||
| 	if caller == "SetPrefs" { | ||||
| 		b.logf("SetPrefs: %v", newp.Pretty()) | ||||
| 	} | ||||
| 	if netMap != nil { | ||||
| 		if login := netMap.UserProfiles[netMap.User].LoginName; login != "" { | ||||
| 			if newp.Persist == nil { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user