Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

sotw: auth #952

Merged
merged 25 commits into from
Nov 5, 2024
Merged

sotw: auth #952

merged 25 commits into from
Nov 5, 2024

Conversation

guicassolato
Copy link
Contributor

@guicassolato guicassolato commented Oct 23, 2024

State-of-the-world reconciler – Auth workflow

  • spec.targetRef.sectionName
  • spec.(defaults|overrides).strategy
  • Defaults & Overrides merge strategies (RFC-0009)
  • Effective AuthPolicy
  • Authorino AuthConfigs
  • Istio cluster (EnvoyFilter)
  • istio extension (WasmPlugin)
  • envoy cluster (EnvoyPatchPolicy)
  • envoy extension (EnvoyExtensionPolicy)
  • Accepted status condition
  • Enforced status condition – mising status of the AuthConfigs only
  • Rename spec.rules.response.success.dynamicMetadataspec.rules.response.success.filters

TODOs

  • Incorporate status of the AuthConfigs into the AuthPolicy Enforced status condition
  • Fix integration tests
  • Dry-run desired AuthConfig to ensure defaults are applied –– probably in a separate PR, so a more holistic approach can be employed, covering all objects that are updated (not only AuthConfigs)

Closes #820
Closes #825
Closes #822

Verification steps

Setup the environment:

make local-setup

Enable Envoy Gateway alongside with Istio:

make envoy-gateway-install

# Restart the Kuadrant Operator so it can acknowledge the presence of Envoy Gateway
kubectl rollout restart deployment/kuadrant-operator-controller-manager -n kuadrant-system
kubectl apply -f -<<EOF
apiVersion: gateway.networking.k8s.io/v1
kind: GatewayClass
metadata:
  name: envoygateway
spec:
  controllerName: gateway.envoyproxy.io/gatewayclass-controller
EOF

kubectl apply -n gateway-system -f -<<EOF
apiVersion: gateway.networking.k8s.io/v1
kind: Gateway
metadata:
  name: kuadrant-envoygateway
spec:
  gatewayClassName: envoygateway
  listeners:
  - name: https
    hostname: "*.eg.apps.io"
    protocol: HTTPS
    port: 443
    tls:
      mode: Terminate
      certificateRefs:
      - name: kuadrant-envoygateway-cert
        kind: Secret
    allowedRoutes:
      namespaces:
        from: All
EOF

Configure TLS on the Envoy Gateway-provided gateway:

kubectl apply -n gateway-system -f -<<EOF
apiVersion: cert-manager.io/v1
kind: ClusterIssuer
metadata:
  name: kuadrant-ca
spec:
  selfSigned: {}
---
apiVersion: kuadrant.io/v1alpha1
kind: TLSPolicy
metadata:
  name: kuadrant-envoygateway-tls
  namespace: gateway-system
spec:
  targetRef:
    group: gateway.networking.k8s.io
    kind: Gateway
    name: kuadrant-envoygateway
  issuerRef:
    group: cert-manager.io
    kind: ClusterIssuer
    name: kuadrant-ca
EOF

Deploy an application:

kubectl apply -f examples/toystore/toystore.yaml

kubectl apply -f - <<EOF
apiVersion: gateway.networking.k8s.io/v1
kind: HTTPRoute
metadata:
  name: toystore
spec:
  parentRefs:
  - name: kuadrant-ingressgateway
    namespace: gateway-system
  - name: kuadrant-envoygateway
    namespace: gateway-system
  rules:
  - backendRefs:
    - name: toystore
      port: 80
    matches:
    - method: GET
  - backendRefs:
    - name: toystore
      port: 80
    matches:
    - method: POST
---
apiVersion: gateway.networking.k8s.io/v1
kind: HTTPRoute
metadata:
  name: other
spec:
  hostnames:
  - other.example.com
  parentRefs:
  - name: kuadrant-ingressgateway
    namespace: gateway-system
  rules:
  - backendRefs:
    - name: toystore
      port: 80
EOF

(From now on and at anytime) Send requests to the application:

export ISTIO_GATEWAY_IP=$(kubectl get gateway/kuadrant-ingressgateway -n gateway-system -o jsonpath='{.status.addresses[0].value}')

