-
Notifications
You must be signed in to change notification settings - Fork 1.6k
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
Allow AWS Assume Role #4474
Allow AWS Assume Role #4474
Conversation
e1eadd8
to
62a7212
Compare
Hey @ekristen, This solution will work only for long-running operations which can be completed within 12 hours. Do you have any idea as to how long-running operations on the restic repository are affected by this? I am assuming, we would need some kind of background go routine which routinely checks for the expiry of the STS token and will renew the STS token and update the client. |
This is true. I wonder how often backups exceed 12 hours and use s3 and would use assume role? Creating a go func that goes into a loop at expiration/2 and updates the current credentials would work. However back to my original question of how often the exceeding 12 hours would happen. I see two options
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Using the aws-sdk in addition to minio is not an option.
From a quick look at the minio-go documentation, it also supports assuming a role: https://pkg.go.dev/github.com/minio/minio-go/v7@v7.0.61/pkg/credentials#STSAssumeRole . Please use that approach instead. That will likely also just fix the expiry problems.
@MichaelEischer Why is it a no-go, it's a small part of the library? The minio doesn't support all the necessary options like passing an ExternalId. I can write a wrapper to support the expiration. Other than the above, is the rest of it acceptable? The environment variable names etc? |
It increases the binary size by 1MB, seems to work for AWS only, feels completely out of place compared to the existing credentials methods and so on. Mixing two SDKs that are both able to access S3 just feels very wrong.
I'd prefer to ask whether the minio developers are willing to add support for ExternalId to minio-go . There are already two AWS specific options for STSAssumeRole, That would be a 10-20 lines change on the minio side along with proper integration in the library, compared to the brittle 100+ lines implementation here. |
Gotcha. I will make the necessary changes and pull requests. |
@MichaelEischer changes as requested, however it depends upon changes to minio-go/v7 which I've opened a PR for here minio/minio-go#1887 -- I'm happy to leave my fork up if you'd like to merge as is, but if you'd like to wait and see if the PR can get merged mainstream, we can leave this open until that PR is merged and upgrade the dependency accordingly. I've built a docker image with these changes and it is available here.
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for updating the PR. Yes, I'd prefer to wait until the minio PR is merged.
@MichaelEischer the minio PR was just merged minio/minio-go#1887 (comment) -- do we need to wait until it hits a release? If not I can update the branch to use the specific commit. |
Working on fully testing the changes right now, but for anyone else that wants to here's the docker image.
|
Had to make a tweak to the region code to make things align properly with assuming roles properly.
|
I'd prefer to wait until the next version of the minio-go library is released, the next restic release will still take quite some time, so there's no need to rush it. I'll try to have a closer look at the code in the next days/weeks. |
@MichaelEischer understood. |
@MichaelEischer thinking about this, I think we need to at least prefix these with |
55e0ad9
to
d0c94ec
Compare
@MichaelEischer minio-go release a new version, this includes that update to make this PR work now. I've also updated the env vars to be prefixed with Here's a build docker image for anyone that wants to test.
|
Thanks, as a heads-up I'm pretty busy at the moment, I probably won't be able to review the PR before Christmas, sorry. |
EnvAWS considers more environment variables, including AWS_SESSION_TOKEN and thus should be checked first.
8050eec
to
6e2296b
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry for the long delay! I've squashed the commits (rebasing all the changes would have been too messy) and rebased them to the current master branch. That implicitly updates minio to v7.0.66.
I've added two remarks, please take a look. Other than that I'm happy with the changes.
Could you give the PR one final try to check that everything still works?
6e2296b
to
1c886c4
Compare
Hey @MichaelEischer all good, glad you found time to come back around to this! I made a couple comments on your comments. I'll go build and test this out and reply once done. |
1c886c4
to
4248c6c
Compare
Everything seems to be working for me just fine. |
Thanks for testing, then let's merge it! |
What does this PR change? What problem does it solve?
Resolves #4472
It adds the ability to allow the discovered credentials for AWS to assume another role and use those credentials for the actual run of restic.
Example: Personal IAM user (ekristen) has access to ec2 console but not s3 backup location but has the right to assume the role, backup, backup has full access to the s3 bucket, so this allows restic to assume a role.
Was the change previously discussed in an issue or on the forum?
Not really, opened #4472
Testing this Pull Request
Using the files from this gist create the folllowing, a test iam user, test iam role, and test s3 bucket. https://gist.github.com/ekristen/e20a976653d0624957add5b4d2ef64ba
Note:* for more advanced use cases you can pass AWS_ASSUME_ROLE_SESSION_NAME and AWS_ASSUME_ROLE_EXTERNAL_ID and use conditions to trust based on values. Additionally you can pass AWS_ASSUME_ROLE_POLICY which is a JSON document for an IAM policy, this can be used to set a STS policy to restrict the STS credentials to a specific path as an example.
Checklist
Note: tests -- there aren't extensive existing tests on authentication methods, there's not a framework to build off of that I could see to add tests.
changelog/unreleased/
that describes the changes for our users (see template).gofmt
on the code in all commits.