66 lines
2.3 KiB
Python
66 lines
2.3 KiB
Python
# Licensed to Elasticsearch under one or more contributor
|
|
# license agreements. See the NOTICE file distributed with
|
|
# this work for additional information regarding copyright
|
|
# ownership. Elasticsearch licenses this file to you under
|
|
# the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing,
|
|
# software distributed under the License is distributed on
|
|
# an 'AS IS' BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
|
|
# either express or implied. See the License for the specific
|
|
# language governing permissions and limitations under the License.
|
|
|
|
import os
|
|
import sys
|
|
import argparse
|
|
try:
|
|
import boto.s3
|
|
except:
|
|
raise RuntimeError("""
|
|
S3 upload requires boto to be installed
|
|
Use one of:
|
|
'pip install -U boto'
|
|
'apt-get install python-boto'
|
|
'easy_install boto'
|
|
""")
|
|
|
|
|
|
def list_buckets(conn):
|
|
return conn.get_all_buckets()
|
|
|
|
|
|
def upload_s3(conn, path, key, file, bucket):
|
|
print('Uploading %s to Amazon S3 bucket %s/%s') % \
|
|
(file, bucket, os.path.join(path, key))
|
|
def percent_cb(complete, total):
|
|
sys.stdout.write('.')
|
|
sys.stdout.flush()
|
|
bucket = conn.create_bucket(bucket)
|
|
k = bucket.new_key(os.path.join(path, key))
|
|
k.set_contents_from_filename(file, cb=percent_cb, num_cb=100)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
parser = argparse.ArgumentParser(description='Uploads files to Amazon S3')
|
|
parser.add_argument('--file', '-f', metavar='path to file',
|
|
help='the branch to release from', required=True)
|
|
parser.add_argument('--bucket', '-b', metavar='B42', default='download.elasticsearch.org',
|
|
help='The S3 Bucket to upload to')
|
|
parser.add_argument('--path', '-p', metavar='elasticsearch/elasticsearch', default='elasticsearch/elasticsearch',
|
|
help='The key path to use')
|
|
parser.add_argument('--key', '-k', metavar='key', default=None,
|
|
help='The key - uses the file name as default key')
|
|
args = parser.parse_args()
|
|
if args.key:
|
|
key = args.key
|
|
else:
|
|
key = os.path.basename(args.file)
|
|
|
|
connection = boto.connect_s3()
|
|
upload_s3(connection, args.path, key, args.file, args.bucket);
|
|
|