forked from awslabs/s3-connector-for-pytorch
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_cibuildwheel_on_ec2.sh
executable file
·34 lines (30 loc) · 1.52 KB
/
run_cibuildwheel_on_ec2.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
if [ $# -ne 7 ]; then
echo "Invalid number of parameters, you need to provide role name, region name, bucket name, prefix, express region name and express bucket name, custom endpoint for s3 standard"
echo "Usage: $0 S3RoleName us-west-2 s3torchconnector-test-bucket-name prefix-name/ us-east-1 s3torchconnectorclient-express-bucket-name https://s3.amazon.com"
exit 1
fi
ROLE_NAME=$1
REGION_NAME=$2
BUCKET_NAME=$3
PREFIX=$4
EXPRESS_REGION_NAME=$5
EXPRESS_BUCKET_NAME=$6
S3_CUSTOM_ENDPOINT_URL=$7
FILE_NAME="tmp_cred.json"
# Set metadata token TTL to 6 hours
TOKEN=`curl -s -X PUT "http://169.254.169.254/latest/api/token" -H "X-aws-ec2-metadata-token-ttl-seconds: 21600"`
# Retrieve temporary credentials and save to file
curl -H "X-aws-ec2-metadata-token: $TOKEN" http://169.254.169.254/latest/meta-data/iam/security-credentials/${ROLE_NAME} >> ${FILE_NAME}
# Expose temporary credentials to use from cibuildwheel container
export AWS_ACCESS_KEY_ID=`cat ${FILE_NAME} | jq -r '.AccessKeyId'`
export AWS_SECRET_ACCESS_KEY=`cat ${FILE_NAME} | jq -r '.SecretAccessKey'`
export AWS_SESSION_TOKEN=`cat ${FILE_NAME} | jq -r '.Token'`
rm ${FILE_NAME}
# Expose settings for integration tests to use from cibuildwheel container
export S3_REGION=${REGION_NAME}
export S3_BUCKET=${BUCKET_NAME}
export S3_PREFIX=${PREFIX}
export S3_EXPRESS_REGION=${EXPRESS_REGION_NAME}
export S3_EXPRESS_BUCKET=${EXPRESS_BUCKET_NAME}
export S3_CUSTOM_ENDPOINT_URL=${S3_CUSTOM_ENDPOINT_URL}
cibuildwheel --output-dir wheelhouse --platform linux s3torchconnectorclient