curl --resolve toystore.example.com:80:$ISTIO_GATEWAY_IP http://toystore.example.com --write-out '%{http_code}\n' --silent --output /dev/null
curl --resolve other.example.com:80:$ISTIO_GATEWAY_IP http://other.example.com --write-out '%{http_code}\n' --silent --output /dev/null
export ENVOY_GATEWAY_IP=$(kubectl get gateway/kuadrant-envoygateway -n gateway-system -o jsonpath='{.status.addresses[0].value}')

curl --resolve toystore.eg.apps.io:443:$ENVOY_GATEWAY_IP https://toystore.eg.apps.io --write-out '%{http_code}\n' --silent --output /dev/null --insecure

Deploy Kuadrant:

kubectl -n kuadrant-system apply -f - <<EOF
apiVersion: kuadrant.io/v1beta1
kind: Kuadrant
metadata:
  name: kuadrant
spec: {}
EOF

Create a gateway atomic default RateLimitPolicy:

kubectl apply -n gateway-system -f - <<EOF
apiVersion: kuadrant.io/v1beta3
kind: RateLimitPolicy
metadata:
  name: gw-rlp
spec:
  targetRef:
    group: gateway.networking.k8s.io
    kind: Gateway
    name: kuadrant-ingressgateway
  defaults:
    limits:
      "global":
        rates:
        - limit: 5
          duration: 10
          unit: second
        when:
        - selector: source.address
          operator: neq
          value: 127.0.0.1
EOF

Create a route RateLimitPolicy:

kubectl apply -f - <<EOF
apiVersion: kuadrant.io/v1beta3
kind: RateLimitPolicy
metadata:
  name: route-rlp
spec:
  targetRef:
    group: gateway.networking.k8s.io
    kind: HTTPRoute
    name: toystore
  limits:
    "specific":
      rates:
      - limit: 3
        duration: 5
        unit: second
      - limit: 20
        duration: 1
        unit: minute
EOF

Modify the gateway RateLimitPolicy to atomic override strategy:

kubectl apply -n gateway-system -f - <<EOF
apiVersion: kuadrant.io/v1beta3
kind: RateLimitPolicy
metadata:
  name: gw-rlp
spec:
  targetRef:
    group: gateway.networking.k8s.io
    kind: Gateway
    name: kuadrant-ingressgateway
  overrides:
    limits:
      "global":
        rates:
        - limit: 5
          duration: 10
          unit: second
        when:
        - selector: source.address
          operator: neq
          value: 127.0.0.1
EOF

Modify the gateway RateLimitPolicy to merge override strategy:

kubectl apply -n gateway-system -f - <<EOF
apiVersion: kuadrant.io/v1beta3
kind: RateLimitPolicy
metadata:
  name: gw-rlp
spec:
  targetRef:
    group: gateway.networking.k8s.io
    kind: Gateway
    name: kuadrant-ingressgateway
  overrides:
    limits:
      "global":
        rates:
        - limit: 5
          duration: 10
          unit: second
        when:
        - selector: source.address
          operator: neq
          value: 127.0.0.1
    strategy: merge
EOF

Create a route AuthPolicy:

kubectl apply -f - <<EOF
apiVersion: kuadrant.io/v1beta3
kind: AuthPolicy
metadata:
  name: route-auth
spec:
  targetRef:
    group: gateway.networking.k8s.io
    kind: HTTPRoute
    name: toystore
  rules:
    authentication:
      "api-keys-authn":
        apiKey:
          selector:
            matchLabels:
              app: toystore
EOF

Create a gateway merge override AuthPolicy:

kubectl apply -n gateway-system -f - <<EOF
apiVersion: kuadrant.io/v1beta3
kind: AuthPolicy
metadata:
  name: route-auth
spec:
  targetRef:
    group: gateway.networking.k8s.io
    kind: Gateway
    name: kuadrant-envoygateway
  overrides:
    rules:
      authorization:
        "forbidden-ip":
          patternMatching:
            patterns:
            - selector: source.address.@extract{"sep":":"}
              operator: neq
              value: "177.30.200.1"
    strategy: merge
EOF

Screenshot 2024-10-28 at 19-57-10

Try other use cases not covered in the verification steps.

