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(operator): Add support for properly configuring the CORS allowed origins header #5906

Merged
merged 3 commits into from
Jan 24, 2025

Conversation

EricWittmann
Copy link
Member

This adds support for configuring the CORS allowed origins operator based on what is found in the CR. The value of the allowed origins is influenced by:

  1. The configured UI ingress host
  2. The configured StudioUI ingress host
  3. The app's env configuration

If none of those sources has information we can use, then the value of the allowed origins defaults to *.

This PR contains an update to the smoke IT test, but also more thorough unit tests.

@EricWittmann
Copy link
Member Author

@carlesarnal this may need to be updated once you implement the Keycloak support


// If the QUARKUS_HTTP_CORS_ORIGINS env var is configured in the "env" section of the CR,
// then make sure to add those configured values to the set of allowed origins we want to
// configure.
Copy link
Member

Choose a reason for hiding this comment

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

This is a valid functionality, but I think we should follow a principle regarding configuration in the env section:

The user should be able to completely override any env. variable set by the operator. i.e. we should not touch variables set by the user, and they should override the ones set by the operator.

The advantage of this is that (together with PTS), there is a workaround for users to handle most situations even if there is a bug in the operator (e.g. setting an incorrect env. var value), or there is some circumstance we were not able to predict. This is also simple to explain to the users.

Disadvantage might be a slight decrease in user experience, where the operator could do more things automatically, but I don't think this would affect a lot of feature.

WDYT?

Copy link
Member

Choose a reason for hiding this comment

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

Note: The method io.apicurio.registry.operator.resource.app.AppDeploymentResource#addEnvVar is designed to do this, and we should consolidate a way env. vars are added to a handful of methods, maybe in EnvironmentVariables.

Copy link
Member Author

Choose a reason for hiding this comment

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

Do you mean that the value configured in the env section should take precedent (override) the rest of the logic? I can see why that makes sense. Please confirm and I'll change it.

value: https://ui.example.org
""";

private static final String WITH_ENV_VAR_AND_INGRESS = """
Copy link
Member

Choose a reason for hiding this comment

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

I think we should use the files in operator/controller/src/test/resources/k8s/examples as much as possible, even if they are simple (or slightly edited in the test). This would provide resources we can use in the docs and where we can point users to. The examples will end up in the "install examples" release artifact.

(BTW similarly I have an aspiration to eventually do the same thing for the registry examples and run them as tests).

Copy link
Member Author

Choose a reason for hiding this comment

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

I was having trouble getting those resources to load in a unit test vs an IT test (the context classloader is different). I didn't want to duplicate the resource loading, but I can of course. I'll go ahead and move these into k8s/exmaples.

Assertions.assertThat(allowedOrigins).containsExactlyInAnyOrder(values);
}

public static String load(String path) {
Copy link
Member

Choose a reason for hiding this comment

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

Similar functionality is already in io.apicurio.registry.operator.resource.ResourceFactory#load. Can we a single place for this functionality? I don't have a preference for where to put it.

Copy link
Member Author

Choose a reason for hiding this comment

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

The resource loading in ResourceFactory didn't work from a unit test, I assume due to the difference in thread context classloader. I can consolidate as long as you're OK with multiple variants of load() for the different use cases. For the unit test I will need to pass a classloader to load() so it can properly load the resource.

@@ -24,6 +24,14 @@ public class Mapper {
YAML_MAPPER.configure(FAIL_ON_UNKNOWN_PROPERTIES, true);
}

public static <T> T deserialize(String data, Class<T> klass) {
Copy link
Member

Choose a reason for hiding this comment

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

Similar functionality is already in io.apicurio.registry.operator.resource.ResourceFactory#deserialize. Can we a single place for this functionality? I don't have a preference for where to put it.

Copy link
Member Author

Choose a reason for hiding this comment

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

Same answer as above.

@EricWittmann EricWittmann merged commit 878ca8b into main Jan 24, 2025
20 checks passed
@EricWittmann EricWittmann deleted the feat/operator-cors branch January 24, 2025 21:34
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