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

feat(trait): add support for multiple ingress paths #5996

Merged
merged 5 commits into from
Jan 8, 2025

Conversation

cfitzw
Copy link
Contributor

@cfitzw cfitzw commented Dec 13, 2024

Related to issue #5981.

  • Allow multiple paths to be set within an ingress.
  • Implement a workaround to allow backward compatibility for ingress.path.
  • Determine if the IngressTrait should be migrated towards adopting K8s API IngressSpec hierarchy.
    Can be reviewed again at a later point in time/in a separate PR.
  • Implement a depreciation message for ingress.path.
  • Output the depreciation message where applicable.

Example usage:

build/_output/bin/kamel-amd64 run test/src/multi-path.yml -o yaml --trait ingress.paths="/api/v1/multi" --trait ingress.paths="/api/v1/path" > test/base/multi-path.yml

... generates:

apiVersion: camel.apache.org/v1
kind: Integration
metadata:
  annotations:
    camel.apache.org/operator.id: camel-k
  creationTimestamp: null
  name: multi-path
spec:
  flows:
  - from:
      steps:
      - set-header:
          name: Content-Type
          simple: application/json
      - set-body:
          constant: '{"welcome": "multi"}'
      uri: rest:get:/api/v1/multi
  - from:
      steps:
      - set-header:
          name: Content-Type
          simple: application/json
      - set-body:
          constant: '{"welcome": "path"}'
      uri: rest:get:/api/v1/path
  traits:
    ingress:
      paths: 
        - /api/v1/multi
        - /api/v1/path
status: {}

Output of ingress (kubectl get ingress multi-path -o yaml):

apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  creationTimestamp: "2024-12-13T15:21:34Z"
  generation: 1
  labels:
    camel.apache.org/generation: "1"
    camel.apache.org/integration: multi-path
  name: multi-path
  namespace: default
  ownerReferences:
  - apiVersion: camel.apache.org/v1
    blockOwnerDeletion: true
    controller: true
    kind: Integration
    name: multi-path
    uid: eb44c65f-3dca-49e5-a368-1ba8946fc3ee
  resourceVersion: "97865"
  uid: bc5651de-87a5-40d7-be30-9375c98dfb61
spec:
  ingressClassName: nginx
  rules:
  - http:
      paths:
      - backend:
          service:
            name: multi-path
            port:
              name: http
        path: /api/v1/multi
        pathType: Prefix
      - backend:
          service:
            name: multi-path
            port:
              name: http
        path: /api/v1/path
        pathType: Prefix
status:
  loadBalancer:
    ingress:
    - ip: 192.168.49.2

Curl Output:

curl 192.168.49.2/api/v1/multi
{"welcome": "multi"}

curl 192.168.49.2/api/v1/path
{"welcome": "path"}

@cfitzw cfitzw changed the title ingress improvements feat(trait): ingress improvements Dec 13, 2024
Copy link
Contributor

✔️ Unit test coverage report - coverage increased from 47.2% to 47.3% (+0.1%)

Copy link
Contributor

@squakez squakez left a comment

Choose a reason for hiding this comment

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

Nice stuff, thanks! As mentioned in the issue, to avoid breaking compatibility you can keep the path logic and additionally include a paths with the logic you're willing to implement.

@cfitzw cfitzw force-pushed the feat-ingress-improvements branch from 23532bd to 8d2f4f5 Compare December 16, 2024 17:13
@cfitzw
Copy link
Contributor Author

cfitzw commented Dec 16, 2024

@squakez - I've now added paths and kept path with deprecated notices. The code will now continue to support the existing path convention.

I could use some assistance on implementing some sort of error handling so that if both path and paths traits exist, that an error is thrown. Right now I have it coded to take only the path and ignore paths when this scenario exists.
I've now just added another small commit (+test) to allow both the path and paths fields to be able to co-exist.

@cfitzw cfitzw changed the title feat(trait): ingress improvements feat(trait): add support for multiple ingress paths Dec 16, 2024
@cfitzw cfitzw marked this pull request as ready for review December 16, 2024 18:03
Copy link
Contributor

⚠️ Unit test coverage report - coverage decreased from 47.6% to 47.3% (-0.3%)

Copy link
Contributor

@squakez squakez left a comment