In general, this PR should enable:

  • AuthPolicies targeting a Gateway
  • AuthPolicies targeting a specific Listener of a Gateway (with spec.targetRef.sectionName)
  • AuthPolicies targeting a HTTPRoute
  • AuthPolicies targeting a specific HTTPRouteRule of a HTTPRoute (with spec.targetRef.sectionName)
  • Multiple AuthPolicies targeting a same resource - different sections of the resource
  • Multiple AuthPolicies targeting a same resource - same section of the resource
  • Multiple AuthPolicies targeting a same resource - entire resource and section of the resource
  • Multiple AuthPolicies targeting a same resource - entire resource
  • Defaults and Overrides in AuthPolicies targeting Gateways
  • Defaults and Overrides in AuthPolicies targeting HTTPRoutes
  • Defaults and Overrides' policy merge strategy in AuthPolicies (spec.defaults.strategy: merge, spec.overrides.strategy: merge)
  • Multiple Gateways parenting a HTTPRoute with AuthPolicies attached at any level
  • Gateways controlled by Istio only
  • Gateways controlled by Envoy Gateway only
  • Mixed Gateways controlled by Istio and Envoy Gateway
  • Status of Gateways and HTTPRoutes reflected in the status Enforced condition of the policies
  • Status of Authorino CR reflected in the status Enforced condition of the policies
  • Presence of Istio WasmPlugin CRs reflected in the status Enforced condition of the policies
  • Presence of Istio EnvoyFilter CRs reflected in the status Enforced condition of the policies
  • Presence of Envoy Gateway EnvoyExtensionPolicy CRs reflected in the status Enforced condition of the policies
  • Presence of Envoy Gateway EnvoyPatchPolicy CRs reflected in the status Enforced condition of the policies

@guicassolato guicassolato self-assigned this Oct 23, 2024
Copy link

codecov bot commented Oct 23, 2024

Codecov Report

Attention: Patch coverage is 86.25162% with 212 lines in your changes missing coverage. Please review.

Project coverage is 76.55%. Comparing base (63f1d28) to head (6138e34).
Report is 40 commits behind head on main.

Files with missing lines Patch % Lines
api/v1beta3/authpolicy_types.go 85.28% 38 Missing and 1 partial ⚠️
...ntrollers/envoy_gateway_auth_cluster_reconciler.go 80.13% 25 Missing and 4 partials ⚠️
controllers/istio_auth_cluster_reconciler.go 80.82% 24 Missing and 4 partials ⚠️
pkg/istio/utils.go 51.78% 18 Missing and 9 partials ⚠️
controllers/authconfigs_reconciler.go 86.59% 19 Missing and 7 partials ⚠️
controllers/auth_policy_status_updater.go 91.32% 12 Missing and 5 partials ⚠️
api/v1/merge_strategies.go 60.71% 11 Missing ⚠️
controllers/auth_workflow_helpers.go 91.66% 6 Missing and 3 partials ⚠️
pkg/envoygateway/utils.go 78.04% 6 Missing and 3 partials ⚠️
controllers/effective_auth_policies_reconciler.go 88.23% 5 Missing and 1 partial ⚠️
... and 6 more
Additional details and impacted files
@@            Coverage Diff             @@
##             main     #952      +/-   ##
==========================================
- Coverage   81.49%   76.55%   -4.94%     
==========================================
  Files         102      113      +11     
  Lines        7177     9056    +1879     
==========================================
+ Hits         5849     6933    +1084     
- Misses        898     1813     +915     
+ Partials      430      310     -120     
Flag Coverage Δ
bare-k8s-integration 10.76% <12.12%> (+1.87%) ⬆️
controllers-integration 63.78% <86.25%> (-1.55%) ⬇️
envoygateway-integration 37.69% <30.02%> (-12.61%) ⬇️
gatewayapi-integration 13.71% <12.45%> (-0.70%) ⬇️
istio-integration 39.46% <30.28%> (-14.06%) ⬇️
unit 25.19% <0.19%> (-3.15%) ⬇️

Flags with carried forward coverage won't be shown. Click here to find out more.

