headscale/acls_test.go

166 lines
4.8 KiB
Go
Raw Normal View History

2021-07-03 17:55:32 +08:00
package headscale
import (
"gopkg.in/check.v1"
)
func (s *Suite) TestWrongPath(c *check.C) {
2021-11-16 00:16:04 +08:00
err := app.LoadACLPolicy("asdfg")
2021-07-03 17:55:32 +08:00
c.Assert(err, check.NotNil)
}
func (s *Suite) TestBrokenHuJson(c *check.C) {
2021-11-16 00:16:04 +08:00
err := app.LoadACLPolicy("./tests/acls/broken.hujson")
2021-07-03 17:55:32 +08:00
c.Assert(err, check.NotNil)
}
func (s *Suite) TestInvalidPolicyHuson(c *check.C) {
2021-11-16 00:16:04 +08:00
err := app.LoadACLPolicy("./tests/acls/invalid.hujson")
2021-07-03 17:55:32 +08:00
c.Assert(err, check.NotNil)
2021-07-03 23:31:32 +08:00
c.Assert(err, check.Equals, errorEmptyPolicy)
2021-07-03 17:55:32 +08:00
}
2021-07-03 23:31:32 +08:00
func (s *Suite) TestParseHosts(c *check.C) {
2021-11-16 00:16:04 +08:00
var hosts Hosts
err := hosts.UnmarshalJSON(
2021-11-13 16:36:45 +08:00
[]byte(
`{"example-host-1": "100.100.100.100","example-host-2": "100.100.101.100/24"}`,
),
)
2021-11-16 00:16:04 +08:00
c.Assert(hosts, check.NotNil)
2021-07-03 17:55:32 +08:00
c.Assert(err, check.IsNil)
2021-07-03 23:31:32 +08:00
}
func (s *Suite) TestParseInvalidCIDR(c *check.C) {
2021-11-16 00:16:04 +08:00
var hosts Hosts
err := hosts.UnmarshalJSON([]byte(`{"example-host-1": "100.100.100.100/42"}`))
c.Assert(hosts, check.IsNil)
2021-07-03 23:31:32 +08:00
c.Assert(err, check.NotNil)
}
func (s *Suite) TestRuleInvalidGeneration(c *check.C) {
2021-11-16 00:16:04 +08:00
err := app.LoadACLPolicy("./tests/acls/acl_policy_invalid.hujson")
2021-07-03 23:31:32 +08:00
c.Assert(err, check.NotNil)
}
func (s *Suite) TestBasicRule(c *check.C) {
2021-11-16 00:16:04 +08:00
err := app.LoadACLPolicy("./tests/acls/acl_policy_basic_1.hujson")
2021-07-03 23:31:32 +08:00
c.Assert(err, check.IsNil)
2021-11-16 00:16:04 +08:00
rules, err := app.generateACLRules()
2021-07-03 23:31:32 +08:00
c.Assert(err, check.IsNil)
2021-07-04 19:01:41 +08:00
c.Assert(rules, check.NotNil)
}
func (s *Suite) TestPortRange(c *check.C) {
2021-11-16 00:16:04 +08:00
err := app.LoadACLPolicy("./tests/acls/acl_policy_basic_range.hujson")
2021-07-04 19:01:41 +08:00
c.Assert(err, check.IsNil)
2021-11-16 00:16:04 +08:00
rules, err := app.generateACLRules()
2021-07-04 19:01:41 +08:00
c.Assert(err, check.IsNil)
c.Assert(rules, check.NotNil)
c.Assert(rules, check.HasLen, 1)
c.Assert((rules)[0].DstPorts, check.HasLen, 1)
c.Assert((rules)[0].DstPorts[0].Ports.First, check.Equals, uint16(5400))
c.Assert((rules)[0].DstPorts[0].Ports.Last, check.Equals, uint16(5500))
2021-07-04 19:01:41 +08:00
}
func (s *Suite) TestPortWildcard(c *check.C) {
2021-11-16 00:16:04 +08:00
err := app.LoadACLPolicy("./tests/acls/acl_policy_basic_wildcards.hujson")
2021-07-04 19:01:41 +08:00
c.Assert(err, check.IsNil)
2021-11-16 00:16:04 +08:00
rules, err := app.generateACLRules()
2021-07-04 19:01:41 +08:00
c.Assert(err, check.IsNil)
c.Assert(rules, check.NotNil)
c.Assert(rules, check.HasLen, 1)
c.Assert((rules)[0].DstPorts, check.HasLen, 1)
c.Assert((rules)[0].DstPorts[0].Ports.First, check.Equals, uint16(0))
c.Assert((rules)[0].DstPorts[0].Ports.Last, check.Equals, uint16(65535))
c.Assert((rules)[0].SrcIPs, check.HasLen, 1)
c.Assert((rules)[0].SrcIPs[0], check.Equals, "*")
2021-07-04 19:01:41 +08:00
}
func (s *Suite) TestPortNamespace(c *check.C) {
2021-11-16 00:16:04 +08:00
namespace, err := app.CreateNamespace("testnamespace")
2021-07-04 19:01:41 +08:00
c.Assert(err, check.IsNil)
2021-11-16 00:16:04 +08:00
pak, err := app.CreatePreAuthKey(namespace.Name, false, false, nil)
2021-07-04 19:01:41 +08:00
c.Assert(err, check.IsNil)
2021-11-16 00:16:04 +08:00
_, err = app.GetMachine("testnamespace", "testmachine")
2021-07-04 19:01:41 +08:00
c.Assert(err, check.NotNil)
2021-11-16 00:16:04 +08:00
ip, _ := app.getAvailableIP()
machine := Machine{
2021-07-04 19:01:41 +08:00
ID: 0,
MachineKey: "foo",
NodeKey: "bar",
DiscoKey: "faa",
Name: "testmachine",
2021-11-16 00:16:04 +08:00
NamespaceID: namespace.ID,
2021-07-04 19:01:41 +08:00
Registered: true,
RegisterMethod: "authKey",
IPAddress: ip.String(),
AuthKeyID: uint(pak.ID),
}
2021-11-16 00:16:04 +08:00
app.db.Save(&machine)
2021-07-04 19:01:41 +08:00
2021-11-16 00:16:04 +08:00
err = app.LoadACLPolicy(
"./tests/acls/acl_policy_basic_namespace_as_user.hujson",
)
2021-07-04 19:01:41 +08:00
c.Assert(err, check.IsNil)
2021-11-16 00:16:04 +08:00
rules, err := app.generateACLRules()
2021-07-04 19:01:41 +08:00
c.Assert(err, check.IsNil)
c.Assert(rules, check.NotNil)
c.Assert(rules, check.HasLen, 1)
c.Assert((rules)[0].DstPorts, check.HasLen, 1)
c.Assert((rules)[0].DstPorts[0].Ports.First, check.Equals, uint16(0))
c.Assert((rules)[0].DstPorts[0].Ports.Last, check.Equals, uint16(65535))
c.Assert((rules)[0].SrcIPs, check.HasLen, 1)
c.Assert((rules)[0].SrcIPs[0], check.Not(check.Equals), "not an ip")
c.Assert((rules)[0].SrcIPs[0], check.Equals, ip.String())
2021-07-03 17:55:32 +08:00
}
2021-07-04 19:23:31 +08:00
func (s *Suite) TestPortGroup(c *check.C) {
2021-11-16 00:16:04 +08:00
namespace, err := app.CreateNamespace("testnamespace")
2021-07-04 19:23:31 +08:00
c.Assert(err, check.IsNil)
2021-11-16 00:16:04 +08:00
pak, err := app.CreatePreAuthKey(namespace.Name, false, false, nil)
2021-07-04 19:23:31 +08:00
c.Assert(err, check.IsNil)
2021-11-16 00:16:04 +08:00
_, err = app.GetMachine("testnamespace", "testmachine")
2021-07-04 19:23:31 +08:00
c.Assert(err, check.NotNil)
2021-11-16 00:16:04 +08:00
ip, _ := app.getAvailableIP()
machine := Machine{
2021-07-04 19:23:31 +08:00
ID: 0,
MachineKey: "foo",
NodeKey: "bar",
DiscoKey: "faa",
Name: "testmachine",
2021-11-16 00:16:04 +08:00
NamespaceID: namespace.ID,
2021-07-04 19:23:31 +08:00
Registered: true,
RegisterMethod: "authKey",
IPAddress: ip.String(),
AuthKeyID: uint(pak.ID),
}
2021-11-16 00:16:04 +08:00
app.db.Save(&machine)
2021-11-16 00:16:04 +08:00
err = app.LoadACLPolicy("./tests/acls/acl_policy_basic_groups.hujson")
2021-07-04 19:23:31 +08:00
c.Assert(err, check.IsNil)
2021-11-16 00:16:04 +08:00
rules, err := app.generateACLRules()
2021-07-04 19:23:31 +08:00
c.Assert(err, check.IsNil)
c.Assert(rules, check.NotNil)
c.Assert(rules, check.HasLen, 1)
c.Assert((rules)[0].DstPorts, check.HasLen, 1)
c.Assert((rules)[0].DstPorts[0].Ports.First, check.Equals, uint16(0))
c.Assert((rules)[0].DstPorts[0].Ports.Last, check.Equals, uint16(65535))
c.Assert((rules)[0].SrcIPs, check.HasLen, 1)
c.Assert((rules)[0].SrcIPs[0], check.Not(check.Equals), "not an ip")
c.Assert((rules)[0].SrcIPs[0], check.Equals, ip.String())
2021-07-04 19:23:31 +08:00
}