2023-03-28 19:39:22 +01:00
|
|
|
// Copyright (c) HashiCorp, Inc.
|
2023-08-11 09:12:13 -04:00
|
|
|
// SPDX-License-Identifier: BUSL-1.1
|
2023-03-28 19:39:22 +01:00
|
|
|
|
2022-03-27 16:29:30 +05:30
|
|
|
package testutils
|
2022-04-05 15:26:14 +01:00
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2022-03-27 16:29:30 +05:30
|
|
|
"github.com/stretchr/testify/require"
|
2022-04-05 14:10:06 -07:00
|
|
|
|
2023-01-04 12:40:34 +00:00
|
|
|
"github.com/hashicorp/go-uuid"
|
|
|
|
|
2022-04-05 14:10:06 -07:00
|
|
|
"github.com/hashicorp/consul/acl"
|
2022-06-17 10:24:43 +01:00
|
|
|
"github.com/hashicorp/consul/acl/resolver"
|
2023-01-04 12:40:34 +00:00
|
|
|
"github.com/hashicorp/consul/agent/structs"
|
2022-04-05 15:26:14 +01:00
|
|
|
)
|
|
|
|
|
2023-01-04 12:40:34 +00:00
|
|
|
func ACLAnonymous(t *testing.T) resolver.Result {
|
2022-06-17 10:24:43 +01:00
|
|
|
t.Helper()
|
|
|
|
|
2023-01-04 12:40:34 +00:00
|
|
|
return resolver.Result{
|
|
|
|
Authorizer: acl.DenyAll(),
|
|
|
|
ACLIdentity: &structs.ACLToken{
|
2023-01-09 13:28:53 -05:00
|
|
|
AccessorID: acl.AnonymousTokenID,
|
2023-01-04 12:40:34 +00:00
|
|
|
},
|
|
|
|
}
|
2022-06-17 10:24:43 +01:00
|
|
|
}
|
|
|
|
|
2023-01-05 16:31:18 +00:00
|
|
|
func ACLsDisabled(t *testing.T) resolver.Result {
|
2022-06-17 10:24:43 +01:00
|
|
|
t.Helper()
|
|
|
|
|
2023-01-04 12:40:34 +00:00
|
|
|
return resolver.Result{
|
2023-01-05 16:31:18 +00:00
|
|
|
Authorizer: acl.ManageAll(),
|
2023-01-04 12:40:34 +00:00
|
|
|
}
|
2022-06-17 10:24:43 +01:00
|
|
|
}
|
|
|
|
|
2023-01-04 12:40:34 +00:00
|
|
|
func ACLNoPermissions(t *testing.T) resolver.Result {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
return resolver.Result{
|
|
|
|
Authorizer: acl.DenyAll(),
|
|
|
|
ACLIdentity: randomACLIdentity(t),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func ACLServiceWriteAny(t *testing.T) resolver.Result {
|
2022-04-05 15:26:14 +01:00
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
policy, err := acl.NewPolicyFromSource(`
|
|
|
|
service "foo" {
|
|
|
|
policy = "write"
|
|
|
|
}
|
2023-02-06 09:35:52 -06:00
|
|
|
`, nil, nil)
|
2022-04-05 15:26:14 +01:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
authz, err := acl.NewPolicyAuthorizerWithDefaults(acl.DenyAll(), []*acl.Policy{policy}, nil)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
2023-01-04 12:40:34 +00:00
|
|
|
return resolver.Result{
|
|
|
|
Authorizer: authz,
|
|
|
|
ACLIdentity: randomACLIdentity(t),
|
|
|
|
}
|
2022-04-05 15:26:14 +01:00
|
|
|
}
|
2022-04-19 17:24:21 -07:00
|
|
|
|
2023-01-04 12:40:34 +00:00
|
|
|
func ACLServiceRead(t *testing.T, serviceName string) resolver.Result {
|
2022-04-19 17:24:21 -07:00
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
aclRule := &acl.Policy{
|
|
|
|
PolicyRules: acl.PolicyRules{
|
|
|
|
Services: []*acl.ServiceRule{
|
|
|
|
{
|
|
|
|
Name: serviceName,
|
|
|
|
Policy: acl.PolicyRead,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
authz, err := acl.NewPolicyAuthorizerWithDefaults(acl.DenyAll(), []*acl.Policy{aclRule}, nil)
|
2023-10-03 16:02:23 -06:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
return resolver.Result{
|
|
|
|
Authorizer: authz,
|
|
|
|
ACLIdentity: randomACLIdentity(t),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func ACLUseProvidedPolicy(t *testing.T, aclPolicy *acl.Policy) resolver.Result {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
authz, err := acl.NewPolicyAuthorizerWithDefaults(acl.DenyAll(), []*acl.Policy{aclPolicy}, nil)
|
2022-04-19 17:24:21 -07:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
2023-01-04 12:40:34 +00:00
|
|
|
return resolver.Result{
|
|
|
|
Authorizer: authz,
|
|
|
|
ACLIdentity: randomACLIdentity(t),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-04-11 06:10:14 -05:00
|
|
|
func ACLOperatorRead(t *testing.T) resolver.Result {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
aclRule := &acl.Policy{
|
|
|
|
PolicyRules: acl.PolicyRules{
|
|
|
|
Operator: acl.PolicyRead,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
authz, err := acl.NewPolicyAuthorizerWithDefaults(acl.DenyAll(), []*acl.Policy{aclRule}, nil)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
return resolver.Result{
|
|
|
|
Authorizer: authz,
|
|
|
|
ACLIdentity: randomACLIdentity(t),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func ACLOperatorWrite(t *testing.T) resolver.Result {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
aclRule := &acl.Policy{
|
|
|
|
PolicyRules: acl.PolicyRules{
|
|
|
|
Operator: acl.PolicyWrite,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
authz, err := acl.NewPolicyAuthorizerWithDefaults(acl.DenyAll(), []*acl.Policy{aclRule}, nil)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
return resolver.Result{
|
|
|
|
Authorizer: authz,
|
|
|
|
ACLIdentity: randomACLIdentity(t),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-01-04 12:40:34 +00:00
|
|
|
func randomACLIdentity(t *testing.T) structs.ACLIdentity {
|
|
|
|
id, err := uuid.GenerateUUID()
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
return &structs.ACLToken{AccessorID: id}
|
2022-04-19 17:24:21 -07:00
|
|
|
}
|