2023-05-21 19:37:59 +03:00
|
|
|
package db
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/juanfont/headscale/hscontrol/types"
|
|
|
|
"github.com/juanfont/headscale/hscontrol/util"
|
|
|
|
"gopkg.in/check.v1"
|
|
|
|
"gorm.io/gorm"
|
2024-07-18 10:01:59 +02:00
|
|
|
"tailscale.com/types/ptr"
|
2023-05-21 19:37:59 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
func (s *Suite) TestCreateAndDestroyUser(c *check.C) {
|
|
|
|
user, err := db.CreateUser("test")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
c.Assert(user.Name, check.Equals, "test")
|
|
|
|
|
|
|
|
users, err := db.ListUsers()
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
c.Assert(len(users), check.Equals, 1)
|
|
|
|
|
|
|
|
err = db.DestroyUser("test")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
_, err = db.GetUser("test")
|
|
|
|
c.Assert(err, check.NotNil)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Suite) TestDestroyUserErrors(c *check.C) {
|
|
|
|
err := db.DestroyUser("test")
|
|
|
|
c.Assert(err, check.Equals, ErrUserNotFound)
|
|
|
|
|
|
|
|
user, err := db.CreateUser("test")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
pak, err := db.CreatePreAuthKey(user.Name, false, false, nil, nil)
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
err = db.DestroyUser("test")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
2024-02-08 17:28:19 +01:00
|
|
|
result := db.DB.Preload("User").First(&pak, "key = ?", pak.Key)
|
2023-05-21 19:37:59 +03:00
|
|
|
// destroying a user also deletes all associated preauthkeys
|
|
|
|
c.Assert(result.Error, check.Equals, gorm.ErrRecordNotFound)
|
|
|
|
|
|
|
|
user, err = db.CreateUser("test")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
pak, err = db.CreatePreAuthKey(user.Name, false, false, nil, nil)
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
2023-09-24 13:42:05 +02:00
|
|
|
node := types.Node{
|
2023-05-21 19:37:59 +03:00
|
|
|
ID: 0,
|
2023-09-24 13:42:05 +02:00
|
|
|
Hostname: "testnode",
|
2023-05-21 19:37:59 +03:00
|
|
|
UserID: user.ID,
|
|
|
|
RegisterMethod: util.RegisterMethodAuthKey,
|
2024-07-18 10:01:59 +02:00
|
|
|
AuthKeyID: ptr.To(pak.ID),
|
2023-05-21 19:37:59 +03:00
|
|
|
}
|
2024-05-16 02:40:14 +02:00
|
|
|
trx := db.DB.Save(&node)
|
|
|
|
c.Assert(trx.Error, check.IsNil)
|
2023-05-21 19:37:59 +03:00
|
|
|
|
|
|
|
err = db.DestroyUser("test")
|
|
|
|
c.Assert(err, check.Equals, ErrUserStillHasNodes)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Suite) TestRenameUser(c *check.C) {
|
|
|
|
userTest, err := db.CreateUser("test")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
c.Assert(userTest.Name, check.Equals, "test")
|
|
|
|
|
|
|
|
users, err := db.ListUsers()
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
c.Assert(len(users), check.Equals, 1)
|
|
|
|
|
|
|
|
err = db.RenameUser("test", "test-renamed")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
_, err = db.GetUser("test")
|
|
|
|
c.Assert(err, check.Equals, ErrUserNotFound)
|
|
|
|
|
|
|
|
_, err = db.GetUser("test-renamed")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
err = db.RenameUser("test-does-not-exit", "test")
|
|
|
|
c.Assert(err, check.Equals, ErrUserNotFound)
|
|
|
|
|
|
|
|
userTest2, err := db.CreateUser("test2")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
c.Assert(userTest2.Name, check.Equals, "test2")
|
|
|
|
|
|
|
|
err = db.RenameUser("test2", "test-renamed")
|
|
|
|
c.Assert(err, check.Equals, ErrUserExists)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Suite) TestSetMachineUser(c *check.C) {
|
|
|
|
oldUser, err := db.CreateUser("old")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
newUser, err := db.CreateUser("new")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
pak, err := db.CreatePreAuthKey(oldUser.Name, false, false, nil, nil)
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
2023-09-24 13:42:05 +02:00
|
|
|
node := types.Node{
|
2023-05-21 19:37:59 +03:00
|
|
|
ID: 0,
|
2023-09-24 13:42:05 +02:00
|
|
|
Hostname: "testnode",
|
2023-05-21 19:37:59 +03:00
|
|
|
UserID: oldUser.ID,
|
|
|
|
RegisterMethod: util.RegisterMethodAuthKey,
|
2024-07-18 10:01:59 +02:00
|
|
|
AuthKeyID: ptr.To(pak.ID),
|
2023-05-21 19:37:59 +03:00
|
|
|
}
|
2024-05-16 02:40:14 +02:00
|
|
|
trx := db.DB.Save(&node)
|
|
|
|
c.Assert(trx.Error, check.IsNil)
|
2023-09-24 13:42:05 +02:00
|
|
|
c.Assert(node.UserID, check.Equals, oldUser.ID)
|
2023-05-21 19:37:59 +03:00
|
|
|
|
2023-09-24 13:42:05 +02:00
|
|
|
err = db.AssignNodeToUser(&node, newUser.Name)
|
2023-05-21 19:37:59 +03:00
|
|
|
c.Assert(err, check.IsNil)
|
2023-09-24 13:42:05 +02:00
|
|
|
c.Assert(node.UserID, check.Equals, newUser.ID)
|
|
|
|
c.Assert(node.User.Name, check.Equals, newUser.Name)
|
2023-05-21 19:37:59 +03:00
|
|
|
|
2023-09-24 13:42:05 +02:00
|
|
|
err = db.AssignNodeToUser(&node, "non-existing-user")
|
2023-05-21 19:37:59 +03:00
|
|
|
c.Assert(err, check.Equals, ErrUserNotFound)
|
|
|
|
|
2023-09-24 13:42:05 +02:00
|
|
|
err = db.AssignNodeToUser(&node, newUser.Name)
|
2023-05-21 19:37:59 +03:00
|
|
|
c.Assert(err, check.IsNil)
|
2023-09-24 13:42:05 +02:00
|
|
|
c.Assert(node.UserID, check.Equals, newUser.ID)
|
|
|
|
c.Assert(node.User.Name, check.Equals, newUser.Name)
|
2023-05-21 19:37:59 +03:00
|
|
|
}
|