Components Coverage Δ
api/v1beta1 (u) 92.18% <100.00%> (+1.27%) ⬆️
api/v1beta2 (u) ∅ <ø> (∅)
pkg/common (u) 87.67% <ø> (-0.47%) ⬇️
pkg/istio (u) 47.03% <ø> (-24.49%) ⬇️
pkg/log (u) 93.18% <ø> (-1.56%) ⬇️
pkg/reconcilers (u) ∅ <ø> (∅)
pkg/rlptools (u) ∅ <ø> (∅)
controllers (i) 83.48% <85.01%> (+0.42%) ⬆️
Files with missing lines Coverage Δ
api/v1beta1/topology.go 100.00% <100.00%> (ø)
api/v1beta3/ratelimitpolicy_types.go 89.62% <100.00%> (+15.93%) ⬆️
controllers/auth_policies_validator.go 100.00% <100.00%> (ø)
controllers/data_plane_policies_workflow.go 100.00% <100.00%> (ø)
...rollers/effective_ratelimit_policies_reconciler.go 88.23% <100.00%> (ø)
...lers/envoy_gateway_ratelimit_cluster_reconciler.go 80.00% <100.00%> (ø)
controllers/ratelimit_policies_validator.go 100.00% <100.00%> (ø)
controllers/ratelimit_policy_status_updater.go 88.81% <100.00%> (ø)
controllers/state_of_the_world.go 92.16% <100.00%> (-5.07%) ⬇️
controllers/test_common.go 100.00% <ø> (ø)
... and 22 more

... and 48 files with indirect coverage changes

@guicassolato guicassolato force-pushed the sotw/auth branch 6 times, most recently from 820f8eb to b32a441 Compare October 28, 2024 15:58
@guicassolato guicassolato marked this pull request as ready for review October 28, 2024 16:15
@guicassolato guicassolato force-pushed the sotw/auth branch 2 times, most recently from e92b91d to cba2fbc Compare October 29, 2024 06:27
@maleck13
Copy link
Collaborator

@guicassolato who is the right person to review this? I am happy to take a look to help it move forward, but someone who has worked on auth or sotw might be a better candidate?
@mikenairn @KevFan ?

Copy link
Contributor

@Boomatang Boomatang left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here are some of the things I noticed while reviewing the code.

.golangci.yaml Outdated Show resolved Hide resolved
api/v1beta3/authpolicy_types.go Show resolved Hide resolved
api/v1beta3/authpolicy_types.go Show resolved Hide resolved
controllers/auth_policy_status_updater.go Show resolved Hide resolved
controllers/auth_policy_status_updater.go Show resolved Hide resolved
controllers/authconfigs_reconciler.go Outdated Show resolved Hide resolved
controllers/authconfigs_reconciler.go Show resolved Hide resolved
@adam-cattermole
Copy link
Member

adam-cattermole commented Oct 30, 2024

I was giving this a go following the authenticated rate limiting guide and am hitting an error trying to define an AuthPolicy with spec.rules.response.success.filters - is there an issue in the way I've defined this:

kubectl apply -f - <<EOF
apiVersion: kuadrant.io/v1beta3
kind: AuthPolicy
metadata:
  name: toystore
spec:
  targetRef:
    group: gateway.networking.k8s.io
    kind: HTTPRoute
    name: toystore
  rules:
    authentication:
      "api-key-users":
        apiKey:
          selector:
            matchLabels:
              app: toystore
          allNamespaces: true
        credentials:
          authorizationHeader:
            prefix: APIKEY
    response:
      success:
        filters:
          "identity":
            json:
              properties:
                "userid":
                  selector: auth.identity.metadata.annotations.secret\.kuadrant\.io/user-id
EOF

The operator crash loops panicking but is fine once I remove the response block.

The panic:
panic: runtime error: invalid memory address or nil pointer dereference
[signal SIGSEGV: segmentation violation code=0x1 addr=0x20 pc=0x151d4a0]

goroutine 5078 [running]:
github.com/kuadrant/kuadrant-operator/api/v1beta3.(*MergeableDenyWithSpec).GetSource(0x17d3980?)
	/workspace/api/v1beta3/authpolicy_types.go:554
github.com/kuadrant/kuadrant-operator/api/v1.NewMergeableRule({0x1e2d110, 0x0}, {0x4000884210, 0x27})
	/workspace/api/v1/merge_strategies.go:37 +0x34
github.com/kuadrant/kuadrant-operator/api/v1beta3.(*AuthPolicy).Rules(0x4000143380)
	/workspace/api/v1beta3/authpolicy_types.go:171 +0x9c4