Choose a reason for hiding this comment

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

Nice work, thanks! If you can give another shot and add a deprecation warning notice in the Integration condition it would be great.

@squakez
Copy link
Contributor

squakez commented Dec 18, 2024

I forgot to add a link to some example you can use for the warning notice:

condition := t.adaptDeprecatedFields()

@cfitzw
Copy link
Contributor Author

cfitzw commented Dec 18, 2024

Excellent - thank you for the example. I'll work to get this added in the coming days.

@cfitzw
Copy link
Contributor Author

cfitzw commented Dec 23, 2024

@squakez, I added this into the configure function:

if t.Path != "" {
	if e.IntegrationInPhase(v1.IntegrationPhaseRunning) {
		m := "The path parameter is deprecated and may be removed in future releases. Use the paths parameter instead."
		t.L.Info(m)
		condition := NewIntegrationCondition(
			"Ingress",
			v1.IntegrationConditionTraitInfo,
			corev1.ConditionTrue,
			TraitConfigurationReason,
			m,
		)

		return true, condition, nil
	}
}

Questions:

  1. When I look at the operator log, I do see the warning/info message, however, it is listed multiple times (x3, even after limiting it to running state). I also needed to add t.L.Info(m) in order to see it in the operator log (I think...).
  2. I don't believe I am doing this correctly -- can you please assist?

@squakez
Copy link
Contributor

squakez commented Jan 2, 2025

@squakez, I added this into the configure function:

if t.Path != "" {
	if e.IntegrationInPhase(v1.IntegrationPhaseRunning) {
		m := "The path parameter is deprecated and may be removed in future releases. Use the paths parameter instead."
		t.L.Info(m)
		condition := NewIntegrationCondition(
			"Ingress",
			v1.IntegrationConditionTraitInfo,
			corev1.ConditionTrue,
			TraitConfigurationReason,
			m,
		)

		return true, condition, nil
	}
}

Questions:

1. When I look at the operator log, I do see the warning/info message, however, it is listed multiple times (x3, even after limiting it to running state). I also needed to add t.L.Info(m) in order to see it in the operator log (I think...).

2. I don't believe I am doing this correctly -- can you please assist?

I don't see this in any commit. Have you committed it yet? The condition looks fine, but you don't need to add a log (the operator will log the condition message by default) and probably you won't need to check either the phase. It is possible that any trait runs multiple time, so, that's something you should not generally worry about.

@cfitzw
Copy link
Contributor Author

cfitzw commented Jan 3, 2025

@squakez, please see latest commit. I have done as you've mentioned, by removing the log line and phases, however, I do not see the message in the operator log now.

Please let me know the proper way to handle/resolve.

@cfitzw cfitzw marked this pull request as draft January 3, 2025 15:25
@squakez
Copy link
Contributor

squakez commented Jan 3, 2025

@squakez, please see latest commit. I have done as you've mentioned, by removing the log line and phases, however, I do not see the message in the operator log now.

Please let me know the proper way to handle/resolve.

LGTM. You were right, the log was required if we want to notify in the operator log. Feel free to include it as you were doing before.

@cfitzw
Copy link
Contributor Author

cfitzw commented Jan 4, 2025

@squakez I've committed back in the info log line, however, this does make me question the purpose of including the condition and return statement?

Maybe the sole purpose of adding the condition is to allow for tests to evaluate the result (which I've now added too...)?

FYI: The openapi.go trait is using a very similar logic, without the log line, however, as alluded to above, openapi_test.go does have a test condition where the same message text is evaluated... though the message would never be seen by folks. Same with deployer.go trait, except no test exists.

It almost seems like there should be a package for throwing depreciation notices to keep better consistency and to provide better awareness (for those not following docs/commits), in some way?

Nonetheless, this should now be complete/ready.

@cfitzw cfitzw marked this pull request as ready for review January 4, 2025 14:18
@squakez
Copy link
Contributor

squakez commented Jan 7, 2025

Thanks @cfitzw. The log line would add a trace in the operator. The condition is instead set into the Integration custom resource, and, in general, that is the one you really want to monitor to understand how things are about the resource. It's fine to have it both though, so, once the checks are green we can merge it.

@squakez squakez merged commit 15a4efe into apache:main Jan 8, 2025
11 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants