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

Inconsistent treatment of role argument in IAM #30

Closed
mmdriley opened this issue Sep 27, 2017 · 4 comments
Closed

Inconsistent treatment of role argument in IAM #30

mmdriley opened this issue Sep 27, 2017 · 4 comments
Assignees
Milestone

Comments

@mmdriley
Copy link
Contributor

In this example, I want to create an IAM role, attach an inline policy, then create an EC2 instance profile with that role.

let assumeInstanceRolePolicyDoc = // ...
let instanceRolePolicyDoc = // ...

let instanceRole = new aws.iam.Role("ecsClusterInstanceRole", {
    assumeRolePolicy: JSON.stringify(assumeInstanceRolePolicyDoc),
});

let instanceRolePolicy = new aws.iam.RolePolicy("ecsClusterInstanceRolePolicy", {
    role: instanceRole.id,  // (a)
    policy: JSON.stringify(instanceRolePolicyDoc),
});

let instanceProfile = new aws.iam.InstanceProfile("ecsClusterInstanceProfile", {
    role: instanceRole,  // (b)
});

At point (a), the role is specified using a string ARN.

readonly role: pulumi.ComputedValue<string>;

At point (b), the role must be specified as the Role object.
readonly role?: pulumi.ComputedValue<Role>;

I haven't looked into how the code is generated yet, but the underlying Terraform schema entries are both schema.TypeString:
https://github.com/terraform-providers/terraform-provider-aws/blob/90d698c66db80d676e2db197be97c1a9977e5393/aws/resource_aws_iam_instance_profile.go#L99
https://github.com/terraform-providers/terraform-provider-aws/blob/90d698c66db80d676e2db197be97c1a9977e5393/aws/resource_aws_iam_role_policy.go#L50

@joeduffy
Copy link
Member

This is, unfortunately, our own doing. It's ill-documented, however, we have the notion of "overlays" which can alter the underlying Terraform type to make it more idiomatic in the target language.

In this case, we are being clever and letting you use a capability-style of configuring resources, where you use object identity rather than strings. This is nice, because you don't need to know to .arn the Role, you just pass it and the right thing happens. (If all you see is string, how would you know if it's .arn, .name, .id, and so on, without consulting documentation.)

You can see where we've enabled it for InstanceProfile here

"role": {Type: awsrestok(iamMod, "Role")},
, but notably, we haven't made the equivalent change for RolePolicy. Frankly, we've been tackling these as we go, and we are due for a more coherent push to get consistent here.

But in parallel with this, we have the overall problem that, sometimes you actually may want to pass a string. E.g., maybe the Role exists outside of our purview. Things like Role.get("...") may help bridge this gap in a strongly typed way. But I still frequently wonder if we ought to fall back to typing things like this as Role | string (union type).

Anyway, a simple solution is to just add the overlays as we encounter them. This may be a fine approach for now so that we can learn more before deciding on the long term solution.

@mmdriley mmdriley self-assigned this Oct 10, 2017
@mmdriley
Copy link
Contributor Author

@lukehoban this doesn't feel like something I'm going to get to soon, but it feels like something to add to the pile of breaking changes we might consider in 0.11.

@mmdriley mmdriley assigned lukehoban and unassigned mmdriley Jan 23, 2018
@ericrudder ericrudder added this to the 0.11 milestone Jan 23, 2018
@joeduffy joeduffy modified the milestones: 0.11, 0.12 Feb 12, 2018
@lukehoban lukehoban modified the milestones: 0.12, 0.14 Apr 8, 2018
@lukehoban lukehoban modified the milestones: 0.14, 0.16 Apr 20, 2018
@lukehoban lukehoban modified the milestones: 0.16, 0.17 Jul 12, 2018
@lukehoban lukehoban assigned pgavlin and unassigned lukehoban Jul 12, 2018
@jen20
Copy link
Contributor

jen20 commented Jul 21, 2018

A similar issue for RolePolicy was fixed in #278. This shouldn't be too hard to go through and fix in the same manner without a breaking change using the same pattern.

Edit: Actually, I read the initial problem description too quickly, this is already fixed by #278 - RolePolicy now accepts string | Role for the role argument.

@lukehoban
Copy link
Contributor

Fixed by #278. Thanks @jen20.

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

No branches or pull requests

6 participants