Security and Permissions
When you query data from Athena or Amazon Redshift, the queried dataset is automatically stored in the default SageMaker S3 bucket for the AWS Region in which you are using Studio Classic. Additionally, when you export a Jupyter Notebook from Amazon SageMaker Data Wrangler and run it, your data flows, or .flow files, are saved to the same default bucket, under the prefix data_wrangler_flows.
For high-level security needs, you can configure a bucket policy that restricts the AWS roles that have access to this default SageMaker S3 bucket. Use the following section to add this type of policy to an S3 bucket. To follow the instructions on this page, use the AWS Command Line Interface (AWS CLI). To learn how, see Configuring the AWS CLI in the IAM User Guide.
Additionally, you need to grant each IAM role that uses Data Wrangler permissions to access
required resources. If you do not require granular permissions for the IAM role you
use to access Data Wrangler, you can add the IAM managed policy, AmazonSageMakerFullAccess
Add a Bucket Policy To Restrict Access to Datasets Imported to Data Wrangler
You can add a policy to the S3 bucket that contains your Data Wrangler resources using an Amazon S3 bucket policy. Resources that Data Wrangler uploads to your default SageMaker S3 bucket in the AWS Region you are using Studio Classic in include the following:
-
Queried Amazon Redshift results. These are stored under the redshift/ prefix.
-
Queried Athena results. These are stored under the athena/ prefix.
-
The .flow files uploaded to Amazon S3 when you run an exported Jupyter Notebook Data Wrangler produces. These are stored under the data_wrangler_flows/ prefix.
Use the following procedure to create an S3 bucket policy that you can add to restrict IAM role access to that bucket. To learn how to add a policy to an S3 bucket, see How do I add an S3 Bucket policy?.
To set up a bucket policy on the S3 bucket that stores your Data Wrangler resources:
-
Configure one or more IAM roles that you want to be able to access Data Wrangler.
-
Open a command prompt or shell. For each role that you create, replace
role-name
with the name of the role and run the following:$ aws iam get-role --role-name
role-name
In the response, you see a
RoleId
string which begins withAROA
. Copy this string. -
Add the following policy to the SageMaker default bucket in the AWS Region in which you are using Data Wrangler. Replace
region
with the AWS Region in which the bucket is located, andaccount-id
with your AWS account ID. ReplaceuserId
s starting withAROAEXAMPLEID
with the IDs of an AWS roles to which you want to grant permission to use Data Wrangler.{ "Version": "2012-10-17", "Statement": [ { "Effect": "Deny", "Principal": "*", "Action": "s3:*", "Resource": [ "arn:aws:s3:::sagemaker-
region
-account-id
/data_wrangler_flows/", "arn:aws:s3:::sagemaker-region
-account-id
/data_wrangler_flows/*", "arn:aws:s3:::sagemaker-region
-account-id
/athena", "arn:aws:s3:::sagemaker-region
-account-id
/athena/*", "arn:aws:s3:::sagemaker-region
-account-id
/redshift", "arn:aws:s3:::sagemaker-region
-account-id
/redshift/*" ], "Condition": { "StringNotLike": { "aws:userId": [ "AROAEXAMPLEID_1
:*", "AROAEXAMPLEID_2
:*" ] } } } ] }
Create an Allowlist for Data Wrangler
Whenever a user starts running Data Wrangler from the Amazon SageMaker Studio Classic user interface, they make call to the SageMaker application programming interface (API) to create a Data Wrangler application.
Your organization might not provide your users with permissions to make those API calls by default.
To provide permissions, you must create and attach a policy to the user's IAM roles using the following policy template:
Data Wrangler Allow List Example
Note
The preceding policy example only gives your users access to the Data Wrangler application.
For information about creating a policy, see Creating policies on the JSON tab.
When you're creating a policy, copy and paste the JSON policy from
Data Wrangler Allow List Example
Important
Delete any IAM policies that prevent users from running the following operations:
If you don't delete the policies, your users could still be affected by them.
After you've creating the policy using the template, attach it to the IAM roles of your users. For information about attaching a policy, see Adding IAM identity permissions (console).
Grant an IAM Role Permission to Use Data Wrangler
You can grant an IAM role permission to use Data Wrangler with the general IAM managed
policy, AmazonSageMakerFullAccess
AmazonSageMakerFullAccess
to grant access to Data Wrangler:
-
If you import data from Amazon Redshift, the Database User name must have the prefix
sagemaker_access
. -
This managed policy only grants permission to access buckets with one of the following in the name:
SageMaker
,SageMaker
,sagemaker
, oraws-glue
. If want to use Data Wrangler to import from an S3 bucket without these phrases in the name, refer to the last section on this page to learn how to grant permission to an IAM entity to access your S3 buckets.
If you have high-security needs, you can attach the policies in this section to an IAM entity to grant permissions required to use Data Wrangler.
If you have datasets in Amazon Redshift or Athena that an IAM role needs to import from Data Wrangler, you must add a policy to that entity to access these resources. The following policies are the most restrictive policies you can use to give an IAM role permission to import data from Amazon Redshift and Athena.
To learn how to attach a custom policy to an IAM role, refer to Managing IAM policies in the IAM User Guide.
Policy example to grant access to an Athena dataset import
The following policy assumes that the IAM role has permission to access the underlying S3 bucket where data is stored through a separate IAM policy.
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "athena:ListDataCatalogs", "athena:ListDatabases", "athena:ListTableMetadata", "athena:GetQueryExecution", "athena:GetQueryResults", "athena:StartQueryExecution", "athena:StopQueryExecution" ], "Resource": [ "*" ] }, { "Effect": "Allow", "Action": [ "glue:CreateTable" ], "Resource": [ "arn:aws:glue:*:*:table/*/sagemaker_tmp_*", "arn:aws:glue:*:*:table/sagemaker_featurestore/*", "arn:aws:glue:*:*:catalog", "arn:aws:glue:*:*:database/*" ] }, { "Effect": "Allow", "Action": [ "glue:DeleteTable" ], "Resource": [ "arn:aws:glue:*:*:table/*/sagemaker_tmp_*", "arn:aws:glue:*:*:catalog", "arn:aws:glue:*:*:database/*" ] }, { "Effect": "Allow", "Action": [ "glue:GetDatabases", "glue:GetTable", "glue:GetTables" ], "Resource": [ "arn:aws:glue:*:*:table/*", "arn:aws:glue:*:*:catalog", "arn:aws:glue:*:*:database/*" ] }, { "Effect": "Allow", "Action": [ "glue:CreateDatabase", "glue:GetDatabase" ], "Resource": [ "arn:aws:glue:*:*:catalog", "arn:aws:glue:*:*:database/sagemaker_featurestore", "arn:aws:glue:*:*:database/sagemaker_processing", "arn:aws:glue:*:*:database/default", "arn:aws:glue:*:*:database/sagemaker_data_wrangler" ] } ] }
Policy example to grant access to an Amazon Redshift dataset import
The following policy grants permission to set up an Amazon Redshift connection to Data Wrangler using
database users that have the prefix sagemaker_access
in the name. To
grant permission to connect using additional database users, add additional entries
under "Resources"
in the following policy. The following policy assumes
that the IAM role has permission to access the underlying S3 bucket where data is
stored through a separate IAM policy, if applicable.
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "redshift-data:ExecuteStatement", "redshift-data:DescribeStatement", "redshift-data:CancelStatement", "redshift-data:GetStatementResult", "redshift-data:ListSchemas", "redshift-data:ListTables" ], "Resource": [ "*" ] }, { "Effect": "Allow", "Action": [ "redshift:GetClusterCredentials" ], "Resource": [ "arn:aws:redshift:*:*:dbuser:*/sagemaker_access*", "arn:aws:redshift:*:*:dbname:*" ] } ] }
Policy to grant access to an S3 bucket
If your dataset is stored in Amazon S3, you can grant an IAM role permission to
access this bucket with a policy similar to the following. This example grants
programmatic read-write access to the bucket named
test
.
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": ["s3:ListBucket"], "Resource": ["arn:aws:s3:::
test
"] }, { "Effect": "Allow", "Action": [ "s3:PutObject", "s3:GetObject", "s3:DeleteObject" ], "Resource": ["arn:aws:s3:::test
/*"] } ] }
To import data from Athena and Amazon Redshift, you must grant an IAM role permission to
access the following prefixes under the default Amazon S3 bucket in the AWS Region Data Wrangler
in which is being used: athena/
, redshift/
. If a default
Amazon S3 bucket does not already exist in the AWS Region, you must also give the IAM
role permission to create a bucket in this region.
Additionally, if you want the IAM role to be able to use the Amazon SageMaker Feature Store, Pipelines,
and Data Wrangler job export options, you must grant access to the prefix
data_wrangler_flows/
in this bucket.
Data Wrangler uses the athena/
and redshift/
prefixes to store
preview files and imported datasets. To learn more, see Imported Data Storage.
Data Wrangler uses the data_wrangler_flows/
prefix to store .flow files when
you run a Jupyter Notebook exported from Data Wrangler. To learn more, see Export.
Use a policy similar to the following to grant the permissions described in the preceding paragraphs.
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "s3:GetObject", "s3:PutObject" ], "Resource": [ "arn:aws:s3:::sagemaker-
region
-account-id
/data_wrangler_flows/", "arn:aws:s3:::sagemaker-region
-account-id
/data_wrangler_flows/*", "arn:aws:s3:::sagemaker-region
-account-id
/athena", "arn:aws:s3:::sagemaker-region
-account-id
/athena/*", "arn:aws:s3:::sagemaker-region
-account-id
/redshift", "arn:aws:s3:::sagemaker-region
-account-id
/redshift/*" ] }, { "Effect": "Allow", "Action": [ "s3:CreateBucket", "s3:ListBucket" ], "Resource": "arn:aws:s3:::sagemaker-region
-account-id
" }, { "Effect": "Allow", "Action": [ "s3:ListAllMyBuckets", "s3:GetBucketLocation" ], "Resource": "*" } ] }
You can also access data in your Amazon S3 bucket from another AWS account by
specifying the Amazon S3 bucket URI. To do this, the IAM policy that grants access to the
Amazon S3 bucket in the other account should use a policy similar to the following
example, where BucketFolder
is the specific directory in the user's
bucket UserBucket
. This policy should be added to the user granting
access to their bucket for another user.
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "s3:GetObject", "s3:PutObject", "s3:PutObjectAcl" ], "Resource": "arn:aws:s3:::
UserBucket
/BucketFolder/
*" }, { "Effect": "Allow", "Action": [ "s3:ListBucket" ], "Resource": "arn:aws:s3:::UserBucket
", "Condition": { "StringLike": { "s3:prefix": [ "BucketFolder
/*" ] } } } ] }
The user that is accessing the bucket (not the bucket owner) must add a policy
similar to the following example to their user. Note that AccountX
and
TestUser
below refers to the bucket owner and their user
respectively.
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Principal": { "AWS": "arn:aws:iam::
AccountX:user
/TestUser
" }, "Action": [ "s3:GetObject", "s3:PutObject", "s3:PutObjectAcl" ], "Resource": [ "arn:aws:s3:::UserBucket
/BucketFolder
/*" ] }, { "Effect": "Allow", "Principal": { "AWS": "arn:aws:iam::AccountX:user
/TestUser
" }, "Action": [ "s3:ListBucket" ], "Resource": [ "arn:aws:s3:::UserBucket
" ] } ] }
Policy example to grant access to use SageMaker Studio
Use a policy like to the following to create an IAM execution role that can be used to set up a Studio Classic instance.
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "sagemaker:CreatePresignedDomainUrl", "sagemaker:DescribeDomain", "sagemaker:ListDomains", "sagemaker:DescribeUserProfile", "sagemaker:ListUserProfiles", "sagemaker:*App", "sagemaker:ListApps" ], "Resource": "*" } ] }
Snowflake and Data Wrangler
All permissions for AWS resources are managed via your IAM role attached to your Studio Classic instance. The Snowflake administrator manages Snowflake-specific permissions, as they can grant granular permissions and privileges to each Snowflake user. This includes databases, schemas, tables, warehouses, and storage integration objects. You must ensure that the correct permissions are set up outside of Data Wrangler.
Note that the Snowflake COPY INTO Amazon S3
command moves data from
Snowflake to Amazon S3 over the public internet by default, but data in
transit is secured using SSL. Data at rest in Amazon S3 is encrypted with SSE-KMS using
the default AWS KMS key.
With respect to Snowflake credentials storage, Data Wrangler does not store customer
credentials. Data Wrangler uses Secrets Manager to store the credentials in a secret and rotates
secrets as part of a best practice security plan. The Snowflake or Studio Classic
administrator needs to ensure that the data scientist’s Studio Classic execution role is
granted permission to perform GetSecretValue
on the secret storing the
credentials. If already attached to the Studio Classic execution role, the
AmazonSageMakerFullAccess
policy has the necessary permissions to
read secrets created by Data Wrangler and secrets created by following the naming and tagging
convention in the instructions above. Secrets that do not follow the conventions
must be separately granted access. We recommend using Secrets Manager to prevent sharing
credentials over unsecured channels; however, note that a logged-in user can
retrieve the plain-text password by launching a terminal or Python notebook in
Studio Classic and then invoking API calls from the Secrets Manager API.
Data Encryption with AWS KMS
Within Data Wrangler, you can decrypt encrypted files and add them to your Data Wrangler flow. You can also encrypt the output of the transforms using either a default AWS KMS key or one that you provide.
You can import files if they have the following:
-
server-side encryption
-
SSE-KMS as the encryption type
To decrypt the file and import to a Data Wrangler flow, you must add the SageMaker Studio Classic user that you're using as a key user.
The following screenshot shows a Studio Classic user role added as a key user. See
IAM Roles
Amazon S3 customer managed key setup for Data Wrangler imported data storage
By default, Data Wrangler uses Amazon S3 buckets that have the following naming convention:
sagemaker-region-account number
. For example, if your account
number is 111122223333
and you are using Studio Classic in us-east-1,
your imported datasets are stored with the following naming convention:
sagemaker-us-east-1-111122223333
.
The following instructions explain how to set up a customer managed key for your default Amazon S3 bucket.
-
To enable server-side encryption and setup a customer managed key for your default S3 bucket, see Using KMS Encryption.
-
After following step 1, navigate to AWS KMS in your AWS Management Console. Find the customer managed key you selected in step 1 of the previous step and add the Studio Classic role as the key user. To do this, follow the instructions in Allows key users to use a customer managed key.
Encrypting the Data That You Export
You can encrypt the data that you export using one of the following methods:
-
Specifying that your Amazon S3 bucket has object use SSE-KMS encryption.
-
Specifying an AWS KMS key to encrypt the data that you export from Data Wrangler.
On the Export data page, specify a value for the AWS KMS key ID or ARN.
For more information on using AWS KMS keys, see Protecting Data Using Server-Side Encryption with AWS KMS keys Stored in AWSAWS Key Management Service (SSE-KMS) .
Amazon AppFlow Permissions
When you're performing a transfer, you must specify an IAM role that has permissions to perform the transfer. You can use the same IAM role that has permissions to use Data Wrangler. By default, the IAM role that you use to access Data Wrangler is the SageMakerExecutionRole
.
The IAM role must have the following permissions:
-
Permissions to Amazon AppFlow
-
Permissions to the AWS Glue Data Catalog
-
Permissions for AWS Glue to discover the data sources that are available
When you run a transfer, Amazon AppFlow stores metadata from the transfer in the AWS Glue Data Catalog. Data Wrangler uses the metadata from the catalog to determine whether it's available for you to query and import.
To add permissions to Amazon AppFlow, add the AmazonAppFlowFullAccess
AWS
managed policy to the IAM role. For more information about adding policies, see Adding or
removing IAM identity permissions.
If you're transferring data to Amazon S3, you must also attach the following policy.
{ "Version": "2012-10-17", "Statement": [ { "Sid": "VisualEditor0", "Effect": "Allow", "Action": [ "s3:GetBucketTagging", "s3:ListBucketVersions", "s3:CreateBucket", "s3:ListBucket", "s3:GetBucketPolicy", "s3:PutEncryptionConfiguration", "s3:GetEncryptionConfiguration", "s3:PutBucketTagging", "s3:GetObjectTagging", "s3:GetBucketOwnershipControls", "s3:PutObjectTagging", "s3:DeleteObject", "s3:DeleteBucket", "s3:DeleteObjectTagging", "s3:GetBucketPublicAccessBlock", "s3:GetBucketPolicyStatus", "s3:PutBucketPublicAccessBlock", "s3:PutAccountPublicAccessBlock", "s3:ListAccessPoints", "s3:PutBucketOwnershipControls", "s3:PutObjectVersionTagging", "s3:DeleteObjectVersionTagging", "s3:GetBucketVersioning", "s3:GetBucketAcl", "s3:PutObject", "s3:GetObject", "s3:GetAccountPublicAccessBlock", "s3:ListAllMyBuckets", "s3:GetAnalyticsConfiguration", "s3:GetBucketLocation" ], "Resource": "*" } ] }
To add AWS Glue permissions, add the AWSGlueConsoleFullAccess
managed policy
to the IAM role. For more information about AWS Glue permissions with Amazon AppFlow, see
[link-to-appflow-page].
Amazon AppFlow needs to access AWS Glue and Data Wrangler for you to import the data that you've transferred. To grant Amazon AppFlow access, add the following trust policy to the IAM role.
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Principal": { "AWS": "arn:aws:iam::
123456789012
:root", "Service": [ "appflow.amazonaws.com" ] }, "Action": "sts:AssumeRole" } ] }
To display the Amazon AppFlow data in Data Wrangler, add the following policy to the IAM role:
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": "glue:SearchTables", "Resource": [ "arn:aws:glue:*:*:table/*/*", "arn:aws:glue:*:*:database/*", "arn:aws:glue:*:*:catalog" ] } ] }
Using Lifecycle Configurations in Data Wrangler
You might have an Amazon EC2 instance that is configured to run Kernel Gateway applications, but not the Data Wrangler application. Kernel Gateway applications provide access to the environment and the kernels that you use to run Studio Classic notebooks and terminals. The Data Wrangler application is the UI application that runs Data Wrangler. Amazon EC2 instances that aren't Data Wrangler instances require a modification to their lifecycle configurations to run Data Wrangler. Lifecycle configurations are shell scripts that automate the customization of your Amazon SageMaker Studio Classic environment.
For more information about lifecycle configurations, see Use lifecycle configurations to customize Studio Classic.
The default lifecycle configuration for your instance doesn't support using Data Wrangler. You can make the following modifications to the default configuration to use Data Wrangler with your instance.
#!/bin/bash set -eux STATUS=$( python3 -c "import sagemaker_dataprep" echo $? ) if [ "$STATUS" -eq 0 ]; then echo 'Instance is of Type Data Wrangler' else echo 'Instance is not of Type Data Wrangler' # Replace this with the URL of your git repository export REPOSITORY_URL="https://github.com/aws-samples/sagemaker-studio-lifecycle-config-examples.git" git -C /root clone $REPOSTIORY_URL fi
You can save the script as lifecycle_configuration.sh
.
You attach the lifecycle configuration to your Studio Classic domain or user profile. For more information about creating and attaching a lifecycle configuration, see Create and associate a lifecycle configuration.
The following instructions show you how to attach a lifecycle configuration to a Studio Classic domain or user profile.
You might run into errors when you're creating or attaching a lifecycle configuration. For information about debugging lifecycle configuration errors, KernelGateway app failure.