2020-02-05 22:16:58 +00:00
|
|
|
// Copyright (c) 2020 Tailscale Inc & AUTHORS All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package ipn
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
"time"
|
2020-03-27 20:26:35 +00:00
|
|
|
|
|
|
|
"tailscale.com/ipn/ipnstate"
|
2021-03-19 17:21:33 +00:00
|
|
|
"tailscale.com/tailcfg"
|
2021-02-05 23:44:46 +00:00
|
|
|
"tailscale.com/types/netmap"
|
2020-02-05 22:16:58 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type FakeBackend struct {
|
|
|
|
serverURL string
|
|
|
|
notify func(n Notify)
|
|
|
|
live bool
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *FakeBackend) Start(opts Options) error {
|
2020-02-19 05:03:22 +00:00
|
|
|
b.serverURL = opts.Prefs.ControlURL
|
2020-02-05 22:16:58 +00:00
|
|
|
if opts.Notify == nil {
|
|
|
|
log.Fatalf("FakeBackend.Start: opts.Notify is nil\n")
|
|
|
|
}
|
|
|
|
b.notify = opts.Notify
|
2020-02-03 23:58:40 +00:00
|
|
|
b.notify(Notify{Prefs: opts.Prefs})
|
2020-02-05 22:16:58 +00:00
|
|
|
nl := NeedsLogin
|
|
|
|
b.notify(Notify{State: &nl})
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *FakeBackend) newState(s State) {
|
|
|
|
b.notify(Notify{State: &s})
|
|
|
|
if s == Running {
|
|
|
|
b.live = true
|
|
|
|
} else {
|
|
|
|
b.live = false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *FakeBackend) StartLoginInteractive() {
|
|
|
|
u := b.serverURL + "/this/is/fake"
|
|
|
|
b.notify(Notify{BrowseToURL: &u})
|
2020-07-13 21:13:11 +01:00
|
|
|
b.login()
|
|
|
|
}
|
|
|
|
|
2021-03-19 17:21:33 +00:00
|
|
|
func (b *FakeBackend) Login(token *tailcfg.Oauth2Token) {
|
2020-07-13 21:13:11 +01:00
|
|
|
b.login()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *FakeBackend) login() {
|
2020-02-05 22:16:58 +00:00
|
|
|
b.newState(NeedsMachineAuth)
|
|
|
|
b.newState(Stopped)
|
|
|
|
// TODO(apenwarr): Fill in a more interesting netmap here.
|
2021-02-05 23:44:46 +00:00
|
|
|
b.notify(Notify{NetMap: &netmap.NetworkMap{}})
|
2020-02-05 22:16:58 +00:00
|
|
|
b.newState(Starting)
|
|
|
|
// TODO(apenwarr): Fill in a more interesting status.
|
|
|
|
b.notify(Notify{Engine: &EngineStatus{}})
|
|
|
|
b.newState(Running)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *FakeBackend) Logout() {
|
|
|
|
b.newState(NeedsLogin)
|
|
|
|
}
|
|
|
|
|
2020-02-20 19:07:00 +00:00
|
|
|
func (b *FakeBackend) SetPrefs(new *Prefs) {
|
|
|
|
if new == nil {
|
|
|
|
panic("FakeBackend.SetPrefs got nil prefs")
|
|
|
|
}
|
|
|
|
|
2020-02-27 20:20:29 +00:00
|
|
|
b.notify(Notify{Prefs: new.Clone()})
|
2020-02-05 22:16:58 +00:00
|
|
|
if new.WantRunning && !b.live {
|
|
|
|
b.newState(Starting)
|
|
|
|
b.newState(Running)
|
|
|
|
} else if !new.WantRunning && b.live {
|
|
|
|
b.newState(Stopped)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-11 03:42:04 +01:00
|
|
|
func (b *FakeBackend) SetWantRunning(v bool) {
|
|
|
|
b.SetPrefs(&Prefs{WantRunning: v})
|
|
|
|
}
|
|
|
|
|
2020-02-05 22:16:58 +00:00
|
|
|
func (b *FakeBackend) RequestEngineStatus() {
|
|
|
|
b.notify(Notify{Engine: &EngineStatus{}})
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *FakeBackend) FakeExpireAfter(x time.Duration) {
|
2021-02-05 23:44:46 +00:00
|
|
|
b.notify(Notify{NetMap: &netmap.NetworkMap{}})
|
2020-02-05 22:16:58 +00:00
|
|
|
}
|
2020-08-09 22:49:42 +01:00
|
|
|
|
2021-03-23 22:16:15 +00:00
|
|
|
func (b *FakeBackend) Ping(ip string, useTSMP bool) {
|
2020-08-09 22:49:42 +01:00
|
|
|
b.notify(Notify{PingResult: &ipnstate.PingResult{}})
|
|
|
|
}
|