github.com/kuadrant/kuadrant-operator/api/v1.copyMergeablePolicy({0xfffe6b897270, 0x400086f1e0})
	/workspace/api/v1/merge_strategies.go:224 +0x98
github.com/kuadrant/kuadrant-operator/api/v1.AtomicDefaultsMergeStrategy({0x1e470c0, 0x400086f1e0}, {0x1e470c0?, 0x400086f1e0})
	/workspace/api/v1/merge_strategies.go:73 +0x100
github.com/kuadrant/kuadrant-operator/api/v1beta3.(*AuthPolicy).Merge(0x1e45f40?, {0x1e470c0?, 0x400086f1e0?})
	/workspace/api/v1beta3/authpolicy_types.go:117 +0x164
github.com/kuadrant/kuadrant-operator/api/v1.EffectivePolicyForPath[...].func1({0x1e470c0?, 0x400086f1e0?}, 0x4000ee8101?)
	/workspace/api/v1/merge_strategies.go:187 +0x3c
github.com/samber/lo.ReduceRight[...]({0x40004e4af0?, 0x5, 0x1884c60?}, 0x40003ad968?, {0x1e470c0, 0x400086f1e0?})
	/go/pkg/mod/github.com/samber/lo@v1.39.0/slice.go:82 +0x5c
github.com/kuadrant/kuadrant-operator/api/v1.EffectivePolicyForPath[...]({0x40004e4a50, 0x5, 0x5}, 0x4000ee81e0)
	/workspace/api/v1/merge_strategies.go:186 +0xd4
github.com/kuadrant/kuadrant-operator/controllers.(*EffectiveAuthPolicyReconciler).calculateEffectivePolicies(0x400077f6e0?, {0x1e3cf70?, 0x400017aaf0?}, 0x400011dac0, {0x1e407a0, 0x40009ec500}, 0x400011dae0)
	/workspace/controllers/effective_auth_policies_reconciler.go:74 +0x3d0
github.com/kuadrant/kuadrant-operator/controllers.(*EffectiveAuthPolicyReconciler).Reconcile(0x4000028310, {0x1e3cf70, 0x400017aaf0}, {0x1e5be08?, 0x400105bc20?, 0x1e5be08?}, 0x400011dac0, {0x0?, 0x0?}, 0x400011dae0)
	/workspace/controllers/effective_auth_policies_reconciler.go:49 +0x148
github.com/kuadrant/policy-machinery/controller.Subscription.Reconcile({0x40001a0420?, {0x2f4d800?, 0x40008796f8?, 0x150e288?}}, {0x1e3cf70, 0x400017aaf0}, {0x400097b950?, 0x400097b950?, 0x2?}, 0x400011dac0, ...)
	/go/pkg/mod/github.com/kuadrant/policy-machinery@v0.6.4/controller/subscriber.go:34 +0xc4
github.com/kuadrant/policy-machinery/controller.(*Workflow).Run.func1()
	/go/pkg/mod/github.com/kuadrant/policy-machinery@v0.6.4/controller/workflow.go:42 +0x48
golang.org/x/sync/errgroup.(*Group).Go.func1()
	/go/pkg/mod/golang.org/x/sync@v0.8.0/errgroup/errgroup.go:78 +0x58
created by golang.org/x/sync/errgroup.(*Group).Go in goroutine 5077
	/go/pkg/mod/golang.org/x/sync@v0.8.0/errgroup/errgroup.go:75 +0x98

@guicassolato
Copy link
Contributor Author

I was giving this a go following the authenticated rate limiting guide and am hitting an error trying to define an AuthPolicy with spec.rules.response.success.filters - is there an issue in the way I've defined this:

[…]

The operator crash loops panicking but is fine once I remove the response block.

Thanks @adam-cattermole! Silly one this bug. Fixed.

@KevFan
Copy link
Contributor

KevFan commented Oct 31, 2024

@guicassolato Is there anything from the guides that should not be working currently from this change? 🤔

I know you've mentioned before that API Key Secret's should be created in the kuadrant-system namespace where the AuthConfig's are now created but following https://github.com/Kuadrant/kuadrant-operator/blob/main/doc/user-guides/auth-for-app-devs-and-platform-engineers.md#-protect-the-toy-store-application-persona-app-developer
at:

curl -H 'Host: api.toystore.com' -H 'Authorization: APIKEY iamaregularuser' http://$GATEWAY_URL/cars -i
# HTTP/1.1 200 OK

