[CONTP-1502] chore: Refresh secrets on reconcile instead of callbacks#2916
Open
Mathew-Estafanous wants to merge 8 commits intomainfrom
Open
[CONTP-1502] chore: Refresh secrets on reconcile instead of callbacks#2916Mathew-Estafanous wants to merge 8 commits intomainfrom
Mathew-Estafanous wants to merge 8 commits intomainfrom
Conversation
🛑 Gate Violations
ℹ️ Info🎯 Code Coverage (details) Useful? React with 👍 / 👎 This comment will be updated automatically if new data arrives.🔗 Commit SHA: f516736 | Docs | Datadog PR Page | Give us feedback! |
6c63ce8 to
4cf448a
Compare
There was a problem hiding this comment.
💡 Codex Review
Here are some automated review suggestions for this pull request.
Reviewed commit: 4cf448a31f
ℹ️ About Codex in GitHub
Codex has been enabled to automatically review pull requests in this repo. Reviews are triggered when you
- Open a pull request for review
- Mark a draft as ready
- Comment "@codex review".
If Codex has suggestions, it will comment; otherwise it will react with 👍.
When you sign up for Codex through ChatGPT, Codex can also answer questions or update the PR, like "@codex address that feedback".
a3bcee6 to
db84b1e
Compare
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
What does this PR do?
Replaces the callback-based secret refresh system with per-reconcile credential resolution. Each reconciler now calls
CredentialManager.GetAuth()at the start of every reconcile to get a fresh authentication context with the latest credentials, instead of registering callbacks that recreate API clients when credentials change.The API clients are stateless HTTP wrappers that don't hold credentials, so they no longer need to be recreated. API URL parsing has been moved into
CredentialManagerusingsync.Oncefor lazy initialization, and thedatadogclientpackage is now a simple factory for stateless API clients.Motivation
The previous callback system introduced unnecessary complexity. Every reconciler had to implement
UpdateDatadogClient(), register a callback at setup time, and recreate entire API clients on credential change — even though only the auth context needed refreshing.This is a reworked version of #2312, adjusted for the latest version of the codebase.
Describe how you validated your changes
Unit and integration tests were updated to reflect the new API surface.
Test_refreshnow validates cache updates instead of callback invocations, andTestReconciler_UpdateDatadogClienttests were removed from all four controller packages since the method no longer exists.Manual QA steps:
config/manager/manager.yamlto mount a secret backend script via a ConfigMap volume and pass--secretBackendCommandand--secretRefreshInterval=30sflags to the operator. SetDD_API_KEYandDD_APP_KEYenv vars toENC[api-key]andENC[app-key].manager.yaml diff
secrets_backend.sh script
make deployand created aDatadogMonitorCR to exercise CRUD operations.Credentials have changed, cache updatedappears at rotation boundaries.. Confirmed both API keys show recent activity in the Datadog API Keys page.