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(cubestore): Support IAM role authentication for S3 #8589

Open
wants to merge 5 commits into
base: master
Choose a base branch
from

Conversation

haipham23
Copy link

I need IAM role authentication, similar to this issue #6795.

Check List

  • Tests has been run in packages where changes made if available
  • Linter has been run for changed code
  • Tests for the changes have been added if not covered yet
  • Docs have been added / updated if required

Issue Reference this PR resolves

Add IAM role authentication.

Description of Changes Made (if issue reference is not provided)

Introduce CUBESTORE_AWS_IAM_ROLE and CUBESTORE_AWS_IAM_REFRESH_EVERY_MINS.

If there is CUBESTORE_AWS_IAM_ROLE in the env, we would generate ID and secret on the flight.
Since this ID is short-lived (15 mins by default), we would need a shorten refresh loop.

@haipham23 haipham23 requested a review from a team as a code owner August 16, 2024 10:14
Copy link

vercel bot commented Aug 16, 2024

The latest updates on your projects. Learn more about Vercel for Git ↗︎

8 Skipped Deployments
Name Status Preview Comments Updated (UTC)
examples-angular-dashboard ⬜️ Ignored (Inspect) Visit Preview Aug 16, 2024 0:32am
examples-react-d3 ⬜️ Ignored (Inspect) Visit Preview Aug 16, 2024 0:32am
examples-react-dashboard ⬜️ Ignored (Inspect) Visit Preview Aug 16, 2024 0:32am
examples-react-data-table ⬜️ Ignored (Inspect) Visit Preview Aug 16, 2024 0:32am
examples-react-highcharts ⬜️ Ignored (Inspect) Visit Preview Aug 16, 2024 0:32am
examples-react-material-ui ⬜️ Ignored (Inspect) Visit Preview Aug 16, 2024 0:32am
examples-react-pivot-table ⬜️ Ignored (Inspect) Visit Preview Aug 16, 2024 0:32am
examples-vue-query-builder ⬜️ Ignored (Inspect) Visit Preview Aug 16, 2024 0:32am

@github-actions github-actions bot added the pr:community Contribution from Cube.js community members. label Aug 16, 2024
@igorlukanin igorlukanin requested a review from ovr August 19, 2024 14:08
@igorlukanin igorlukanin added the cube store Issues relating to Cube Store label Aug 19, 2024
@leopepe
Copy link

leopepe commented Jan 20, 2025

@igorlukanin it is not clear why the Vercel test is failing. I am interested in this feature and could work on the tests to make it acceptable and suitable for merging.
Can I help somehow? :)

@igorlukanin
Copy link
Member

I've rebased this PR on top of the latest and it looks like we have more build steps failing now. Could anyone please take a look?

@leopepe
Copy link

leopepe commented Jan 21, 2025

I've rebased this PR on top of the latest and it looks like we have more build steps failing now. Could anyone please take a look?

I can have a look. I think I can fix the error for the failing checks.
Unfortunately I don't have permission to change the original branch.

Copy link

@leopepe leopepe left a comment

Choose a reason for hiding this comment

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

These suggestions fixes the formatting and build error happening currently in the checks

@@ -101,6 +101,7 @@ humansize = "2.1.3"
deepsize = "0.2.0"
anyhow = "1.0"
arc-swap = "1.7.1"
aws_sdk_sts = "1.38.0"
Copy link

Choose a reason for hiding this comment

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

Suggested change
aws_sdk_sts = "1.38.0"
aws-sdk-sts = "1.38.0"

Comment on lines +64 to +66
Some(role_name) => {
assume_role(&role_name, &region.to_string()).await
}
Copy link

Choose a reason for hiding this comment

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

Suggested change
Some(role_name) => {
assume_role(&role_name, &region.to_string()).await
}
Some(role_name) => assume_role(&role_name, &region.to_string()).await,

Comment on lines +118 to +121
.assume_role(AssumeRoleRequest::builder()
.role_arn(format!("arn:aws:iam::{}:role/{}", account_id, role_or_access_key))
.duration_seconds(28800)
.build())
Copy link

Choose a reason for hiding this comment

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

Suggested change
.assume_role(AssumeRoleRequest::builder()
.role_arn(format!("arn:aws:iam::{}:role/{}", account_id, role_or_access_key))
.duration_seconds(28800)
.build())
.assume_role(
AssumeRoleRequest::builder()
.role_arn(format!(
"arn:aws:iam::{}:role/{}",
account_id, role_or_access_key
))
.duration_seconds(28800)
.build(),
)

Comment on lines +128 to +129
let access_key = assume_role_output.access_key_id.ok_or_else(|| CubeError::internal("Failed to get access key".to_string()))?;
let secret_key = assume_role_output.secret_access_key.ok_or_else(|| CubeError::internal("Failed to get secret key".to_string()))?;
Copy link

Choose a reason for hiding this comment

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

Suggested change
let access_key = assume_role_output.access_key_id.ok_or_else(|| CubeError::internal("Failed to get access key".to_string()))?;
let secret_key = assume_role_output.secret_access_key.ok_or_else(|| CubeError::internal("Failed to get secret key".to_string()))?;
let access_key = assume_role_output
.access_key_id
.ok_or_else(|| CubeError::internal("Failed to get access key".to_string()))?;
let secret_key = assume_role_output
.secret_access_key
.ok_or_else(|| CubeError::internal("Failed to get secret key".to_string()))?;

let fs = match fs.upgrade() {
None => {
log::debug!("Stopping S3 credentials refresh loop");
return;
}
Some(fs) => fs,
};

let (access_key, secret_key) = if is_role {
let (access_key, secret_key) = assume_role(&role_or_access_key.as_ref().unwrap(), &region.to_string()).await;
Copy link

Choose a reason for hiding this comment

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

Suggested change
let (access_key, secret_key) = assume_role(&role_or_access_key.as_ref().unwrap(), &region.to_string()).await;
let (access_key, secret_key) =
assume_role(&role_or_access_key.as_ref().unwrap(), &region.to_string()).await;

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
cube store Issues relating to Cube Store pr:community Contribution from Cube.js community members.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants