mirror of
				https://github.com/juanfont/headscale.git
				synced 2025-10-30 23:51:03 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			183 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			183 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package headscale
 | |
| 
 | |
| import (
 | |
| 	"time"
 | |
| 
 | |
| 	"gopkg.in/check.v1"
 | |
| )
 | |
| 
 | |
| func (*Suite) TestCreatePreAuthKey(c *check.C) {
 | |
| 	_, err := h.CreatePreAuthKey("bogus", true, false, nil)
 | |
| 
 | |
| 	c.Assert(err, check.NotNil)
 | |
| 
 | |
| 	n, err := h.CreateNamespace("test")
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	k, err := h.CreatePreAuthKey(n.Name, true, false, nil)
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	// Did we get a valid key?
 | |
| 	c.Assert(k.Key, check.NotNil)
 | |
| 	c.Assert(len(k.Key), check.Equals, 48)
 | |
| 
 | |
| 	// Make sure the Namespace association is populated
 | |
| 	c.Assert(k.Namespace.Name, check.Equals, n.Name)
 | |
| 
 | |
| 	_, err = h.GetPreAuthKeys("bogus")
 | |
| 	c.Assert(err, check.NotNil)
 | |
| 
 | |
| 	keys, err := h.GetPreAuthKeys(n.Name)
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 	c.Assert(len(*keys), check.Equals, 1)
 | |
| 
 | |
| 	// Make sure the Namespace association is populated
 | |
| 	c.Assert((*keys)[0].Namespace.Name, check.Equals, n.Name)
 | |
| }
 | |
| 
 | |
| func (*Suite) TestExpiredPreAuthKey(c *check.C) {
 | |
| 	n, err := h.CreateNamespace("test2")
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	now := time.Now()
 | |
| 	pak, err := h.CreatePreAuthKey(n.Name, true, false, &now)
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	p, err := h.checkKeyValidity(pak.Key)
 | |
| 	c.Assert(err, check.Equals, errorAuthKeyExpired)
 | |
| 	c.Assert(p, check.IsNil)
 | |
| }
 | |
| 
 | |
| func (*Suite) TestPreAuthKeyDoesNotExist(c *check.C) {
 | |
| 	p, err := h.checkKeyValidity("potatoKey")
 | |
| 	c.Assert(err, check.Equals, errorAuthKeyNotFound)
 | |
| 	c.Assert(p, check.IsNil)
 | |
| }
 | |
| 
 | |
| func (*Suite) TestValidateKeyOk(c *check.C) {
 | |
| 	n, err := h.CreateNamespace("test3")
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	pak, err := h.CreatePreAuthKey(n.Name, true, false, nil)
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	p, err := h.checkKeyValidity(pak.Key)
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 	c.Assert(p.ID, check.Equals, pak.ID)
 | |
| }
 | |
| 
 | |
| func (*Suite) TestAlreadyUsedKey(c *check.C) {
 | |
| 	n, err := h.CreateNamespace("test4")
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	pak, err := h.CreatePreAuthKey(n.Name, false, false, nil)
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	m := Machine{
 | |
| 		ID:             0,
 | |
| 		MachineKey:     "foo",
 | |
| 		NodeKey:        "bar",
 | |
| 		DiscoKey:       "faa",
 | |
| 		Name:           "testest",
 | |
| 		NamespaceID:    n.ID,
 | |
| 		Registered:     true,
 | |
| 		RegisterMethod: "authKey",
 | |
| 		AuthKeyID:      uint(pak.ID),
 | |
| 	}
 | |
| 	h.db.Save(&m)
 | |
| 
 | |
| 	p, err := h.checkKeyValidity(pak.Key)
 | |
| 	c.Assert(err, check.Equals, errorAuthKeyNotReusableAlreadyUsed)
 | |
| 	c.Assert(p, check.IsNil)
 | |
| }
 | |
| 
 | |
| func (*Suite) TestReusableBeingUsedKey(c *check.C) {
 | |
| 	n, err := h.CreateNamespace("test5")
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	pak, err := h.CreatePreAuthKey(n.Name, true, false, nil)
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	m := Machine{
 | |
| 		ID:             1,
 | |
| 		MachineKey:     "foo",
 | |
| 		NodeKey:        "bar",
 | |
| 		DiscoKey:       "faa",
 | |
| 		Name:           "testest",
 | |
| 		NamespaceID:    n.ID,
 | |
| 		Registered:     true,
 | |
| 		RegisterMethod: "authKey",
 | |
| 		AuthKeyID:      uint(pak.ID),
 | |
| 	}
 | |
| 	h.db.Save(&m)
 | |
| 
 | |
| 	p, err := h.checkKeyValidity(pak.Key)
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 	c.Assert(p.ID, check.Equals, pak.ID)
 | |
| }
 | |
| 
 | |
| func (*Suite) TestNotReusableNotBeingUsedKey(c *check.C) {
 | |
| 	n, err := h.CreateNamespace("test6")
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	pak, err := h.CreatePreAuthKey(n.Name, false, false, nil)
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	p, err := h.checkKeyValidity(pak.Key)
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 	c.Assert(p.ID, check.Equals, pak.ID)
 | |
| }
 | |
| 
 | |
| func (*Suite) TestEphemeralKey(c *check.C) {
 | |
| 	n, err := h.CreateNamespace("test7")
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	pak, err := h.CreatePreAuthKey(n.Name, false, true, nil)
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	now := time.Now()
 | |
| 	m := Machine{
 | |
| 		ID:             0,
 | |
| 		MachineKey:     "foo",
 | |
| 		NodeKey:        "bar",
 | |
| 		DiscoKey:       "faa",
 | |
| 		Name:           "testest",
 | |
| 		NamespaceID:    n.ID,
 | |
| 		Registered:     true,
 | |
| 		RegisterMethod: "authKey",
 | |
| 		LastSeen:       &now,
 | |
| 		AuthKeyID:      uint(pak.ID),
 | |
| 	}
 | |
| 	h.db.Save(&m)
 | |
| 
 | |
| 	_, err = h.checkKeyValidity(pak.Key)
 | |
| 	// Ephemeral keys are by definition reusable
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	_, err = h.GetMachine("test7", "testest")
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	h.expireEphemeralNodesWorker()
 | |
| 
 | |
| 	// The machine record should have been deleted
 | |
| 	_, err = h.GetMachine("test7", "testest")
 | |
| 	c.Assert(err, check.NotNil)
 | |
| }
 | |
| 
 | |
| func (*Suite) TestExpirePreauthKey(c *check.C) {
 | |
| 	n, err := h.CreateNamespace("test3")
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 
 | |
| 	pak, err := h.CreatePreAuthKey(n.Name, true, false, nil)
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 	c.Assert(pak.Expiration, check.IsNil)
 | |
| 
 | |
| 	err = h.MarkExpirePreAuthKey(pak)
 | |
| 	c.Assert(err, check.IsNil)
 | |
| 	c.Assert(pak.Expiration, check.NotNil)
 | |
| 
 | |
| 	p, err := h.checkKeyValidity(pak.Key)
 | |
| 	c.Assert(err, check.Equals, errorAuthKeyExpired)
 | |
| 	c.Assert(p, check.IsNil)
 | |
| }
 |