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

Fix marshalling of false value in KeycloakBoolQuoted #495

Merged
merged 2 commits into from
Mar 12, 2021

Conversation

vlaurin
Copy link
Contributor

@vlaurin vlaurin commented Mar 11, 2021

Resolves #492

false is currently marshalled to "" (empty string). This is incorrect: "" represents the default value for an attribute which hasn't been explicitly set.

"" could be interpreted by Keycloak as either true or false depending on what the default value is in Keycloak for the attribute considered. For example, in client scopes, both attributes include.in.token.scope and display.on.consent.screen are evaluated to true (ON) when their value is "".

As a result, "" and "false" are not equivalent and "false" must be used explicitly to accurately turn off Keycloak attributes and not rely on default Keycloak behaviours.

For the same reason, the assumption made when unmarshalling is incorrect as well, though this has a lesser negative effect: https://github.com/mrparkers/terraform-provider-keycloak/blob/master/keycloak/util.go#L24-L25

vlaurin and others added 2 commits March 11, 2021 16:31
Resolves keycloak#492

`false` is currently marshalled to `""` (empty string). This is incorrect: `""` represents the default value for an attribute which hasn't been explicitly set.
`""` could be interpreted as either `true` or `false` depending on what the default value is in Keycloak for the attribute considered.
As a result, `""` and `"false"` are not equivalent and `"false"` must be used explicitly to accurately turn off Keycloak attributes and not rely on default Keycloak behaviours.
@mrparkers
Copy link
Contributor

The code LGTM, thanks for looking into this.

For the same reason, the assumption made when unmarshalling is incorrect as well, though this has a lesser negative effect: https://github.com/mrparkers/terraform-provider-keycloak/blob/master/keycloak/util.go#L24-L25

Yeah, this makes sense, but I'm not sure if there's anything we can really do about that. I think the best solution would be for the Keycloak API to stop using quoted boolean values 😄 . Although if you have any suggestions I'm definitely open to them.

@mrparkers mrparkers merged commit 6068244 into keycloak:master Mar 12, 2021
@vlaurin vlaurin deleted the fix/bool-quoted-marshalling branch March 12, 2021 17:01
@vlaurin
Copy link
Contributor Author

vlaurin commented Mar 12, 2021

@mrparkers Thank for merging. Yes, the unmarshalling one is tricky. I agree that the proper fix should be on the Keycloak side, if Keycloak is assuming default values for attributes then its API should reflect these defaults rather than returning empty strings.

At the level of this provider, I think the ideal course of action would be to not map "" to either true or false but rather to something like nil though this breaks the bool type.

The risk at present is that if an attribute is set as false on a resource, but pulled as "" from Keycloak then no update will take place; if the default value assumed by Keycloak is true then that's a mismatch. To recover from it, one would have to first set the value to true to force an update to an explicit value, then switch back to false.

Instead, I think what should be expected is:

Keycloak Terraform Current behaviour Expected behaviour
"" "false" Noop Update to "false"
"" "true" Update to "true" Update to "true"
"false" "false" Noop Noop
"true" "true" Noop Noop

This would require KeycloakBoolQuoted to have 3 states which I believe is not permitted with Go bool type?

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.

DisplayOnConsentScreen broken for resource keycloak_openid_client_scope
2 participants