mirror of
https://github.com/status-im/consul.git
synced 2025-01-12 06:44:41 +00:00
a72f868218
This updates the testing/deployer (aka "topology test") framework to conditionally configure and launch catalog constructs using v2 resources. This is controlled via a Version field on the Node construct in a topology.Config. This only functions for a dataplane type and has other restrictions that match the rest of v2 (no peering, no wanfed, no mesh gateways). Like config entries, you can statically provide a set of initial resources to be synced when bringing up the cluster (beyond those that are generated for you such as workloads, services, etc). If you want to author a test that can be freely converted between v1 and v2 then that is possible. If you switch to the multi-port definition on a topology.Service (aka "workload/instance") then that makes v1 ineligible. This also adds a starter set of "on every PR" integration tests for single and multiport under test-integ/catalogv2
203 lines
3.8 KiB
Go
203 lines
3.8 KiB
Go
// Copyright (c) HashiCorp, Inc.
|
|
// SPDX-License-Identifier: BUSL-1.1
|
|
|
|
package sprawl
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/hashicorp/consul/api"
|
|
|
|
"github.com/hashicorp/consul/testing/deployer/topology"
|
|
)
|
|
|
|
func policyForCrossNamespaceRead(partition string) *api.ACLPolicy {
|
|
return &api.ACLPolicy{
|
|
Name: "cross-ns-catalog-read",
|
|
Description: "cross-ns-catalog-read",
|
|
Partition: partition,
|
|
Rules: fmt.Sprintf(`
|
|
partition %[1]q {
|
|
namespace_prefix "" {
|
|
node_prefix "" { policy = "read" }
|
|
service_prefix "" { policy = "read" }
|
|
}
|
|
}
|
|
`, partition),
|
|
}
|
|
}
|
|
|
|
const anonymousTokenAccessorID = "00000000-0000-0000-0000-000000000002"
|
|
|
|
func anonymousToken() *api.ACLToken {
|
|
return &api.ACLToken{
|
|
AccessorID: anonymousTokenAccessorID,
|
|
// SecretID: "anonymous",
|
|
Description: "anonymous",
|
|
Local: false,
|
|
Policies: []*api.ACLTokenPolicyLink{
|
|
{
|
|
Name: "anonymous",
|
|
},
|
|
},
|
|
}
|
|
}
|
|
|
|
func anonymousPolicy(enterprise bool) *api.ACLPolicy {
|
|
p := &api.ACLPolicy{
|
|
Name: "anonymous",
|
|
Description: "anonymous",
|
|
}
|
|
if enterprise {
|
|
p.Rules = `
|
|
partition_prefix "" {
|
|
namespace_prefix "" {
|
|
node_prefix "" { policy = "read" }
|
|
service_prefix "" { policy = "read" }
|
|
}
|
|
}
|
|
`
|
|
} else {
|
|
p.Rules = `
|
|
node_prefix "" { policy = "read" }
|
|
service_prefix "" { policy = "read" }
|
|
`
|
|
}
|
|
return p
|
|
}
|
|
|
|
func tokenForNode(node *topology.Node, enterprise bool) *api.ACLToken {
|
|
nid := node.ID()
|
|
|
|
tokenName := "agent--" + nid.ACLString()
|
|
|
|
token := &api.ACLToken{
|
|
Description: tokenName,
|
|
Local: false,
|
|
NodeIdentities: []*api.ACLNodeIdentity{{
|
|
NodeName: node.PodName(),
|
|
Datacenter: node.Datacenter,
|
|
}},
|
|
}
|
|
if enterprise {
|
|
token.Partition = node.Partition
|
|
token.Namespace = "default"
|
|
}
|
|
return token
|
|
}
|
|
|
|
func tokenForService(svc *topology.Service, overridePolicy *api.ACLPolicy, enterprise bool) *api.ACLToken {
|
|
token := &api.ACLToken{
|
|
Description: "service--" + svc.ID.ACLString(),
|
|
Local: false,
|
|
}
|
|
if overridePolicy != nil {
|
|
token.Policies = []*api.ACLTokenPolicyLink{{ID: overridePolicy.ID}}
|
|
} else if svc.IsV2() {
|
|
token.TemplatedPolicies = []*api.ACLTemplatedPolicy{{
|
|
TemplateName: api.ACLTemplatedPolicyWorkloadIdentityName,
|
|
TemplateVariables: &api.ACLTemplatedPolicyVariables{
|
|
Name: svc.ID.Name,
|
|
},
|
|
}}
|
|
} else {
|
|
token.ServiceIdentities = []*api.ACLServiceIdentity{{
|
|
ServiceName: svc.ID.Name,
|
|
}}
|
|
}
|
|
|
|
if enterprise {
|
|
token.Namespace = svc.ID.Namespace
|
|
token.Partition = svc.ID.Partition
|
|
}
|
|
|
|
return token
|
|
}
|
|
|
|
const (
|
|
meshGatewayCommunityRules = `
|
|
service "mesh-gateway" {
|
|
policy = "write"
|
|
}
|
|
service_prefix "" {
|
|
policy = "read"
|
|
}
|
|
node_prefix "" {
|
|
policy = "read"
|
|
}
|
|
agent_prefix "" {
|
|
policy = "read"
|
|
}
|
|
# for peering
|
|
mesh = "write"
|
|
peering = "read"
|
|
`
|
|
|
|
meshGatewayEntDefaultRules = `
|
|
namespace_prefix "" {
|
|
service "mesh-gateway" {
|
|
policy = "write"
|
|
}
|
|
service_prefix "" {
|
|
policy = "read"
|
|
}
|
|
node_prefix "" {
|
|
policy = "read"
|
|
}
|
|
}
|
|
agent_prefix "" {
|
|
policy = "read"
|
|
}
|
|
# for peering
|
|
mesh = "write"
|
|
|
|
partition_prefix "" {
|
|
peering = "read"
|
|
}
|
|
`
|
|
|
|
meshGatewayEntNonDefaultRules = `
|
|
namespace_prefix "" {
|
|
service "mesh-gateway" {
|
|
policy = "write"
|
|
}
|
|
service_prefix "" {
|
|
policy = "read"
|
|
}
|
|
node_prefix "" {
|
|
policy = "read"
|
|
}
|
|
}
|
|
agent_prefix "" {
|
|
policy = "read"
|
|
}
|
|
# for peering
|
|
mesh = "write"
|
|
`
|
|
)
|
|
|
|
func policyForMeshGateway(svc *topology.Service, enterprise bool) *api.ACLPolicy {
|
|
policyName := "mesh-gateway--" + svc.ID.ACLString()
|
|
|
|
policy := &api.ACLPolicy{
|
|
Name: policyName,
|
|
Description: policyName,
|
|
}
|
|
if enterprise {
|
|
policy.Partition = svc.ID.Partition
|
|
policy.Namespace = "default"
|
|
}
|
|
|
|
if enterprise {
|
|
if svc.ID.Partition == "default" {
|
|
policy.Rules = meshGatewayEntDefaultRules
|
|
} else {
|
|
policy.Rules = meshGatewayEntNonDefaultRules
|
|
}
|
|
} else {
|
|
policy.Rules = meshGatewayCommunityRules
|
|
}
|
|
|
|
return policy
|
|
}
|