-
Notifications
You must be signed in to change notification settings - Fork 90
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
Applying auth0_user and auth0_organization_member produced inconsistent results after apply #1007
Comments
Hello, resource "auth0_organization_member" "main" { This will allow creation of Let us know if that works out. |
Thank you for the suggestion. We've tried doing that but it does not fix the bug. Based on my own understanding, I believe this makes sense; the addition of depends_on isn't necessary since the dependency on auth0_user.main is already explicit in the assignment of auth0_organization_member.main.user_id. In both cases, the terraform apply logs show the user is fully created before the organization_member creation is started. |
My own continued research on finding a resolution for this has ultimately boiled down to this comment. In a nutshell, the likely problem is either eventual consistency or an api response within the provider during the user apply is not making this possible. My suspicion is currently on what's returned by the user creation (or a related GET after the user creation). It may not be returning the resource or an id that is necessary to determine how to build the organization member. |
I can confirm I can reproduce this consistently. I am not sure how the Auth0 API is implemented in the backend but it feels like it may be asynchronous and while creating the user returns a user ID the user it not actually fully provisioned. I have added some debug and error logs to the OrganizationMemeber code in my local copy of the provider. When I run the apply I can see the organization member is created and the state ID is set using the org_id and user_id. After creating the resources its always good practice to read it back which most providers do and auth0 is no different. However when the read call happens it fetches all the members of the organization and then loops through them to check if the user_id is one of them. However after looping through the list the user_id is not found. The logic in the readOrganizationMember after looping all users of the org and not finding the user will set the state ID as an empty string.
Setting a ResourceData id as an empty string effectively removes it from the state. There for the create adds an ID to the ResourceData then calls the read which sets the ID to empty string which removed it again. This is why you get the error that the provider produced an inconsistent result. and that the object was present and is now absent. When you re-run the apply it will trigger a create again which I believe is idempotent on the auth0 side so it will look like it created the user even though the user already existed from the last apply. when the create then calls the read the read will fetch all the organization members again and this time find the user since it was actually created in the previous apply. I have noticed this a few times in several places in the auth0 provider. I would suggest the auth0 team should add some logic in the read to use something like adding a sleep or a retry loop if the resource is a new resource since there is a delay in the create completing but the user being in the organizations member list. func readOrganizationMember(ctx context.Context, data *schema.ResourceData, meta interface{}) diag.Diagnostics {
api := meta.(*config.Config).GetAPI()
organizationID := data.Get("organization_id").(string)
// If this is a new resource sleep for 1 sync to give it time to be linked to the org
if data.IsNewResource() {
time.Sleep(1 * time.Second)
}
members, err := fetchAllOrganizationMembers(ctx, api, organizationID)
if err != nil {
return diag.FromErr(internalError.HandleAPIError(data, err))
}
...
... |
As a mitigation for the OP you can make use of terraforms resource "auth0_user" "user" {
connection_name = "local-dev-test-org-internal-users"
email = "test@test.com"
email_verified = true
password = "passpass$12$12"
}
resource "time_sleep" "async_wait" {
create_duration = "3s"
depends_on = [auth0_user.user]
}
resource "auth0_organization_member" "main" {
organization_id = var.auth0_organization_id
user_id = auth0_user.user.user_id
depends_on = [time_sleep.async_wait]
} This will delay the time between the resources allowing the user resource to be fully created in the auth0 backend
that should at least unblock you until the team can fix the provider. |
I'm confused how this helps. Your log from running it seems to imply it does, but I'm hoping someone can clarify why. |
@cdsre Hello!
I think it's evident that it's a caching issue. For now, the workaround suggested by @cdsre is a great option. Thanks! |
Checklist
Description
When creating an
auth0_user
and relatedauth0_organization_member
in the same apply step, we always get the following error.If we retry the apply after the error, the operation succeeds.
Also, if we run apply with just the user, then run apply for the organization member both operations succeed.
Expectation
That the
auth0_user
and relatedauth0_organization_member
would be created successfully on the first apply.Reproduction
Given an Auth0 tenant with an M2M application used by the terraform client, the default Auth0 database, and an existing organization, run apply on the following code:
Auth0 Terraform Provider version
1.4.0
Terraform version
1.9.5
The text was updated successfully, but these errors were encountered: