Skip to content

Commit

Permalink
new structure of the wasm config based on Kuadrant/wasm-shim#110
Browse files Browse the repository at this point in the history
Signed-off-by: Guilherme Cassolato <[email protected]>
  • Loading branch information
guicassolato committed Oct 15, 2024
1 parent a0cbc9f commit 27a1d1e
Show file tree
Hide file tree
Showing 10 changed files with 1,304 additions and 1,312 deletions.
14 changes: 7 additions & 7 deletions controllers/envoy_gateway_extenion_reconciler.go
Original file line number Diff line number Diff line change
Expand Up @@ -139,7 +139,7 @@ func (r *envoyGatewayExtensionReconciler) buildWasmConfigs(ctx context.Context,

logger.V(1).Info("building wasm configs for envoy gateway extension", "effectivePolicies", len(effectivePolicies.(EffectiveRateLimitPolicies)))

Check warning on line 140 in controllers/envoy_gateway_extenion_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/envoy_gateway_extenion_reconciler.go#L140

Added line #L140 was not covered by tests

wasmPolicies := kuadrantgatewayapi.GrouppedHTTPRouteMatchConfigs{}
wasmActionSets := kuadrantgatewayapi.GrouppedHTTPRouteMatchConfigs{}

Check warning on line 142 in controllers/envoy_gateway_extenion_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/envoy_gateway_extenion_reconciler.go#L142

Added line #L142 was not covered by tests

// build the wasm policies for each topological path that contains an effective rate limit policy affecting an envoy gateway gateway
for pathID, effectivePolicy := range effectivePolicies.(EffectiveRateLimitPolicies) {

Check warning on line 145 in controllers/envoy_gateway_extenion_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/envoy_gateway_extenion_reconciler.go#L145

Added line #L145 was not covered by tests
Expand All @@ -152,17 +152,17 @@ func (r *envoyGatewayExtensionReconciler) buildWasmConfigs(ctx context.Context,
continue

Check warning on line 152 in controllers/envoy_gateway_extenion_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/envoy_gateway_extenion_reconciler.go#L151-L152

Added lines #L151 - L152 were not covered by tests
}

wasmPoliciesForPath, err := wasm.BuildWasmPoliciesForPath(pathID, effectivePolicy.Path, effectivePolicy.Spec.Rules(), rateLimitWasmRuleBuilder(pathID, effectivePolicy, state))
wasmActionSetsForPath, err := wasm.BuildActionSetsForPath(pathID, effectivePolicy.Path, effectivePolicy.Spec.Rules(), rateLimitWasmActionBuilder(pathID, effectivePolicy, state))
if err != nil {
logger.Error(err, "failed to build wasm policies for path", "pathID", pathID)
continue

Check warning on line 158 in controllers/envoy_gateway_extenion_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/envoy_gateway_extenion_reconciler.go#L155-L158

Added lines #L155 - L158 were not covered by tests
}
wasmPolicies.Add(gateway.GetLocator(), wasmPoliciesForPath...)
wasmActionSets.Add(gateway.GetLocator(), wasmActionSetsForPath...)

Check warning on line 160 in controllers/envoy_gateway_extenion_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/envoy_gateway_extenion_reconciler.go#L160

Added line #L160 was not covered by tests
}

wasmConfigs := lo.MapValues(wasmPolicies.Sorted(), func(configs kuadrantgatewayapi.SortableHTTPRouteMatchConfigs, _ string) wasm.Config {
return wasm.BuildWasmConfigForPolicies(lo.Map(configs, func(c kuadrantgatewayapi.HTTPRouteMatchConfig, _ int) wasm.Policy {
return c.Config.(wasm.Policy)
wasmConfigs := lo.MapValues(wasmActionSets.Sorted(), func(configs kuadrantgatewayapi.SortableHTTPRouteMatchConfigs, _ string) wasm.Config {
return wasm.BuildConfigForActionSet(lo.Map(configs, func(c kuadrantgatewayapi.HTTPRouteMatchConfig, _ int) wasm.ActionSet {
return c.Config.(wasm.ActionSet)
}))

Check warning on line 166 in controllers/envoy_gateway_extenion_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/envoy_gateway_extenion_reconciler.go#L163-L166

Added lines #L163 - L166 were not covered by tests
})

Expand Down Expand Up @@ -212,7 +212,7 @@ func buildEnvoyExtensionPolicyForGateway(gateway machinery.Targetable, wasmConfi
},

Check warning on line 212 in controllers/envoy_gateway_extenion_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/envoy_gateway_extenion_reconciler.go#L209-L212

Added lines #L209 - L212 were not covered by tests
}

if len(wasmConfig.Policies) == 0 {
if len(wasmConfig.ActionSets) == 0 {
utils.TagObjectToDelete(envoyPolicy)
} else {
pluginConfigJSON, err := wasmConfig.ToJSON()
Expand Down
14 changes: 7 additions & 7 deletions controllers/istio_extension_reconciler.go
Original file line number Diff line number Diff line change
Expand Up @@ -140,7 +140,7 @@ func (r *istioExtensionReconciler) buildWasmConfigs(ctx context.Context, state *

logger.V(1).Info("building wasm configs for istio extension", "effectivePolicies", len(effectivePolicies.(EffectiveRateLimitPolicies)))

Check warning on line 141 in controllers/istio_extension_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/istio_extension_reconciler.go#L141

Added line #L141 was not covered by tests

wasmPolicies := kuadrantgatewayapi.GrouppedHTTPRouteMatchConfigs{}
wasmActionSets := kuadrantgatewayapi.GrouppedHTTPRouteMatchConfigs{}

Check warning on line 143 in controllers/istio_extension_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/istio_extension_reconciler.go#L143

Added line #L143 was not covered by tests

// build the wasm policies for each topological path that contains an effective rate limit policy affecting an istio gateway
for pathID, effectivePolicy := range effectivePolicies.(EffectiveRateLimitPolicies) {

Check warning on line 146 in controllers/istio_extension_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/istio_extension_reconciler.go#L146

Added line #L146 was not covered by tests
Expand All @@ -153,17 +153,17 @@ func (r *istioExtensionReconciler) buildWasmConfigs(ctx context.Context, state *
continue

Check warning on line 153 in controllers/istio_extension_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/istio_extension_reconciler.go#L152-L153

Added lines #L152 - L153 were not covered by tests
}

wasmPoliciesForPath, err := wasm.BuildWasmPoliciesForPath(pathID, effectivePolicy.Path, effectivePolicy.Spec.Rules(), rateLimitWasmRuleBuilder(pathID, effectivePolicy, state))
wasmActionSetsForPath, err := wasm.BuildActionSetsForPath(pathID, effectivePolicy.Path, effectivePolicy.Spec.Rules(), rateLimitWasmActionBuilder(pathID, effectivePolicy, state))
if err != nil {
logger.Error(err, "failed to build wasm policies for path", "pathID", pathID)
continue

Check warning on line 159 in controllers/istio_extension_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/istio_extension_reconciler.go#L156-L159

Added lines #L156 - L159 were not covered by tests
}
wasmPolicies.Add(gateway.GetLocator(), wasmPoliciesForPath...)
wasmActionSets.Add(gateway.GetLocator(), wasmActionSetsForPath...)

Check warning on line 161 in controllers/istio_extension_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/istio_extension_reconciler.go#L161

Added line #L161 was not covered by tests
}

wasmConfigs := lo.MapValues(wasmPolicies.Sorted(), func(configs kuadrantgatewayapi.SortableHTTPRouteMatchConfigs, _ string) wasm.Config {
return wasm.BuildWasmConfigForPolicies(lo.Map(configs, func(c kuadrantgatewayapi.HTTPRouteMatchConfig, _ int) wasm.Policy {
return c.Config.(wasm.Policy)
wasmConfigs := lo.MapValues(wasmActionSets.Sorted(), func(configs kuadrantgatewayapi.SortableHTTPRouteMatchConfigs, _ string) wasm.Config {
return wasm.BuildConfigForActionSet(lo.Map(configs, func(c kuadrantgatewayapi.HTTPRouteMatchConfig, _ int) wasm.ActionSet {
return c.Config.(wasm.ActionSet)
}))

Check warning on line 167 in controllers/istio_extension_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/istio_extension_reconciler.go#L164-L167

Added lines #L164 - L167 were not covered by tests
})

Expand Down Expand Up @@ -195,7 +195,7 @@ func buildIstioWasmPluginForGateway(gateway machinery.Targetable, wasmConfig was
},

Check warning on line 195 in controllers/istio_extension_reconciler.go

View check run for this annotation

Codecov / codecov/patch

controllers/istio_extension_reconciler.go#L187-L195

Added lines #L187 - L195 were not covered by tests
}

if len(wasmConfig.Policies) == 0 {
if len(wasmConfig.ActionSets) == 0 {
utils.TagObjectToDelete(wasmPlugin)
} else {
pluginConfigStruct, err := wasmConfig.ToStruct()
Expand Down
38 changes: 13 additions & 25 deletions controllers/ratelimit_workflow.go
Original file line number Diff line number Diff line change
Expand Up @@ -151,51 +151,39 @@ func rateLimitClusterPatch(host string, port int) map[string]any {
}
}

func rateLimitWasmRuleBuilder(pathID string, effectivePolicy EffectiveRateLimitPolicy, state *sync.Map) wasm.RuleBuilderFunc {
func rateLimitWasmActionBuilder(pathID string, effectivePolicy EffectiveRateLimitPolicy, state *sync.Map) wasm.ActionBuilderFunc {
policiesInPath := kuadrantv1.PoliciesInPath(effectivePolicy.Path, isRateLimitPolicyAcceptedAndNotDeletedFunc(state))

Check warning on line 155 in controllers/ratelimit_workflow.go

View check run for this annotation

Codecov / codecov/patch

controllers/ratelimit_workflow.go#L154-L155

Added lines #L154 - L155 were not covered by tests

// assumes the path is always [gatewayclass, gateway, listener, httproute, httprouterule]
httpRoute, _ := effectivePolicy.Path[3].(*machinery.HTTPRoute)

Check warning on line 158 in controllers/ratelimit_workflow.go

View check run for this annotation

Codecov / codecov/patch

controllers/ratelimit_workflow.go#L158

Added line #L158 was not covered by tests

limitsNamespace := LimitsNamespaceFromRoute(httpRoute.HTTPRoute)

Check warning on line 160 in controllers/ratelimit_workflow.go

View check run for this annotation

Codecov / codecov/patch

controllers/ratelimit_workflow.go#L160

Added line #L160 was not covered by tests

return func(httpRouteMatch gatewayapiv1.HTTPRouteMatch, uniquePolicyRuleKey string, policyRule kuadrantv1.MergeableRule) (wasm.Rule, error) {
return func(uniquePolicyRuleKey string, policyRule kuadrantv1.MergeableRule) (wasm.Action, error) {
source, found := lo.Find(policiesInPath, func(p machinery.Policy) bool {
return p.GetLocator() == policyRule.Source
})
if !found { // should never happen
return wasm.Rule{}, fmt.Errorf("could not find source policy %s in path %s", policyRule.Source, pathID)
return wasm.Action{}, fmt.Errorf("could not find source policy %s in path %s", policyRule.Source, pathID)

Check warning on line 167 in controllers/ratelimit_workflow.go

View check run for this annotation

Codecov / codecov/patch

controllers/ratelimit_workflow.go#L162-L167

Added lines #L162 - L167 were not covered by tests
}
limitIdentifier := LimitNameToLimitadorIdentifier(k8stypes.NamespacedName{Name: source.GetName(), Namespace: source.GetNamespace()}, uniquePolicyRuleKey)
limit := policyRule.Spec.(kuadrantv1beta3.Limit)
return wasmRuleFromLimit(limit, limitIdentifier, limitsNamespace, httpRouteMatch), nil
return wasmActionFromLimit(limit, limitIdentifier, limitsNamespace), nil

Check warning on line 171 in controllers/ratelimit_workflow.go

View check run for this annotation

Codecov / codecov/patch

controllers/ratelimit_workflow.go#L169-L171

Added lines #L169 - L171 were not covered by tests
}
}

// wasmRuleFromLimit builds a wasm rate-limit rule for a given limit.
// Conditions are built from the limit top-level conditions and a HTTPRouteMatch.
// The order of the conditions is as follows:
// 1. Route-level conditions: HTTP method, path, headers
// 2. Top-level conditions: 'when' conditions (blended into each block of route-level conditions)
// wasmActionFromLimit builds a wasm rate-limit action for a given limit.
// Conditions are built from the limit top-level conditions.
//
// The only action of the rule is the rate-limit policy extension, whose data includes the activation of the limit
// The only action of the rule is the ratelimit service, whose data includes the activation of the limit
// and any counter qualifier of the limit.
func wasmRuleFromLimit(limit kuadrantv1beta3.Limit, limitIdentifier, scope string, routeMatch gatewayapiv1.HTTPRouteMatch) wasm.Rule {
rule := wasm.Rule{
Conditions: wasm.ConditionsFromHTTPRouteMatch(routeMatch, limit.When...),
func wasmActionFromLimit(limit kuadrantv1beta3.Limit, limitIdentifier, scope string) wasm.Action {
return wasm.Action{
ServiceName: wasm.RateLimitServiceName,
Scope: scope,
Conditions: wasm.PredicatesFromWhenConditions(limit.When...),
Data: wasmDataFromLimit(limitIdentifier, limit),
}

if data := wasmDataFromLimit(limitIdentifier, limit); data != nil {
rule.Actions = []wasm.Action{
{
Scope: scope,
ExtensionName: wasm.RateLimitExtensionName,
Data: data,
},
}
}

return rule
}

func wasmDataFromLimit(limitIdentifier string, limit kuadrantv1beta3.Limit) (data []wasm.DataType) {
Expand Down
Loading

0 comments on commit 27a1d1e

Please sign in to comment.