gives a 403:

# HTTP/1.1 403 Forbidden                     
HTTP/1.1 403 Forbidden
x-ext-auth-reason: Unauthorized
date: Thu, 31 Oct 2024 12:29:44 GMT
server: istio-envoy
content-length: 0

Copy link
Contributor

@thomasmaas thomasmaas left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Lets merge move on.

@guicassolato
Copy link
Contributor Author

@guicassolato Is there anything from the guides that should not be working currently from this change? 🤔

I know you've mentioned before that API Key Secret's should be created in the kuadrant-system namespace where the AuthConfig's are now created but following https://github.com/Kuadrant/kuadrant-operator/blob/main/doc/user-guides/auth-for-app-devs-and-platform-engineers.md#-protect-the-toy-store-application-persona-app-developer at:

curl -H 'Host: api.toystore.com' -H 'Authorization: APIKEY iamaregularuser' http://$GATEWAY_URL/cars -i
# HTTP/1.1 200 OK

gives a 403:

# HTTP/1.1 403 Forbidden                     
HTTP/1.1 403 Forbidden
x-ext-auth-reason: Unauthorized
date: Thu, 31 Oct 2024 12:29:44 GMT
server: istio-envoy
content-length: 0

@KevFan, I've added another commit updating the doc.

TL;DR – What you experienced when trying the user guide is not an issue of this PR. Rather, it's a combination of 2 things:

  1. The removal of routeSelector (UPDATE: bump authPolicy to v1beta3 in guides #949) without an equivalent using sectionName (only possible after this PR).
  2. (TBC) What I believe could be a bug in Authorino that linked the API key Secrets created in the default namespace to AuthConfigs in the kuadrant-system one, despite apiKey.allNamespaces set to false, due to the empty apiKey.selector.

Copy link
Contributor

@KevFan KevFan left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me! 👍

Copy link
Contributor

@Boomatang Boomatang left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Happy to see this merge

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
…teway extension resources

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
… merges

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
…h Kuadrant AuthPolicy

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
@guicassolato guicassolato merged commit 5540253 into main Nov 5, 2024
28 of 29 checks passed
@guicassolato guicassolato deleted the sotw/auth branch November 5, 2024 10:01
maleck13 pushed a commit that referenced this pull request Nov 13, 2024
* Prepare AuthPolicy type for the merge strategy

* Structure of named patterns changed from `patterns: map[string][]PatternExpression` to `patterns: map[string]{allOf: []PatternExpression}`.
* `spec.response.success.dynamicMetadata` field renamed `spec.response.success.filters`, documented as meant for exporting data to other filters managed by Kuadrant only.

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* sotw: auth

* AuthPolicies validation
* Effective auth policies
* Authorino AuthConfigs
* Istio/Envoy Gateway cluster patches
* Istio/Envoy Gateway wasm extensions
* (Most part of) AuthPolicy status update

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* activate auth service in the wasm config

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* check status of the authconfigs for the authpolicy enforced status condition + refactoring of the ratelimitpolicy staus updater for consistency with auth

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* tests: fix unit tests pkg/wasm

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* bump policy-machinery to v0.6.2

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* bump policy-machinery to v0.6.3

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* add effective authpolicy count to debug log messages when building gateway extension resources

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* fix: equality between envoy gateway extension resources

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* De/restructure all objects via JSON

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* Remove unused funcs from the reconciliation of AuthConfigs

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* fix: equality between envoy gateway cluster patch resources

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* bump policy-machinery to v0.6.4

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* remove unnecessary custom json unmarshallers from poliyc types

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* tests: activate auth service in the wasm config

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* fix: build envoy auth cluster patch with correct name

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* fix: cel validations of the authpolicy

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* tests: fix authpolicy integration tests

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* fix: mark empty authpolicies as enforced

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* disable prealloc linter

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* refactor: improved tracking of the origin of a policy rule throughout merges

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* fix log message

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* fix nil custom response unauthenticated/unauthorized configs

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* preallocate the modifiedAuthConfigs slice

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

* docs: updated user guide Enforcing authentication & authorization with Kuadrant AuthPolicy

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>

---------

Signed-off-by: Guilherme Cassolato <guicassolato@gmail.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: Done
7 participants