gcloud 0.0.4 → 0.0.6
Sign up to get free protection for your applications and to get access to all the features.
- data.tar.gz.sig +0 -0
- data/CHANGELOG +4 -0
- data/Makefile +4 -0
- data/Manifest +760 -1
- data/bin/gcloud +7 -0
- data/bin/{gcutil → gcutil.symlink} +0 -0
- data/bin/gsutil-symlink +377 -0
- data/gcloud.gemspec +5 -5
- data/packages/gsutil/CHECKSUM +1 -0
- data/packages/gsutil/COPYING +202 -0
- data/packages/gsutil/LICENSE.third_party +295 -0
- data/packages/gsutil/MANIFEST.in +5 -0
- data/packages/gsutil/README +38 -0
- data/packages/gsutil/README.pkg +49 -0
- data/packages/gsutil/ReleaseNotes.txt +780 -0
- data/packages/gsutil/VERSION +1 -0
- data/packages/gsutil/boto/Changelog.rst +35 -0
- data/packages/gsutil/boto/LICENSE +18 -0
- data/packages/gsutil/boto/MANIFEST.in +12 -0
- data/packages/gsutil/boto/README.rst +163 -0
- data/packages/gsutil/boto/bin/asadmin +290 -0
- data/packages/gsutil/boto/bin/bundle_image +27 -0
- data/packages/gsutil/boto/bin/cfadmin +108 -0
- data/packages/gsutil/boto/bin/cq +89 -0
- data/packages/gsutil/boto/bin/cwutil +140 -0
- data/packages/gsutil/boto/bin/elbadmin +284 -0
- data/packages/gsutil/boto/bin/fetch_file +43 -0
- data/packages/gsutil/boto/bin/glacier +154 -0
- data/packages/gsutil/boto/bin/instance_events +145 -0
- data/packages/gsutil/boto/bin/kill_instance +35 -0
- data/packages/gsutil/boto/bin/launch_instance +252 -0
- data/packages/gsutil/boto/bin/list_instances +90 -0
- data/packages/gsutil/boto/bin/lss3 +77 -0
- data/packages/gsutil/boto/bin/mturk +465 -0
- data/packages/gsutil/boto/bin/pyami_sendmail +52 -0
- data/packages/gsutil/boto/bin/route53 +205 -0
- data/packages/gsutil/boto/bin/s3put +374 -0
- data/packages/gsutil/boto/bin/sdbadmin +194 -0
- data/packages/gsutil/boto/bin/taskadmin +116 -0
- data/packages/gsutil/boto/boto/__init__.py +793 -0
- data/packages/gsutil/boto/boto/__init__.pyc +0 -0
- data/packages/gsutil/boto/boto/auth.py +682 -0
- data/packages/gsutil/boto/boto/auth.pyc +0 -0
- data/packages/gsutil/boto/boto/auth_handler.py +58 -0
- data/packages/gsutil/boto/boto/auth_handler.pyc +0 -0
- data/packages/gsutil/boto/boto/beanstalk/__init__.py +65 -0
- data/packages/gsutil/boto/boto/beanstalk/exception.py +64 -0
- data/packages/gsutil/boto/boto/beanstalk/layer1.py +1153 -0
- data/packages/gsutil/boto/boto/beanstalk/response.py +703 -0
- data/packages/gsutil/boto/boto/beanstalk/wrapper.py +29 -0
- data/packages/gsutil/boto/boto/cacerts/__init__.py +22 -0
- data/packages/gsutil/boto/boto/cacerts/__init__.pyc +0 -0
- data/packages/gsutil/boto/boto/cacerts/cacerts.txt +633 -0
- data/packages/gsutil/boto/boto/cloudformation/__init__.py +68 -0
- data/packages/gsutil/boto/boto/cloudformation/connection.py +364 -0
- data/packages/gsutil/boto/boto/cloudformation/stack.py +360 -0
- data/packages/gsutil/boto/boto/cloudformation/template.py +43 -0
- data/packages/gsutil/boto/boto/cloudfront/__init__.py +324 -0
- data/packages/gsutil/boto/boto/cloudfront/distribution.py +745 -0
- data/packages/gsutil/boto/boto/cloudfront/exception.py +26 -0
- data/packages/gsutil/boto/boto/cloudfront/identity.py +122 -0
- data/packages/gsutil/boto/boto/cloudfront/invalidation.py +216 -0
- data/packages/gsutil/boto/boto/cloudfront/logging.py +38 -0
- data/packages/gsutil/boto/boto/cloudfront/object.py +48 -0
- data/packages/gsutil/boto/boto/cloudfront/origin.py +150 -0
- data/packages/gsutil/boto/boto/cloudfront/signers.py +60 -0
- data/packages/gsutil/boto/boto/cloudsearch/__init__.py +45 -0
- data/packages/gsutil/boto/boto/cloudsearch/document.py +265 -0
- data/packages/gsutil/boto/boto/cloudsearch/domain.py +394 -0
- data/packages/gsutil/boto/boto/cloudsearch/layer1.py +738 -0
- data/packages/gsutil/boto/boto/cloudsearch/layer2.py +67 -0
- data/packages/gsutil/boto/boto/cloudsearch/optionstatus.py +248 -0
- data/packages/gsutil/boto/boto/cloudsearch/search.py +365 -0
- data/packages/gsutil/boto/boto/cloudsearch/sourceattribute.py +75 -0
- data/packages/gsutil/boto/boto/compat.py +28 -0
- data/packages/gsutil/boto/boto/compat.pyc +0 -0
- data/packages/gsutil/boto/boto/connection.py +1081 -0
- data/packages/gsutil/boto/boto/connection.pyc +0 -0
- data/packages/gsutil/boto/boto/contrib/__init__.py +22 -0
- data/packages/gsutil/boto/boto/contrib/ymlmessage.py +52 -0
- data/packages/gsutil/boto/boto/core/README +58 -0
- data/packages/gsutil/boto/boto/core/__init__.py +23 -0
- data/packages/gsutil/boto/boto/core/auth.py +78 -0
- data/packages/gsutil/boto/boto/core/credentials.py +154 -0
- data/packages/gsutil/boto/boto/core/dictresponse.py +178 -0
- data/packages/gsutil/boto/boto/core/service.py +67 -0
- data/packages/gsutil/boto/boto/datapipeline/__init__.py +0 -0
- data/packages/gsutil/boto/boto/datapipeline/exceptions.py +42 -0
- data/packages/gsutil/boto/boto/datapipeline/layer1.py +546 -0
- data/packages/gsutil/boto/boto/dynamodb/__init__.py +66 -0
- data/packages/gsutil/boto/boto/dynamodb/batch.py +262 -0
- data/packages/gsutil/boto/boto/dynamodb/condition.py +170 -0
- data/packages/gsutil/boto/boto/dynamodb/exceptions.py +64 -0
- data/packages/gsutil/boto/boto/dynamodb/item.py +196 -0
- data/packages/gsutil/boto/boto/dynamodb/layer1.py +575 -0
- data/packages/gsutil/boto/boto/dynamodb/layer2.py +798 -0
- data/packages/gsutil/boto/boto/dynamodb/schema.py +112 -0
- data/packages/gsutil/boto/boto/dynamodb/table.py +540 -0
- data/packages/gsutil/boto/boto/dynamodb/types.py +326 -0
- data/packages/gsutil/boto/boto/ec2/__init__.py +96 -0
- data/packages/gsutil/boto/boto/ec2/address.py +103 -0
- data/packages/gsutil/boto/boto/ec2/autoscale/__init__.py +781 -0
- data/packages/gsutil/boto/boto/ec2/autoscale/activity.py +74 -0
- data/packages/gsutil/boto/boto/ec2/autoscale/group.py +337 -0
- data/packages/gsutil/boto/boto/ec2/autoscale/instance.py +60 -0
- data/packages/gsutil/boto/boto/ec2/autoscale/launchconfig.py +209 -0
- data/packages/gsutil/boto/boto/ec2/autoscale/policy.py +166 -0
- data/packages/gsutil/boto/boto/ec2/autoscale/request.py +38 -0
- data/packages/gsutil/boto/boto/ec2/autoscale/scheduled.py +60 -0
- data/packages/gsutil/boto/boto/ec2/autoscale/tag.py +84 -0
- data/packages/gsutil/boto/boto/ec2/blockdevicemapping.py +141 -0
- data/packages/gsutil/boto/boto/ec2/bundleinstance.py +78 -0
- data/packages/gsutil/boto/boto/ec2/buyreservation.py +84 -0
- data/packages/gsutil/boto/boto/ec2/cloudwatch/__init__.py +603 -0
- data/packages/gsutil/boto/boto/ec2/cloudwatch/alarm.py +316 -0
- data/packages/gsutil/boto/boto/ec2/cloudwatch/datapoint.py +40 -0
- data/packages/gsutil/boto/boto/ec2/cloudwatch/dimension.py +38 -0
- data/packages/gsutil/boto/boto/ec2/cloudwatch/listelement.py +31 -0
- data/packages/gsutil/boto/boto/ec2/cloudwatch/metric.py +175 -0
- data/packages/gsutil/boto/boto/ec2/connection.py +3409 -0
- data/packages/gsutil/boto/boto/ec2/ec2object.py +107 -0
- data/packages/gsutil/boto/boto/ec2/elb/__init__.py +553 -0
- data/packages/gsutil/boto/boto/ec2/elb/healthcheck.py +89 -0
- data/packages/gsutil/boto/boto/ec2/elb/instancestate.py +62 -0
- data/packages/gsutil/boto/boto/ec2/elb/listelement.py +36 -0
- data/packages/gsutil/boto/boto/ec2/elb/listener.py +75 -0
- data/packages/gsutil/boto/boto/ec2/elb/loadbalancer.py +324 -0
- data/packages/gsutil/boto/boto/ec2/elb/policies.py +89 -0
- data/packages/gsutil/boto/boto/ec2/elb/securitygroup.py +38 -0
- data/packages/gsutil/boto/boto/ec2/group.py +39 -0
- data/packages/gsutil/boto/boto/ec2/image.py +350 -0
- data/packages/gsutil/boto/boto/ec2/instance.py +661 -0
- data/packages/gsutil/boto/boto/ec2/instanceinfo.py +51 -0
- data/packages/gsutil/boto/boto/ec2/instancestatus.py +207 -0
- data/packages/gsutil/boto/boto/ec2/keypair.py +113 -0
- data/packages/gsutil/boto/boto/ec2/launchspecification.py +105 -0
- data/packages/gsutil/boto/boto/ec2/networkinterface.py +247 -0
- data/packages/gsutil/boto/boto/ec2/placementgroup.py +51 -0
- data/packages/gsutil/boto/boto/ec2/regioninfo.py +34 -0
- data/packages/gsutil/boto/boto/ec2/reservedinstance.py +227 -0
- data/packages/gsutil/boto/boto/ec2/securitygroup.py +357 -0
- data/packages/gsutil/boto/boto/ec2/snapshot.py +170 -0
- data/packages/gsutil/boto/boto/ec2/spotdatafeedsubscription.py +63 -0
- data/packages/gsutil/boto/boto/ec2/spotinstancerequest.py +188 -0
- data/packages/gsutil/boto/boto/ec2/spotpricehistory.py +55 -0
- data/packages/gsutil/boto/boto/ec2/tag.py +87 -0
- data/packages/gsutil/boto/boto/ec2/vmtype.py +58 -0
- data/packages/gsutil/boto/boto/ec2/volume.py +293 -0
- data/packages/gsutil/boto/boto/ec2/volumestatus.py +200 -0
- data/packages/gsutil/boto/boto/ec2/zone.py +80 -0
- data/packages/gsutil/boto/boto/ecs/__init__.py +90 -0
- data/packages/gsutil/boto/boto/ecs/item.py +153 -0
- data/packages/gsutil/boto/boto/elasticache/__init__.py +62 -0
- data/packages/gsutil/boto/boto/elasticache/layer1.py +1252 -0
- data/packages/gsutil/boto/boto/elastictranscoder/__init__.py +62 -0
- data/packages/gsutil/boto/boto/elastictranscoder/exceptions.py +46 -0
- data/packages/gsutil/boto/boto/elastictranscoder/layer1.py +509 -0
- data/packages/gsutil/boto/boto/emr/__init__.py +73 -0
- data/packages/gsutil/boto/boto/emr/bootstrap_action.py +44 -0
- data/packages/gsutil/boto/boto/emr/connection.py +531 -0
- data/packages/gsutil/boto/boto/emr/emrobject.py +176 -0
- data/packages/gsutil/boto/boto/emr/instance_group.py +43 -0
- data/packages/gsutil/boto/boto/emr/step.py +281 -0
- data/packages/gsutil/boto/boto/exception.py +476 -0
- data/packages/gsutil/boto/boto/exception.pyc +0 -0
- data/packages/gsutil/boto/boto/file/README +49 -0
- data/packages/gsutil/boto/boto/file/__init__.py +28 -0
- data/packages/gsutil/boto/boto/file/bucket.py +112 -0
- data/packages/gsutil/boto/boto/file/connection.py +33 -0
- data/packages/gsutil/boto/boto/file/key.py +199 -0
- data/packages/gsutil/boto/boto/file/simpleresultset.py +30 -0
- data/packages/gsutil/boto/boto/fps/__init__.py +21 -0
- data/packages/gsutil/boto/boto/fps/connection.py +369 -0
- data/packages/gsutil/boto/boto/fps/exception.py +344 -0
- data/packages/gsutil/boto/boto/fps/response.py +175 -0
- data/packages/gsutil/boto/boto/glacier/__init__.py +57 -0
- data/packages/gsutil/boto/boto/glacier/concurrent.py +409 -0
- data/packages/gsutil/boto/boto/glacier/exceptions.py +58 -0
- data/packages/gsutil/boto/boto/glacier/job.py +152 -0
- data/packages/gsutil/boto/boto/glacier/layer1.py +637 -0
- data/packages/gsutil/boto/boto/glacier/layer2.py +93 -0
- data/packages/gsutil/boto/boto/glacier/response.py +48 -0
- data/packages/gsutil/boto/boto/glacier/utils.py +163 -0
- data/packages/gsutil/boto/boto/glacier/vault.py +387 -0
- data/packages/gsutil/boto/boto/glacier/writer.py +242 -0
- data/packages/gsutil/boto/boto/gs/__init__.py +22 -0
- data/packages/gsutil/boto/boto/gs/__init__.pyc +0 -0
- data/packages/gsutil/boto/boto/gs/acl.py +304 -0
- data/packages/gsutil/boto/boto/gs/acl.pyc +0 -0
- data/packages/gsutil/boto/boto/gs/bucket.py +870 -0
- data/packages/gsutil/boto/boto/gs/bucket.pyc +0 -0
- data/packages/gsutil/boto/boto/gs/bucketlistresultset.py +64 -0
- data/packages/gsutil/boto/boto/gs/bucketlistresultset.pyc +0 -0
- data/packages/gsutil/boto/boto/gs/connection.py +103 -0
- data/packages/gsutil/boto/boto/gs/connection.pyc +0 -0
- data/packages/gsutil/boto/boto/gs/cors.py +169 -0
- data/packages/gsutil/boto/boto/gs/cors.pyc +0 -0
- data/packages/gsutil/boto/boto/gs/key.py +704 -0
- data/packages/gsutil/boto/boto/gs/key.pyc +0 -0
- data/packages/gsutil/boto/boto/gs/resumable_upload_handler.py +659 -0
- data/packages/gsutil/boto/boto/gs/resumable_upload_handler.pyc +0 -0
- data/packages/gsutil/boto/boto/gs/user.py +54 -0
- data/packages/gsutil/boto/boto/gs/user.pyc +0 -0
- data/packages/gsutil/boto/boto/handler.py +44 -0
- data/packages/gsutil/boto/boto/handler.pyc +0 -0
- data/packages/gsutil/boto/boto/https_connection.py +124 -0
- data/packages/gsutil/boto/boto/https_connection.pyc +0 -0
- data/packages/gsutil/boto/boto/iam/__init__.py +74 -0
- data/packages/gsutil/boto/boto/iam/connection.py +1317 -0
- data/packages/gsutil/boto/boto/iam/summarymap.py +42 -0
- data/packages/gsutil/boto/boto/jsonresponse.py +163 -0
- data/packages/gsutil/boto/boto/jsonresponse.pyc +0 -0
- data/packages/gsutil/boto/boto/manage/__init__.py +23 -0
- data/packages/gsutil/boto/boto/manage/cmdshell.py +241 -0
- data/packages/gsutil/boto/boto/manage/propget.py +64 -0
- data/packages/gsutil/boto/boto/manage/server.py +556 -0
- data/packages/gsutil/boto/boto/manage/task.py +175 -0
- data/packages/gsutil/boto/boto/manage/test_manage.py +34 -0
- data/packages/gsutil/boto/boto/manage/volume.py +420 -0
- data/packages/gsutil/boto/boto/mashups/__init__.py +23 -0
- data/packages/gsutil/boto/boto/mashups/interactive.py +97 -0
- data/packages/gsutil/boto/boto/mashups/iobject.py +115 -0
- data/packages/gsutil/boto/boto/mashups/order.py +211 -0
- data/packages/gsutil/boto/boto/mashups/server.py +395 -0
- data/packages/gsutil/boto/boto/mturk/__init__.py +23 -0
- data/packages/gsutil/boto/boto/mturk/connection.py +1027 -0
- data/packages/gsutil/boto/boto/mturk/layoutparam.py +55 -0
- data/packages/gsutil/boto/boto/mturk/notification.py +103 -0
- data/packages/gsutil/boto/boto/mturk/price.py +48 -0
- data/packages/gsutil/boto/boto/mturk/qualification.py +137 -0
- data/packages/gsutil/boto/boto/mturk/question.py +455 -0
- data/packages/gsutil/boto/boto/mws/__init__.py +21 -0
- data/packages/gsutil/boto/boto/mws/connection.py +813 -0
- data/packages/gsutil/boto/boto/mws/exception.py +75 -0
- data/packages/gsutil/boto/boto/mws/response.py +655 -0
- data/packages/gsutil/boto/boto/plugin.py +90 -0
- data/packages/gsutil/boto/boto/plugin.pyc +0 -0
- data/packages/gsutil/boto/boto/provider.py +337 -0
- data/packages/gsutil/boto/boto/provider.pyc +0 -0
- data/packages/gsutil/boto/boto/pyami/__init__.py +22 -0
- data/packages/gsutil/boto/boto/pyami/__init__.pyc +0 -0
- data/packages/gsutil/boto/boto/pyami/bootstrap.py +134 -0
- data/packages/gsutil/boto/boto/pyami/config.py +229 -0
- data/packages/gsutil/boto/boto/pyami/config.pyc +0 -0
- data/packages/gsutil/boto/boto/pyami/copybot.cfg +60 -0
- data/packages/gsutil/boto/boto/pyami/copybot.py +97 -0
- data/packages/gsutil/boto/boto/pyami/helloworld.py +28 -0
- data/packages/gsutil/boto/boto/pyami/installers/__init__.py +64 -0
- data/packages/gsutil/boto/boto/pyami/installers/ubuntu/__init__.py +22 -0
- data/packages/gsutil/boto/boto/pyami/installers/ubuntu/apache.py +43 -0
- data/packages/gsutil/boto/boto/pyami/installers/ubuntu/ebs.py +238 -0
- data/packages/gsutil/boto/boto/pyami/installers/ubuntu/installer.py +96 -0
- data/packages/gsutil/boto/boto/pyami/installers/ubuntu/mysql.py +109 -0
- data/packages/gsutil/boto/boto/pyami/installers/ubuntu/trac.py +139 -0
- data/packages/gsutil/boto/boto/pyami/launch_ami.py +178 -0
- data/packages/gsutil/boto/boto/pyami/scriptbase.py +44 -0
- data/packages/gsutil/boto/boto/pyami/startup.py +60 -0
- data/packages/gsutil/boto/boto/rds/__init__.py +1194 -0
- data/packages/gsutil/boto/boto/rds/dbinstance.py +357 -0
- data/packages/gsutil/boto/boto/rds/dbsecuritygroup.py +177 -0
- data/packages/gsutil/boto/boto/rds/dbsnapshot.py +108 -0
- data/packages/gsutil/boto/boto/rds/event.py +49 -0
- data/packages/gsutil/boto/boto/rds/parametergroup.py +201 -0
- data/packages/gsutil/boto/boto/rds/regioninfo.py +32 -0
- data/packages/gsutil/boto/boto/regioninfo.py +63 -0
- data/packages/gsutil/boto/boto/regioninfo.pyc +0 -0
- data/packages/gsutil/boto/boto/resultset.py +169 -0
- data/packages/gsutil/boto/boto/resultset.pyc +0 -0
- data/packages/gsutil/boto/boto/roboto/__init__.py +1 -0
- data/packages/gsutil/boto/boto/roboto/awsqueryrequest.py +504 -0
- data/packages/gsutil/boto/boto/roboto/awsqueryservice.py +121 -0
- data/packages/gsutil/boto/boto/roboto/param.py +147 -0
- data/packages/gsutil/boto/boto/route53/__init__.py +75 -0
- data/packages/gsutil/boto/boto/route53/connection.py +403 -0
- data/packages/gsutil/boto/boto/route53/exception.py +27 -0
- data/packages/gsutil/boto/boto/route53/hostedzone.py +56 -0
- data/packages/gsutil/boto/boto/route53/record.py +306 -0
- data/packages/gsutil/boto/boto/route53/status.py +42 -0
- data/packages/gsutil/boto/boto/route53/zone.py +412 -0
- data/packages/gsutil/boto/boto/s3/__init__.py +84 -0
- data/packages/gsutil/boto/boto/s3/__init__.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/acl.py +164 -0
- data/packages/gsutil/boto/boto/s3/acl.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/bucket.py +1634 -0
- data/packages/gsutil/boto/boto/s3/bucket.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/bucketlistresultset.py +139 -0
- data/packages/gsutil/boto/boto/s3/bucketlistresultset.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/bucketlogging.py +83 -0
- data/packages/gsutil/boto/boto/s3/bucketlogging.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/connection.py +540 -0
- data/packages/gsutil/boto/boto/s3/connection.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/cors.py +210 -0
- data/packages/gsutil/boto/boto/s3/cors.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/deletemarker.py +55 -0
- data/packages/gsutil/boto/boto/s3/deletemarker.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/key.py +1712 -0
- data/packages/gsutil/boto/boto/s3/key.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/keyfile.py +134 -0
- data/packages/gsutil/boto/boto/s3/keyfile.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/lifecycle.py +231 -0
- data/packages/gsutil/boto/boto/s3/lifecycle.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/multidelete.py +138 -0
- data/packages/gsutil/boto/boto/s3/multidelete.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/multipart.py +315 -0
- data/packages/gsutil/boto/boto/s3/multipart.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/prefix.py +42 -0
- data/packages/gsutil/boto/boto/s3/prefix.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/resumable_download_handler.py +339 -0
- data/packages/gsutil/boto/boto/s3/resumable_download_handler.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/tagging.py +71 -0
- data/packages/gsutil/boto/boto/s3/tagging.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/user.py +49 -0
- data/packages/gsutil/boto/boto/s3/user.pyc +0 -0
- data/packages/gsutil/boto/boto/s3/website.py +237 -0
- data/packages/gsutil/boto/boto/s3/website.pyc +0 -0
- data/packages/gsutil/boto/boto/sdb/__init__.py +67 -0
- data/packages/gsutil/boto/boto/sdb/connection.py +617 -0
- data/packages/gsutil/boto/boto/sdb/db/__init__.py +20 -0
- data/packages/gsutil/boto/boto/sdb/db/blob.py +75 -0
- data/packages/gsutil/boto/boto/sdb/db/key.py +59 -0
- data/packages/gsutil/boto/boto/sdb/db/manager/__init__.py +85 -0
- data/packages/gsutil/boto/boto/sdb/db/manager/sdbmanager.py +732 -0
- data/packages/gsutil/boto/boto/sdb/db/manager/xmlmanager.py +517 -0
- data/packages/gsutil/boto/boto/sdb/db/model.py +294 -0
- data/packages/gsutil/boto/boto/sdb/db/property.py +703 -0
- data/packages/gsutil/boto/boto/sdb/db/query.py +85 -0
- data/packages/gsutil/boto/boto/sdb/db/sequence.py +226 -0
- data/packages/gsutil/boto/boto/sdb/db/test_db.py +231 -0
- data/packages/gsutil/boto/boto/sdb/domain.py +377 -0
- data/packages/gsutil/boto/boto/sdb/item.py +181 -0
- data/packages/gsutil/boto/boto/sdb/queryresultset.py +92 -0
- data/packages/gsutil/boto/boto/sdb/regioninfo.py +32 -0
- data/packages/gsutil/boto/boto/services/__init__.py +23 -0
- data/packages/gsutil/boto/boto/services/bs.py +179 -0
- data/packages/gsutil/boto/boto/services/message.py +58 -0
- data/packages/gsutil/boto/boto/services/result.py +136 -0
- data/packages/gsutil/boto/boto/services/service.py +161 -0
- data/packages/gsutil/boto/boto/services/servicedef.py +91 -0
- data/packages/gsutil/boto/boto/services/sonofmmm.cfg +43 -0
- data/packages/gsutil/boto/boto/services/sonofmmm.py +81 -0
- data/packages/gsutil/boto/boto/services/submit.py +88 -0
- data/packages/gsutil/boto/boto/ses/__init__.py +54 -0
- data/packages/gsutil/boto/boto/ses/connection.py +521 -0
- data/packages/gsutil/boto/boto/ses/exceptions.py +77 -0
- data/packages/gsutil/boto/boto/sns/__init__.py +78 -0
- data/packages/gsutil/boto/boto/sns/connection.py +431 -0
- data/packages/gsutil/boto/boto/sqs/__init__.py +56 -0
- data/packages/gsutil/boto/boto/sqs/attributes.py +46 -0
- data/packages/gsutil/boto/boto/sqs/batchresults.py +95 -0
- data/packages/gsutil/boto/boto/sqs/connection.py +417 -0
- data/packages/gsutil/boto/boto/sqs/jsonmessage.py +43 -0
- data/packages/gsutil/boto/boto/sqs/message.py +253 -0
- data/packages/gsutil/boto/boto/sqs/queue.py +478 -0
- data/packages/gsutil/boto/boto/sqs/regioninfo.py +32 -0
- data/packages/gsutil/boto/boto/storage_uri.py +835 -0
- data/packages/gsutil/boto/boto/storage_uri.pyc +0 -0
- data/packages/gsutil/boto/boto/sts/__init__.py +55 -0
- data/packages/gsutil/boto/boto/sts/connection.py +207 -0
- data/packages/gsutil/boto/boto/sts/credentials.py +215 -0
- data/packages/gsutil/boto/boto/swf/__init__.py +60 -0
- data/packages/gsutil/boto/boto/swf/exceptions.py +44 -0
- data/packages/gsutil/boto/boto/swf/layer1.py +1512 -0
- data/packages/gsutil/boto/boto/swf/layer1_decisions.py +287 -0
- data/packages/gsutil/boto/boto/swf/layer2.py +342 -0
- data/packages/gsutil/boto/boto/utils.py +927 -0
- data/packages/gsutil/boto/boto/utils.pyc +0 -0
- data/packages/gsutil/boto/boto/vpc/__init__.py +910 -0
- data/packages/gsutil/boto/boto/vpc/customergateway.py +54 -0
- data/packages/gsutil/boto/boto/vpc/dhcpoptions.py +72 -0
- data/packages/gsutil/boto/boto/vpc/internetgateway.py +72 -0
- data/packages/gsutil/boto/boto/vpc/routetable.py +109 -0
- data/packages/gsutil/boto/boto/vpc/subnet.py +57 -0
- data/packages/gsutil/boto/boto/vpc/vpc.py +54 -0
- data/packages/gsutil/boto/boto/vpc/vpnconnection.py +60 -0
- data/packages/gsutil/boto/boto/vpc/vpngateway.py +83 -0
- data/packages/gsutil/boto/docs/BotoCheatSheet.pdf +0 -0
- data/packages/gsutil/boto/docs/Makefile +89 -0
- data/packages/gsutil/boto/docs/make.bat +113 -0
- data/packages/gsutil/boto/docs/source/_templates/layout.html +3 -0
- data/packages/gsutil/boto/docs/source/autoscale_tut.rst +220 -0
- data/packages/gsutil/boto/docs/source/boto_config_tut.rst +125 -0
- data/packages/gsutil/boto/docs/source/boto_theme/static/boto.css_t +239 -0
- data/packages/gsutil/boto/docs/source/boto_theme/static/pygments.css +61 -0
- data/packages/gsutil/boto/docs/source/boto_theme/theme.conf +3 -0
- data/packages/gsutil/boto/docs/source/cloudfront_tut.rst +196 -0
- data/packages/gsutil/boto/docs/source/cloudsearch_tut.rst +411 -0
- data/packages/gsutil/boto/docs/source/cloudwatch_tut.rst +116 -0
- data/packages/gsutil/boto/docs/source/conf.py +32 -0
- data/packages/gsutil/boto/docs/source/contributing.rst +204 -0
- data/packages/gsutil/boto/docs/source/documentation.rst +59 -0
- data/packages/gsutil/boto/docs/source/dynamodb_tut.rst +339 -0
- data/packages/gsutil/boto/docs/source/ec2_tut.rst +86 -0
- data/packages/gsutil/boto/docs/source/elb_tut.rst +257 -0
- data/packages/gsutil/boto/docs/source/emr_tut.rst +108 -0
- data/packages/gsutil/boto/docs/source/index.rst +146 -0
- data/packages/gsutil/boto/docs/source/rds_tut.rst +108 -0
- data/packages/gsutil/boto/docs/source/ref/autoscale.rst +62 -0
- data/packages/gsutil/boto/docs/source/ref/beanstalk.rst +26 -0
- data/packages/gsutil/boto/docs/source/ref/boto.rst +47 -0
- data/packages/gsutil/boto/docs/source/ref/cloudformation.rst +34 -0
- data/packages/gsutil/boto/docs/source/ref/cloudfront.rst +68 -0
- data/packages/gsutil/boto/docs/source/ref/cloudsearch.rst +59 -0
- data/packages/gsutil/boto/docs/source/ref/cloudwatch.rst +27 -0
- data/packages/gsutil/boto/docs/source/ref/contrib.rst +32 -0
- data/packages/gsutil/boto/docs/source/ref/datapipeline.rst +26 -0
- data/packages/gsutil/boto/docs/source/ref/dynamodb.rst +61 -0
- data/packages/gsutil/boto/docs/source/ref/ec2.rst +140 -0
- data/packages/gsutil/boto/docs/source/ref/ecs.rst +19 -0
- data/packages/gsutil/boto/docs/source/ref/elasticache.rst +19 -0
- data/packages/gsutil/boto/docs/source/ref/elastictranscoder.rst +26 -0
- data/packages/gsutil/boto/docs/source/ref/elb.rst +47 -0
- data/packages/gsutil/boto/docs/source/ref/emr.rst +34 -0
- data/packages/gsutil/boto/docs/source/ref/file.rst +34 -0
- data/packages/gsutil/boto/docs/source/ref/fps.rst +19 -0
- data/packages/gsutil/boto/docs/source/ref/glacier.rst +63 -0
- data/packages/gsutil/boto/docs/source/ref/gs.rst +72 -0
- data/packages/gsutil/boto/docs/source/ref/iam.rst +27 -0
- data/packages/gsutil/boto/docs/source/ref/index.rst +40 -0
- data/packages/gsutil/boto/docs/source/ref/manage.rst +47 -0
- data/packages/gsutil/boto/docs/source/ref/mturk.rst +54 -0
- data/packages/gsutil/boto/docs/source/ref/mws.rst +33 -0
- data/packages/gsutil/boto/docs/source/ref/pyami.rst +103 -0
- data/packages/gsutil/boto/docs/source/ref/rds.rst +47 -0
- data/packages/gsutil/boto/docs/source/ref/route53.rst +34 -0
- data/packages/gsutil/boto/docs/source/ref/s3.rst +111 -0
- data/packages/gsutil/boto/docs/source/ref/sdb.rst +45 -0
- data/packages/gsutil/boto/docs/source/ref/sdb_db.rst +83 -0
- data/packages/gsutil/boto/docs/source/ref/services.rst +61 -0
- data/packages/gsutil/boto/docs/source/ref/ses.rst +21 -0
- data/packages/gsutil/boto/docs/source/ref/sns.rst +17 -0
- data/packages/gsutil/boto/docs/source/ref/sqs.rst +61 -0
- data/packages/gsutil/boto/docs/source/ref/sts.rst +25 -0
- data/packages/gsutil/boto/docs/source/ref/swf.rst +22 -0
- data/packages/gsutil/boto/docs/source/ref/vpc.rst +54 -0
- data/packages/gsutil/boto/docs/source/s3_tut.rst +450 -0
- data/packages/gsutil/boto/docs/source/security_groups.rst +82 -0
- data/packages/gsutil/boto/docs/source/ses_tut.rst +171 -0
- data/packages/gsutil/boto/docs/source/simpledb_tut.rst +188 -0
- data/packages/gsutil/boto/docs/source/sqs_tut.rst +246 -0
- data/packages/gsutil/boto/docs/source/vpc_tut.rst +100 -0
- data/packages/gsutil/boto/pylintrc +305 -0
- data/packages/gsutil/boto/requirements.txt +10 -0
- data/packages/gsutil/boto/setup.py +89 -0
- data/packages/gsutil/boto/tests/__init__.py +20 -0
- data/packages/gsutil/boto/tests/db/test_lists.py +96 -0
- data/packages/gsutil/boto/tests/db/test_password.py +128 -0
- data/packages/gsutil/boto/tests/db/test_query.py +152 -0
- data/packages/gsutil/boto/tests/db/test_sequence.py +109 -0
- data/packages/gsutil/boto/tests/devpay/__init__.py +0 -0
- data/packages/gsutil/boto/tests/devpay/test_s3.py +181 -0
- data/packages/gsutil/boto/tests/fps/__init__.py +0 -0
- data/packages/gsutil/boto/tests/fps/test.py +100 -0
- data/packages/gsutil/boto/tests/fps/test_verify_signature.py +12 -0
- data/packages/gsutil/boto/tests/integration/__init__.py +0 -0
- data/packages/gsutil/boto/tests/integration/beanstalk/test_wrapper.py +209 -0
- data/packages/gsutil/boto/tests/integration/cloudformation/__init__.py +21 -0
- data/packages/gsutil/boto/tests/integration/cloudformation/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/cloudformation/test_connection.py +110 -0
- data/packages/gsutil/boto/tests/integration/cloudsearch/__init__.py +21 -0
- data/packages/gsutil/boto/tests/integration/cloudsearch/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/datapipeline/test_layer1.py +122 -0
- data/packages/gsutil/boto/tests/integration/dynamodb/__init__.py +20 -0
- data/packages/gsutil/boto/tests/integration/dynamodb/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/dynamodb/test_layer1.py +266 -0
- data/packages/gsutil/boto/tests/integration/dynamodb/test_layer2.py +484 -0
- data/packages/gsutil/boto/tests/integration/dynamodb/test_table.py +84 -0
- data/packages/gsutil/boto/tests/integration/ec2/__init__.py +20 -0
- data/packages/gsutil/boto/tests/integration/ec2/autoscale/__init__.py +21 -0
- data/packages/gsutil/boto/tests/integration/ec2/autoscale/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/ec2/autoscale/test_connection.py +167 -0
- data/packages/gsutil/boto/tests/integration/ec2/cloudwatch/__init__.py +20 -0
- data/packages/gsutil/boto/tests/integration/ec2/cloudwatch/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/ec2/cloudwatch/test_connection.py +277 -0
- data/packages/gsutil/boto/tests/integration/ec2/elb/__init__.py +20 -0
- data/packages/gsutil/boto/tests/integration/ec2/elb/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/ec2/elb/test_connection.py +130 -0
- data/packages/gsutil/boto/tests/integration/ec2/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/ec2/test_connection.py +192 -0
- data/packages/gsutil/boto/tests/integration/ec2/vpc/__init__.py +0 -0
- data/packages/gsutil/boto/tests/integration/ec2/vpc/test_connection.py +95 -0
- data/packages/gsutil/boto/tests/integration/elasticache/__init__.py +0 -0
- data/packages/gsutil/boto/tests/integration/elasticache/test_layer1.py +67 -0
- data/packages/gsutil/boto/tests/integration/elastictranscoder/__init__.py +0 -0
- data/packages/gsutil/boto/tests/integration/elastictranscoder/test_cert_verification.py +35 -0
- data/packages/gsutil/boto/tests/integration/elastictranscoder/test_layer1.py +115 -0
- data/packages/gsutil/boto/tests/integration/emr/__init__.py +20 -0
- data/packages/gsutil/boto/tests/integration/emr/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/glacier/__init__.py +22 -0
- data/packages/gsutil/boto/tests/integration/glacier/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/glacier/test_layer1.py +44 -0
- data/packages/gsutil/boto/tests/integration/glacier/test_layer2.py +45 -0
- data/packages/gsutil/boto/tests/integration/gs/__init__.py +0 -0
- data/packages/gsutil/boto/tests/integration/gs/cb_test_harness.py +71 -0
- data/packages/gsutil/boto/tests/integration/gs/test_basic.py +379 -0
- data/packages/gsutil/boto/tests/integration/gs/test_generation_conditionals.py +399 -0
- data/packages/gsutil/boto/tests/integration/gs/test_resumable_downloads.py +358 -0
- data/packages/gsutil/boto/tests/integration/gs/test_resumable_uploads.py +525 -0
- data/packages/gsutil/boto/tests/integration/gs/test_storage_uri.py +125 -0
- data/packages/gsutil/boto/tests/integration/gs/test_versioning.py +268 -0
- data/packages/gsutil/boto/tests/integration/gs/testcase.py +116 -0
- data/packages/gsutil/boto/tests/integration/gs/util.py +63 -0
- data/packages/gsutil/boto/tests/integration/iam/__init__.py +20 -0
- data/packages/gsutil/boto/tests/integration/iam/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/mws/__init__.py +0 -0
- data/packages/gsutil/boto/tests/integration/mws/test.py +100 -0
- data/packages/gsutil/boto/tests/integration/rds/__init__.py +21 -0
- data/packages/gsutil/boto/tests/integration/rds/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/route53/__init__.py +20 -0
- data/packages/gsutil/boto/tests/integration/route53/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/route53/test_zone.py +132 -0
- data/packages/gsutil/boto/tests/integration/s3/__init__.py +20 -0
- data/packages/gsutil/boto/tests/integration/s3/mock_storage_service.py +589 -0
- data/packages/gsutil/boto/tests/integration/s3/other_cacerts.txt +70 -0
- data/packages/gsutil/boto/tests/integration/s3/test_bucket.py +263 -0
- data/packages/gsutil/boto/tests/integration/s3/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/s3/test_connection.py +245 -0
- data/packages/gsutil/boto/tests/integration/s3/test_cors.py +78 -0
- data/packages/gsutil/boto/tests/integration/s3/test_encryption.py +115 -0
- data/packages/gsutil/boto/tests/integration/s3/test_https_cert_validation.py +141 -0
- data/packages/gsutil/boto/tests/integration/s3/test_key.py +375 -0
- data/packages/gsutil/boto/tests/integration/s3/test_mfa.py +95 -0
- data/packages/gsutil/boto/tests/integration/s3/test_multidelete.py +181 -0
- data/packages/gsutil/boto/tests/integration/s3/test_multipart.py +139 -0
- data/packages/gsutil/boto/tests/integration/s3/test_pool.py +246 -0
- data/packages/gsutil/boto/tests/integration/s3/test_versioning.py +158 -0
- data/packages/gsutil/boto/tests/integration/sdb/__init__.py +20 -0
- data/packages/gsutil/boto/tests/integration/sdb/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/sdb/test_connection.py +119 -0
- data/packages/gsutil/boto/tests/integration/ses/__init__.py +0 -0
- data/packages/gsutil/boto/tests/integration/ses/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/ses/test_connection.py +38 -0
- data/packages/gsutil/boto/tests/integration/sns/__init__.py +20 -0
- data/packages/gsutil/boto/tests/integration/sns/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/sqs/__init__.py +20 -0
- data/packages/gsutil/boto/tests/integration/sqs/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/sqs/test_connection.py +217 -0
- data/packages/gsutil/boto/tests/integration/sts/__init__.py +20 -0
- data/packages/gsutil/boto/tests/integration/sts/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/sts/test_session_token.py +65 -0
- data/packages/gsutil/boto/tests/integration/swf/__init__.py +0 -0
- data/packages/gsutil/boto/tests/integration/swf/test_cert_verification.py +40 -0
- data/packages/gsutil/boto/tests/integration/swf/test_layer1.py +246 -0
- data/packages/gsutil/boto/tests/integration/swf/test_layer1_workflow_execution.py +173 -0
- data/packages/gsutil/boto/tests/mturk/__init__.py +0 -0
- data/packages/gsutil/boto/tests/mturk/_init_environment.py +28 -0
- data/packages/gsutil/boto/tests/mturk/all_tests.py +24 -0
- data/packages/gsutil/boto/tests/mturk/cleanup_tests.py +47 -0
- data/packages/gsutil/boto/tests/mturk/common.py +45 -0
- data/packages/gsutil/boto/tests/mturk/create_free_text_question_regex.doctest +100 -0
- data/packages/gsutil/boto/tests/mturk/create_hit.doctest +92 -0
- data/packages/gsutil/boto/tests/mturk/create_hit_binary.doctest +94 -0
- data/packages/gsutil/boto/tests/mturk/create_hit_external.py +21 -0
- data/packages/gsutil/boto/tests/mturk/create_hit_from_hit_type.doctest +103 -0
- data/packages/gsutil/boto/tests/mturk/create_hit_test.py +21 -0
- data/packages/gsutil/boto/tests/mturk/create_hit_with_qualifications.py +16 -0
- data/packages/gsutil/boto/tests/mturk/hit_persistence.py +27 -0
- data/packages/gsutil/boto/tests/mturk/mocks.py +11 -0
- data/packages/gsutil/boto/tests/mturk/reviewable_hits.doctest +129 -0
- data/packages/gsutil/boto/tests/mturk/run-doctest.py +13 -0
- data/packages/gsutil/boto/tests/mturk/search_hits.doctest +16 -0
- data/packages/gsutil/boto/tests/mturk/selenium_support.py +61 -0
- data/packages/gsutil/boto/tests/mturk/support.py +7 -0
- data/packages/gsutil/boto/tests/mturk/test_disable_hit.py +11 -0
- data/packages/gsutil/boto/tests/test.py +59 -0
- data/packages/gsutil/boto/tests/unit/__init__.py +79 -0
- data/packages/gsutil/boto/tests/unit/auth/__init__.py +0 -0
- data/packages/gsutil/boto/tests/unit/auth/test_sigv4.py +73 -0
- data/packages/gsutil/boto/tests/unit/beanstalk/__init__.py +0 -0
- data/packages/gsutil/boto/tests/unit/beanstalk/test_layer1.py +128 -0
- data/packages/gsutil/boto/tests/unit/cloudformation/__init__.py +0 -0
- data/packages/gsutil/boto/tests/unit/cloudformation/test_connection.py +605 -0
- data/packages/gsutil/boto/tests/unit/cloudformation/test_stack.py +63 -0
- data/packages/gsutil/boto/tests/unit/cloudfront/__init__.py +0 -0
- data/packages/gsutil/boto/tests/unit/cloudfront/test_invalidation_list.py +113 -0
- data/packages/gsutil/boto/tests/unit/cloudfront/test_signed_urls.py +354 -0
- data/packages/gsutil/boto/tests/unit/cloudsearch/__init__.py +1 -0
- data/packages/gsutil/boto/tests/unit/cloudsearch/test_connection.py +241 -0
- data/packages/gsutil/boto/tests/unit/cloudsearch/test_document.py +324 -0
- data/packages/gsutil/boto/tests/unit/cloudsearch/test_search.py +325 -0
- data/packages/gsutil/boto/tests/unit/dynamodb/__init__.py +0 -0
- data/packages/gsutil/boto/tests/unit/dynamodb/test_batch.py +103 -0
- data/packages/gsutil/boto/tests/unit/dynamodb/test_layer2.py +119 -0
- data/packages/gsutil/boto/tests/unit/dynamodb/test_types.py +82 -0
- data/packages/gsutil/boto/tests/unit/ec2/__init__.py +0 -0
- data/packages/gsutil/boto/tests/unit/ec2/autoscale/__init__.py +0 -0
- data/packages/gsutil/boto/tests/unit/ec2/autoscale/test_group.py +162 -0
- data/packages/gsutil/boto/tests/unit/ec2/test_address.py +39 -0
- data/packages/gsutil/boto/tests/unit/ec2/test_blockdevicemapping.py +79 -0
- data/packages/gsutil/boto/tests/unit/ec2/test_connection.py +480 -0
- data/packages/gsutil/boto/tests/unit/ec2/test_instance.py +243 -0
- data/packages/gsutil/boto/tests/unit/ec2/test_networkinterface.py +140 -0
- data/packages/gsutil/boto/tests/unit/ec2/test_volume.py +248 -0
- data/packages/gsutil/boto/tests/unit/emr/test_emr_responses.py +373 -0
- data/packages/gsutil/boto/tests/unit/glacier/__init__.py +0 -0
- data/packages/gsutil/boto/tests/unit/glacier/test_concurrent.py +120 -0
- data/packages/gsutil/boto/tests/unit/glacier/test_job.py +60 -0
- data/packages/gsutil/boto/tests/unit/glacier/test_layer1.py +98 -0
- data/packages/gsutil/boto/tests/unit/glacier/test_layer2.py +266 -0
- data/packages/gsutil/boto/tests/unit/glacier/test_utils.py +116 -0
- data/packages/gsutil/boto/tests/unit/glacier/test_vault.py +100 -0
- data/packages/gsutil/boto/tests/unit/glacier/test_writer.py +185 -0
- data/packages/gsutil/boto/tests/unit/provider/__init__.py +0 -0
- data/packages/gsutil/boto/tests/unit/provider/test_provider.py +176 -0
- data/packages/gsutil/boto/tests/unit/rds/__init__.py +0 -0
- data/packages/gsutil/boto/tests/unit/rds/test_connection.py +131 -0
- data/packages/gsutil/boto/tests/unit/s3/__init__.py +0 -0
- data/packages/gsutil/boto/tests/unit/s3/test_cors_configuration.py +77 -0
- data/packages/gsutil/boto/tests/unit/s3/test_key.py +75 -0
- data/packages/gsutil/boto/tests/unit/s3/test_keyfile.py +101 -0
- data/packages/gsutil/boto/tests/unit/s3/test_lifecycle.py +97 -0
- data/packages/gsutil/boto/tests/unit/s3/test_tagging.py +47 -0
- data/packages/gsutil/boto/tests/unit/s3/test_uri.py +257 -0
- data/packages/gsutil/boto/tests/unit/s3/test_website.py +188 -0
- data/packages/gsutil/boto/tests/unit/sns/__init__.py +0 -0
- data/packages/gsutil/boto/tests/unit/sns/test_connection.py +99 -0
- data/packages/gsutil/boto/tests/unit/sqs/__init__.py +0 -0
- data/packages/gsutil/boto/tests/unit/sqs/test_connection.py +98 -0
- data/packages/gsutil/boto/tests/unit/sqs/test_queue.py +40 -0
- data/packages/gsutil/boto/tests/unit/sts/test_connection.py +74 -0
- data/packages/gsutil/boto/tests/unit/test_connection.py +60 -0
- data/packages/gsutil/boto/tests/unit/utils/test_utils.py +109 -0
- data/packages/gsutil/boto/tox.ini +8 -0
- data/packages/gsutil/gslib/README +5 -0
- data/packages/gsutil/gslib/__init__.py +22 -0
- data/packages/gsutil/gslib/__init__.pyc +0 -0
- data/packages/gsutil/gslib/addlhelp/__init__.py +15 -0
- data/packages/gsutil/gslib/addlhelp/acls.py +234 -0
- data/packages/gsutil/gslib/addlhelp/anon.py +57 -0
- data/packages/gsutil/gslib/addlhelp/command_opts.py +116 -0
- data/packages/gsutil/gslib/addlhelp/dev.py +139 -0
- data/packages/gsutil/gslib/addlhelp/metadata.py +186 -0
- data/packages/gsutil/gslib/addlhelp/naming.py +173 -0
- data/packages/gsutil/gslib/addlhelp/prod.py +160 -0
- data/packages/gsutil/gslib/addlhelp/projects.py +130 -0
- data/packages/gsutil/gslib/addlhelp/subdirs.py +110 -0
- data/packages/gsutil/gslib/addlhelp/support.py +86 -0
- data/packages/gsutil/gslib/addlhelp/versioning.py +242 -0
- data/packages/gsutil/gslib/addlhelp/wildcards.py +170 -0
- data/packages/gsutil/gslib/bucket_listing_ref.py +175 -0
- data/packages/gsutil/gslib/bucket_listing_ref.pyc +0 -0
- data/packages/gsutil/gslib/command.py +722 -0
- data/packages/gsutil/gslib/command.pyc +0 -0
- data/packages/gsutil/gslib/command_runner.py +101 -0
- data/packages/gsutil/gslib/command_runner.pyc +0 -0
- data/packages/gsutil/gslib/commands/__init__.py +15 -0
- data/packages/gsutil/gslib/commands/__init__.pyc +0 -0
- data/packages/gsutil/gslib/commands/cat.py +131 -0
- data/packages/gsutil/gslib/commands/cat.pyc +0 -0
- data/packages/gsutil/gslib/commands/chacl.py +532 -0
- data/packages/gsutil/gslib/commands/chacl.pyc +0 -0
- data/packages/gsutil/gslib/commands/config.py +694 -0
- data/packages/gsutil/gslib/commands/config.pyc +0 -0
- data/packages/gsutil/gslib/commands/cp.py +1818 -0
- data/packages/gsutil/gslib/commands/cp.pyc +0 -0
- data/packages/gsutil/gslib/commands/disablelogging.py +101 -0
- data/packages/gsutil/gslib/commands/disablelogging.pyc +0 -0
- data/packages/gsutil/gslib/commands/enablelogging.py +149 -0
- data/packages/gsutil/gslib/commands/enablelogging.pyc +0 -0
- data/packages/gsutil/gslib/commands/getacl.py +82 -0
- data/packages/gsutil/gslib/commands/getacl.pyc +0 -0
- data/packages/gsutil/gslib/commands/getcors.py +121 -0
- data/packages/gsutil/gslib/commands/getcors.pyc +0 -0
- data/packages/gsutil/gslib/commands/getdefacl.py +86 -0
- data/packages/gsutil/gslib/commands/getdefacl.pyc +0 -0
- data/packages/gsutil/gslib/commands/getlogging.py +137 -0
- data/packages/gsutil/gslib/commands/getlogging.pyc +0 -0
- data/packages/gsutil/gslib/commands/getversioning.py +116 -0
- data/packages/gsutil/gslib/commands/getversioning.pyc +0 -0
- data/packages/gsutil/gslib/commands/getwebcfg.py +122 -0
- data/packages/gsutil/gslib/commands/getwebcfg.pyc +0 -0
- data/packages/gsutil/gslib/commands/help.py +218 -0
- data/packages/gsutil/gslib/commands/help.pyc +0 -0
- data/packages/gsutil/gslib/commands/ls.py +578 -0
- data/packages/gsutil/gslib/commands/ls.pyc +0 -0
- data/packages/gsutil/gslib/commands/mb.py +172 -0
- data/packages/gsutil/gslib/commands/mb.pyc +0 -0
- data/packages/gsutil/gslib/commands/mv.py +159 -0
- data/packages/gsutil/gslib/commands/mv.pyc +0 -0
- data/packages/gsutil/gslib/commands/perfdiag.py +903 -0
- data/packages/gsutil/gslib/commands/perfdiag.pyc +0 -0
- data/packages/gsutil/gslib/commands/rb.py +113 -0
- data/packages/gsutil/gslib/commands/rb.pyc +0 -0
- data/packages/gsutil/gslib/commands/rm.py +239 -0
- data/packages/gsutil/gslib/commands/rm.pyc +0 -0
- data/packages/gsutil/gslib/commands/setacl.py +138 -0
- data/packages/gsutil/gslib/commands/setacl.pyc +0 -0
- data/packages/gsutil/gslib/commands/setcors.py +145 -0
- data/packages/gsutil/gslib/commands/setcors.pyc +0 -0
- data/packages/gsutil/gslib/commands/setdefacl.py +105 -0
- data/packages/gsutil/gslib/commands/setdefacl.pyc +0 -0
- data/packages/gsutil/gslib/commands/setmeta.py +428 -0
- data/packages/gsutil/gslib/commands/setmeta.pyc +0 -0
- data/packages/gsutil/gslib/commands/setversioning.py +114 -0
- data/packages/gsutil/gslib/commands/setversioning.pyc +0 -0
- data/packages/gsutil/gslib/commands/setwebcfg.py +190 -0
- data/packages/gsutil/gslib/commands/setwebcfg.pyc +0 -0
- data/packages/gsutil/gslib/commands/test.py +228 -0
- data/packages/gsutil/gslib/commands/test.pyc +0 -0
- data/packages/gsutil/gslib/commands/update.py +305 -0
- data/packages/gsutil/gslib/commands/update.pyc +0 -0
- data/packages/gsutil/gslib/commands/version.py +150 -0
- data/packages/gsutil/gslib/commands/version.pyc +0 -0
- data/packages/gsutil/gslib/exception.py +76 -0
- data/packages/gsutil/gslib/exception.pyc +0 -0
- data/packages/gsutil/gslib/help_provider.py +81 -0
- data/packages/gsutil/gslib/help_provider.pyc +0 -0
- data/packages/gsutil/gslib/name_expansion.py +550 -0
- data/packages/gsutil/gslib/name_expansion.pyc +0 -0
- data/packages/gsutil/gslib/no_op_auth_plugin.py +30 -0
- data/packages/gsutil/gslib/plurality_checkable_iterator.py +56 -0
- data/packages/gsutil/gslib/plurality_checkable_iterator.pyc +0 -0
- data/packages/gsutil/gslib/project_id.py +67 -0
- data/packages/gsutil/gslib/project_id.pyc +0 -0
- data/packages/gsutil/gslib/storage_uri_builder.py +56 -0
- data/packages/gsutil/gslib/storage_uri_builder.pyc +0 -0
- data/packages/gsutil/gslib/tests/__init__.py +15 -0
- data/packages/gsutil/gslib/tests/__init__.pyc +0 -0
- data/packages/gsutil/gslib/tests/test_chacl.py +236 -0
- data/packages/gsutil/gslib/tests/test_cp.py +267 -0
- data/packages/gsutil/gslib/tests/test_data/test.gif +0 -0
- data/packages/gsutil/gslib/tests/test_data/test.mp3 +0 -0
- data/packages/gsutil/gslib/tests/test_ls.py +66 -0
- data/packages/gsutil/gslib/tests/test_mv.py +69 -0
- data/packages/gsutil/gslib/tests/test_naming.py +989 -0
- data/packages/gsutil/gslib/tests/test_perfdiag.py +41 -0
- data/packages/gsutil/gslib/tests/test_plurality_checkable_iterator.py +67 -0
- data/packages/gsutil/gslib/tests/test_rm.py +143 -0
- data/packages/gsutil/gslib/tests/test_setacl.py +152 -0
- data/packages/gsutil/gslib/tests/test_setcors.py +168 -0
- data/packages/gsutil/gslib/tests/test_setmeta.py +91 -0
- data/packages/gsutil/gslib/tests/test_setversioning.py +44 -0
- data/packages/gsutil/gslib/tests/test_setwebcfg.py +63 -0
- data/packages/gsutil/gslib/tests/test_thread_pool.py +92 -0
- data/packages/gsutil/gslib/tests/test_wildcard_iterator.py +364 -0
- data/packages/gsutil/gslib/tests/testcase/__init__.py +18 -0
- data/packages/gsutil/gslib/tests/testcase/base.py +89 -0
- data/packages/gsutil/gslib/tests/testcase/integration_testcase.py +197 -0
- data/packages/gsutil/gslib/tests/testcase/unit_testcase.py +230 -0
- data/packages/gsutil/gslib/tests/util.py +125 -0
- data/packages/gsutil/gslib/tests/util.pyc +0 -0
- data/packages/gsutil/gslib/thread_pool.py +79 -0
- data/packages/gsutil/gslib/thread_pool.pyc +0 -0
- data/packages/gsutil/gslib/util.py +151 -0
- data/packages/gsutil/gslib/util.pyc +0 -0
- data/packages/gsutil/gslib/wildcard_iterator.py +492 -0
- data/packages/gsutil/gslib/wildcard_iterator.pyc +0 -0
- data/packages/gsutil/gsutil +377 -0
- data/packages/gsutil/gsutil.spec.in +75 -0
- data/packages/gsutil/oauth2_plugin/__init__.py +22 -0
- data/packages/gsutil/oauth2_plugin/__init__.pyc +0 -0
- data/packages/gsutil/oauth2_plugin/oauth2_client.py +642 -0
- data/packages/gsutil/oauth2_plugin/oauth2_client.pyc +0 -0
- data/packages/gsutil/oauth2_plugin/oauth2_client_test.py +374 -0
- data/packages/gsutil/oauth2_plugin/oauth2_helper.py +110 -0
- data/packages/gsutil/oauth2_plugin/oauth2_helper.pyc +0 -0
- data/packages/gsutil/oauth2_plugin/oauth2_plugin.py +24 -0
- data/packages/gsutil/oauth2_plugin/oauth2_plugin.pyc +0 -0
- data/packages/gsutil/pkg_gen.sh +54 -0
- data/packages/gsutil/pkg_util.py +60 -0
- data/packages/gsutil/setup.py +141 -0
- data/packages/gsutil/third_party/__init__.py +0 -0
- data/packages/gsutil/third_party/__init__.pyc +0 -0
- data/packages/gsutil/third_party/fancy_urllib/README +21 -0
- data/packages/gsutil/third_party/fancy_urllib/__init__.py +398 -0
- data/packages/gsutil/third_party/fancy_urllib/__init__.pyc +0 -0
- data/tasks/rubygem.rake +3 -1
- metadata +770 -7
- metadata.gz.sig +0 -0
@@ -0,0 +1,175 @@
|
|
1
|
+
# Copyright (c) 2006-2009 Mitch Garnaat http://garnaat.org/
|
2
|
+
#
|
3
|
+
# Permission is hereby granted, free of charge, to any person obtaining a
|
4
|
+
# copy of this software and associated documentation files (the
|
5
|
+
# "Software"), to deal in the Software without restriction, including
|
6
|
+
# without limitation the rights to use, copy, modify, merge, publish, dis-
|
7
|
+
# tribute, sublicense, and/or sell copies of the Software, and to permit
|
8
|
+
# persons to whom the Software is furnished to do so, subject to the fol-
|
9
|
+
# lowing conditions:
|
10
|
+
#
|
11
|
+
# The above copyright notice and this permission notice shall be included
|
12
|
+
# in all copies or substantial portions of the Software.
|
13
|
+
#
|
14
|
+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
15
|
+
# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
|
16
|
+
# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
|
17
|
+
# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
18
|
+
# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
19
|
+
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
20
|
+
# IN THE SOFTWARE.
|
21
|
+
#
|
22
|
+
|
23
|
+
import boto
|
24
|
+
from boto.sdb.db.property import StringProperty, DateTimeProperty, IntegerProperty
|
25
|
+
from boto.sdb.db.model import Model
|
26
|
+
import datetime, subprocess, StringIO, time
|
27
|
+
|
28
|
+
def check_hour(val):
|
29
|
+
if val == '*':
|
30
|
+
return
|
31
|
+
if int(val) < 0 or int(val) > 23:
|
32
|
+
raise ValueError
|
33
|
+
|
34
|
+
class Task(Model):
|
35
|
+
|
36
|
+
"""
|
37
|
+
A scheduled, repeating task that can be executed by any participating servers.
|
38
|
+
The scheduling is similar to cron jobs. Each task has an hour attribute.
|
39
|
+
The allowable values for hour are [0-23|*].
|
40
|
+
|
41
|
+
To keep the operation reasonably efficient and not cause excessive polling,
|
42
|
+
the minimum granularity of a Task is hourly. Some examples:
|
43
|
+
|
44
|
+
hour='*' - the task would be executed each hour
|
45
|
+
hour='3' - the task would be executed at 3AM GMT each day.
|
46
|
+
|
47
|
+
"""
|
48
|
+
name = StringProperty()
|
49
|
+
hour = StringProperty(required=True, validator=check_hour, default='*')
|
50
|
+
command = StringProperty(required=True)
|
51
|
+
last_executed = DateTimeProperty()
|
52
|
+
last_status = IntegerProperty()
|
53
|
+
last_output = StringProperty()
|
54
|
+
message_id = StringProperty()
|
55
|
+
|
56
|
+
@classmethod
|
57
|
+
def start_all(cls, queue_name):
|
58
|
+
for task in cls.all():
|
59
|
+
task.start(queue_name)
|
60
|
+
|
61
|
+
def __init__(self, id=None, **kw):
|
62
|
+
Model.__init__(self, id, **kw)
|
63
|
+
self.hourly = self.hour == '*'
|
64
|
+
self.daily = self.hour != '*'
|
65
|
+
self.now = datetime.datetime.utcnow()
|
66
|
+
|
67
|
+
def check(self):
|
68
|
+
"""
|
69
|
+
Determine how long until the next scheduled time for a Task.
|
70
|
+
Returns the number of seconds until the next scheduled time or zero
|
71
|
+
if the task needs to be run immediately.
|
72
|
+
If it's an hourly task and it's never been run, run it now.
|
73
|
+
If it's a daily task and it's never been run and the hour is right, run it now.
|
74
|
+
"""
|
75
|
+
boto.log.info('checking Task[%s]-now=%s, last=%s' % (self.name, self.now, self.last_executed))
|
76
|
+
|
77
|
+
if self.hourly and not self.last_executed:
|
78
|
+
return 0
|
79
|
+
|
80
|
+
if self.daily and not self.last_executed:
|
81
|
+
if int(self.hour) == self.now.hour:
|
82
|
+
return 0
|
83
|
+
else:
|
84
|
+
return max( (int(self.hour)-self.now.hour), (self.now.hour-int(self.hour)) )*60*60
|
85
|
+
|
86
|
+
delta = self.now - self.last_executed
|
87
|
+
if self.hourly:
|
88
|
+
if delta.seconds >= 60*60:
|
89
|
+
return 0
|
90
|
+
else:
|
91
|
+
return 60*60 - delta.seconds
|
92
|
+
else:
|
93
|
+
if int(self.hour) == self.now.hour:
|
94
|
+
if delta.days >= 1:
|
95
|
+
return 0
|
96
|
+
else:
|
97
|
+
return 82800 # 23 hours, just to be safe
|
98
|
+
else:
|
99
|
+
return max( (int(self.hour)-self.now.hour), (self.now.hour-int(self.hour)) )*60*60
|
100
|
+
|
101
|
+
def _run(self, msg, vtimeout):
|
102
|
+
boto.log.info('Task[%s] - running:%s' % (self.name, self.command))
|
103
|
+
log_fp = StringIO.StringIO()
|
104
|
+
process = subprocess.Popen(self.command, shell=True, stdin=subprocess.PIPE,
|
105
|
+
stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
106
|
+
nsecs = 5
|
107
|
+
current_timeout = vtimeout
|
108
|
+
while process.poll() == None:
|
109
|
+
boto.log.info('nsecs=%s, timeout=%s' % (nsecs, current_timeout))
|
110
|
+
if nsecs >= current_timeout:
|
111
|
+
current_timeout += vtimeout
|
112
|
+
boto.log.info('Task[%s] - setting timeout to %d seconds' % (self.name, current_timeout))
|
113
|
+
if msg:
|
114
|
+
msg.change_visibility(current_timeout)
|
115
|
+
time.sleep(5)
|
116
|
+
nsecs += 5
|
117
|
+
t = process.communicate()
|
118
|
+
log_fp.write(t[0])
|
119
|
+
log_fp.write(t[1])
|
120
|
+
boto.log.info('Task[%s] - output: %s' % (self.name, log_fp.getvalue()))
|
121
|
+
self.last_executed = self.now
|
122
|
+
self.last_status = process.returncode
|
123
|
+
self.last_output = log_fp.getvalue()[0:1023]
|
124
|
+
|
125
|
+
def run(self, msg, vtimeout=60):
|
126
|
+
delay = self.check()
|
127
|
+
boto.log.info('Task[%s] - delay=%s seconds' % (self.name, delay))
|
128
|
+
if delay == 0:
|
129
|
+
self._run(msg, vtimeout)
|
130
|
+
queue = msg.queue
|
131
|
+
new_msg = queue.new_message(self.id)
|
132
|
+
new_msg = queue.write(new_msg)
|
133
|
+
self.message_id = new_msg.id
|
134
|
+
self.put()
|
135
|
+
boto.log.info('Task[%s] - new message id=%s' % (self.name, new_msg.id))
|
136
|
+
msg.delete()
|
137
|
+
boto.log.info('Task[%s] - deleted message %s' % (self.name, msg.id))
|
138
|
+
else:
|
139
|
+
boto.log.info('new_vtimeout: %d' % delay)
|
140
|
+
msg.change_visibility(delay)
|
141
|
+
|
142
|
+
def start(self, queue_name):
|
143
|
+
boto.log.info('Task[%s] - starting with queue: %s' % (self.name, queue_name))
|
144
|
+
queue = boto.lookup('sqs', queue_name)
|
145
|
+
msg = queue.new_message(self.id)
|
146
|
+
msg = queue.write(msg)
|
147
|
+
self.message_id = msg.id
|
148
|
+
self.put()
|
149
|
+
boto.log.info('Task[%s] - start successful' % self.name)
|
150
|
+
|
151
|
+
class TaskPoller(object):
|
152
|
+
|
153
|
+
def __init__(self, queue_name):
|
154
|
+
self.sqs = boto.connect_sqs()
|
155
|
+
self.queue = self.sqs.lookup(queue_name)
|
156
|
+
|
157
|
+
def poll(self, wait=60, vtimeout=60):
|
158
|
+
while True:
|
159
|
+
m = self.queue.read(vtimeout)
|
160
|
+
if m:
|
161
|
+
task = Task.get_by_id(m.get_body())
|
162
|
+
if task:
|
163
|
+
if not task.message_id or m.id == task.message_id:
|
164
|
+
boto.log.info('Task[%s] - read message %s' % (task.name, m.id))
|
165
|
+
task.run(m, vtimeout)
|
166
|
+
else:
|
167
|
+
boto.log.info('Task[%s] - found extraneous message, ignoring' % task.name)
|
168
|
+
else:
|
169
|
+
time.sleep(wait)
|
170
|
+
|
171
|
+
|
172
|
+
|
173
|
+
|
174
|
+
|
175
|
+
|
@@ -0,0 +1,34 @@
|
|
1
|
+
from boto.manage.server import Server
|
2
|
+
from boto.manage.volume import Volume
|
3
|
+
import time
|
4
|
+
|
5
|
+
print '--> Creating New Volume'
|
6
|
+
volume = Volume.create()
|
7
|
+
print volume
|
8
|
+
|
9
|
+
print '--> Creating New Server'
|
10
|
+
server_list = Server.create()
|
11
|
+
server = server_list[0]
|
12
|
+
print server
|
13
|
+
|
14
|
+
print '----> Waiting for Server to start up'
|
15
|
+
while server.status != 'running':
|
16
|
+
print '*'
|
17
|
+
time.sleep(10)
|
18
|
+
print '----> Server is running'
|
19
|
+
|
20
|
+
print '--> Run "df -k" on Server'
|
21
|
+
status = server.run('df -k')
|
22
|
+
print status[1]
|
23
|
+
|
24
|
+
print '--> Now run volume.make_ready to make the volume ready to use on server'
|
25
|
+
volume.make_ready(server)
|
26
|
+
|
27
|
+
print '--> Run "df -k" on Server'
|
28
|
+
status = server.run('df -k')
|
29
|
+
print status[1]
|
30
|
+
|
31
|
+
print '--> Do an "ls -al" on the new filesystem'
|
32
|
+
status = server.run('ls -al %s' % volume.mount_point)
|
33
|
+
print status[1]
|
34
|
+
|
@@ -0,0 +1,420 @@
|
|
1
|
+
# Copyright (c) 2006-2009 Mitch Garnaat http://garnaat.org/
|
2
|
+
#
|
3
|
+
# Permission is hereby granted, free of charge, to any person obtaining a
|
4
|
+
# copy of this software and associated documentation files (the
|
5
|
+
# "Software"), to deal in the Software without restriction, including
|
6
|
+
# without limitation the rights to use, copy, modify, merge, publish, dis-
|
7
|
+
# tribute, sublicense, and/or sell copies of the Software, and to permit
|
8
|
+
# persons to whom the Software is furnished to do so, subject to the fol-
|
9
|
+
# lowing conditions:
|
10
|
+
#
|
11
|
+
# The above copyright notice and this permission notice shall be included
|
12
|
+
# in all copies or substantial portions of the Software.
|
13
|
+
#
|
14
|
+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
15
|
+
# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
|
16
|
+
# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
|
17
|
+
# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
18
|
+
# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
19
|
+
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
20
|
+
# IN THE SOFTWARE.
|
21
|
+
|
22
|
+
from __future__ import with_statement
|
23
|
+
from boto.sdb.db.model import Model
|
24
|
+
from boto.sdb.db.property import StringProperty, IntegerProperty, ListProperty, ReferenceProperty, CalculatedProperty
|
25
|
+
from boto.manage.server import Server
|
26
|
+
from boto.manage import propget
|
27
|
+
import boto.utils
|
28
|
+
import boto.ec2
|
29
|
+
import time
|
30
|
+
import traceback
|
31
|
+
from contextlib import closing
|
32
|
+
import datetime
|
33
|
+
|
34
|
+
|
35
|
+
class CommandLineGetter(object):
|
36
|
+
|
37
|
+
def get_region(self, params):
|
38
|
+
if not params.get('region', None):
|
39
|
+
prop = self.cls.find_property('region_name')
|
40
|
+
params['region'] = propget.get(prop, choices=boto.ec2.regions)
|
41
|
+
|
42
|
+
def get_zone(self, params):
|
43
|
+
if not params.get('zone', None):
|
44
|
+
prop = StringProperty(name='zone', verbose_name='EC2 Availability Zone',
|
45
|
+
choices=self.ec2.get_all_zones)
|
46
|
+
params['zone'] = propget.get(prop)
|
47
|
+
|
48
|
+
def get_name(self, params):
|
49
|
+
if not params.get('name', None):
|
50
|
+
prop = self.cls.find_property('name')
|
51
|
+
params['name'] = propget.get(prop)
|
52
|
+
|
53
|
+
def get_size(self, params):
|
54
|
+
if not params.get('size', None):
|
55
|
+
prop = IntegerProperty(name='size', verbose_name='Size (GB)')
|
56
|
+
params['size'] = propget.get(prop)
|
57
|
+
|
58
|
+
def get_mount_point(self, params):
|
59
|
+
if not params.get('mount_point', None):
|
60
|
+
prop = self.cls.find_property('mount_point')
|
61
|
+
params['mount_point'] = propget.get(prop)
|
62
|
+
|
63
|
+
def get_device(self, params):
|
64
|
+
if not params.get('device', None):
|
65
|
+
prop = self.cls.find_property('device')
|
66
|
+
params['device'] = propget.get(prop)
|
67
|
+
|
68
|
+
def get(self, cls, params):
|
69
|
+
self.cls = cls
|
70
|
+
self.get_region(params)
|
71
|
+
self.ec2 = params['region'].connect()
|
72
|
+
self.get_zone(params)
|
73
|
+
self.get_name(params)
|
74
|
+
self.get_size(params)
|
75
|
+
self.get_mount_point(params)
|
76
|
+
self.get_device(params)
|
77
|
+
|
78
|
+
class Volume(Model):
|
79
|
+
|
80
|
+
name = StringProperty(required=True, unique=True, verbose_name='Name')
|
81
|
+
region_name = StringProperty(required=True, verbose_name='EC2 Region')
|
82
|
+
zone_name = StringProperty(required=True, verbose_name='EC2 Zone')
|
83
|
+
mount_point = StringProperty(verbose_name='Mount Point')
|
84
|
+
device = StringProperty(verbose_name="Device Name", default='/dev/sdp')
|
85
|
+
volume_id = StringProperty(required=True)
|
86
|
+
past_volume_ids = ListProperty(item_type=str)
|
87
|
+
server = ReferenceProperty(Server, collection_name='volumes',
|
88
|
+
verbose_name='Server Attached To')
|
89
|
+
volume_state = CalculatedProperty(verbose_name="Volume State",
|
90
|
+
calculated_type=str, use_method=True)
|
91
|
+
attachment_state = CalculatedProperty(verbose_name="Attachment State",
|
92
|
+
calculated_type=str, use_method=True)
|
93
|
+
size = CalculatedProperty(verbose_name="Size (GB)",
|
94
|
+
calculated_type=int, use_method=True)
|
95
|
+
|
96
|
+
@classmethod
|
97
|
+
def create(cls, **params):
|
98
|
+
getter = CommandLineGetter()
|
99
|
+
getter.get(cls, params)
|
100
|
+
region = params.get('region')
|
101
|
+
ec2 = region.connect()
|
102
|
+
zone = params.get('zone')
|
103
|
+
size = params.get('size')
|
104
|
+
ebs_volume = ec2.create_volume(size, zone.name)
|
105
|
+
v = cls()
|
106
|
+
v.ec2 = ec2
|
107
|
+
v.volume_id = ebs_volume.id
|
108
|
+
v.name = params.get('name')
|
109
|
+
v.mount_point = params.get('mount_point')
|
110
|
+
v.device = params.get('device')
|
111
|
+
v.region_name = region.name
|
112
|
+
v.zone_name = zone.name
|
113
|
+
v.put()
|
114
|
+
return v
|
115
|
+
|
116
|
+
@classmethod
|
117
|
+
def create_from_volume_id(cls, region_name, volume_id, name):
|
118
|
+
vol = None
|
119
|
+
ec2 = boto.ec2.connect_to_region(region_name)
|
120
|
+
rs = ec2.get_all_volumes([volume_id])
|
121
|
+
if len(rs) == 1:
|
122
|
+
v = rs[0]
|
123
|
+
vol = cls()
|
124
|
+
vol.volume_id = v.id
|
125
|
+
vol.name = name
|
126
|
+
vol.region_name = v.region.name
|
127
|
+
vol.zone_name = v.zone
|
128
|
+
vol.put()
|
129
|
+
return vol
|
130
|
+
|
131
|
+
def create_from_latest_snapshot(self, name, size=None):
|
132
|
+
snapshot = self.get_snapshots()[-1]
|
133
|
+
return self.create_from_snapshot(name, snapshot, size)
|
134
|
+
|
135
|
+
def create_from_snapshot(self, name, snapshot, size=None):
|
136
|
+
if size < self.size:
|
137
|
+
size = self.size
|
138
|
+
ec2 = self.get_ec2_connection()
|
139
|
+
if self.zone_name == None or self.zone_name == '':
|
140
|
+
# deal with the migration case where the zone is not set in the logical volume:
|
141
|
+
current_volume = ec2.get_all_volumes([self.volume_id])[0]
|
142
|
+
self.zone_name = current_volume.zone
|
143
|
+
ebs_volume = ec2.create_volume(size, self.zone_name, snapshot)
|
144
|
+
v = Volume()
|
145
|
+
v.ec2 = self.ec2
|
146
|
+
v.volume_id = ebs_volume.id
|
147
|
+
v.name = name
|
148
|
+
v.mount_point = self.mount_point
|
149
|
+
v.device = self.device
|
150
|
+
v.region_name = self.region_name
|
151
|
+
v.zone_name = self.zone_name
|
152
|
+
v.put()
|
153
|
+
return v
|
154
|
+
|
155
|
+
def get_ec2_connection(self):
|
156
|
+
if self.server:
|
157
|
+
return self.server.ec2
|
158
|
+
if not hasattr(self, 'ec2') or self.ec2 == None:
|
159
|
+
self.ec2 = boto.ec2.connect_to_region(self.region_name)
|
160
|
+
return self.ec2
|
161
|
+
|
162
|
+
def _volume_state(self):
|
163
|
+
ec2 = self.get_ec2_connection()
|
164
|
+
rs = ec2.get_all_volumes([self.volume_id])
|
165
|
+
return rs[0].volume_state()
|
166
|
+
|
167
|
+
def _attachment_state(self):
|
168
|
+
ec2 = self.get_ec2_connection()
|
169
|
+
rs = ec2.get_all_volumes([self.volume_id])
|
170
|
+
return rs[0].attachment_state()
|
171
|
+
|
172
|
+
def _size(self):
|
173
|
+
if not hasattr(self, '__size'):
|
174
|
+
ec2 = self.get_ec2_connection()
|
175
|
+
rs = ec2.get_all_volumes([self.volume_id])
|
176
|
+
self.__size = rs[0].size
|
177
|
+
return self.__size
|
178
|
+
|
179
|
+
def install_xfs(self):
|
180
|
+
if self.server:
|
181
|
+
self.server.install('xfsprogs xfsdump')
|
182
|
+
|
183
|
+
def get_snapshots(self):
|
184
|
+
"""
|
185
|
+
Returns a list of all completed snapshots for this volume ID.
|
186
|
+
"""
|
187
|
+
ec2 = self.get_ec2_connection()
|
188
|
+
rs = ec2.get_all_snapshots()
|
189
|
+
all_vols = [self.volume_id] + self.past_volume_ids
|
190
|
+
snaps = []
|
191
|
+
for snapshot in rs:
|
192
|
+
if snapshot.volume_id in all_vols:
|
193
|
+
if snapshot.progress == '100%':
|
194
|
+
snapshot.date = boto.utils.parse_ts(snapshot.start_time)
|
195
|
+
snapshot.keep = True
|
196
|
+
snaps.append(snapshot)
|
197
|
+
snaps.sort(cmp=lambda x, y: cmp(x.date, y.date))
|
198
|
+
return snaps
|
199
|
+
|
200
|
+
def attach(self, server=None):
|
201
|
+
if self.attachment_state == 'attached':
|
202
|
+
print 'already attached'
|
203
|
+
return None
|
204
|
+
if server:
|
205
|
+
self.server = server
|
206
|
+
self.put()
|
207
|
+
ec2 = self.get_ec2_connection()
|
208
|
+
ec2.attach_volume(self.volume_id, self.server.instance_id, self.device)
|
209
|
+
|
210
|
+
def detach(self, force=False):
|
211
|
+
state = self.attachment_state
|
212
|
+
if state == 'available' or state == None or state == 'detaching':
|
213
|
+
print 'already detached'
|
214
|
+
return None
|
215
|
+
ec2 = self.get_ec2_connection()
|
216
|
+
ec2.detach_volume(self.volume_id, self.server.instance_id, self.device, force)
|
217
|
+
self.server = None
|
218
|
+
self.put()
|
219
|
+
|
220
|
+
def checkfs(self, use_cmd=None):
|
221
|
+
if self.server == None:
|
222
|
+
raise ValueError('server attribute must be set to run this command')
|
223
|
+
# detemine state of file system on volume, only works if attached
|
224
|
+
if use_cmd:
|
225
|
+
cmd = use_cmd
|
226
|
+
else:
|
227
|
+
cmd = self.server.get_cmdshell()
|
228
|
+
status = cmd.run('xfs_check %s' % self.device)
|
229
|
+
if not use_cmd:
|
230
|
+
cmd.close()
|
231
|
+
if status[1].startswith('bad superblock magic number 0'):
|
232
|
+
return False
|
233
|
+
return True
|
234
|
+
|
235
|
+
def wait(self):
|
236
|
+
if self.server == None:
|
237
|
+
raise ValueError('server attribute must be set to run this command')
|
238
|
+
with closing(self.server.get_cmdshell()) as cmd:
|
239
|
+
# wait for the volume device to appear
|
240
|
+
cmd = self.server.get_cmdshell()
|
241
|
+
while not cmd.exists(self.device):
|
242
|
+
boto.log.info('%s still does not exist, waiting 10 seconds' % self.device)
|
243
|
+
time.sleep(10)
|
244
|
+
|
245
|
+
def format(self):
|
246
|
+
if self.server == None:
|
247
|
+
raise ValueError('server attribute must be set to run this command')
|
248
|
+
status = None
|
249
|
+
with closing(self.server.get_cmdshell()) as cmd:
|
250
|
+
if not self.checkfs(cmd):
|
251
|
+
boto.log.info('make_fs...')
|
252
|
+
status = cmd.run('mkfs -t xfs %s' % self.device)
|
253
|
+
return status
|
254
|
+
|
255
|
+
def mount(self):
|
256
|
+
if self.server == None:
|
257
|
+
raise ValueError('server attribute must be set to run this command')
|
258
|
+
boto.log.info('handle_mount_point')
|
259
|
+
with closing(self.server.get_cmdshell()) as cmd:
|
260
|
+
cmd = self.server.get_cmdshell()
|
261
|
+
if not cmd.isdir(self.mount_point):
|
262
|
+
boto.log.info('making directory')
|
263
|
+
# mount directory doesn't exist so create it
|
264
|
+
cmd.run("mkdir %s" % self.mount_point)
|
265
|
+
else:
|
266
|
+
boto.log.info('directory exists already')
|
267
|
+
status = cmd.run('mount -l')
|
268
|
+
lines = status[1].split('\n')
|
269
|
+
for line in lines:
|
270
|
+
t = line.split()
|
271
|
+
if t and t[2] == self.mount_point:
|
272
|
+
# something is already mounted at the mount point
|
273
|
+
# unmount that and mount it as /tmp
|
274
|
+
if t[0] != self.device:
|
275
|
+
cmd.run('umount %s' % self.mount_point)
|
276
|
+
cmd.run('mount %s /tmp' % t[0])
|
277
|
+
cmd.run('chmod 777 /tmp')
|
278
|
+
break
|
279
|
+
# Mount up our new EBS volume onto mount_point
|
280
|
+
cmd.run("mount %s %s" % (self.device, self.mount_point))
|
281
|
+
cmd.run('xfs_growfs %s' % self.mount_point)
|
282
|
+
|
283
|
+
def make_ready(self, server):
|
284
|
+
self.server = server
|
285
|
+
self.put()
|
286
|
+
self.install_xfs()
|
287
|
+
self.attach()
|
288
|
+
self.wait()
|
289
|
+
self.format()
|
290
|
+
self.mount()
|
291
|
+
|
292
|
+
def freeze(self):
|
293
|
+
if self.server:
|
294
|
+
return self.server.run("/usr/sbin/xfs_freeze -f %s" % self.mount_point)
|
295
|
+
|
296
|
+
def unfreeze(self):
|
297
|
+
if self.server:
|
298
|
+
return self.server.run("/usr/sbin/xfs_freeze -u %s" % self.mount_point)
|
299
|
+
|
300
|
+
def snapshot(self):
|
301
|
+
# if this volume is attached to a server
|
302
|
+
# we need to freeze the XFS file system
|
303
|
+
try:
|
304
|
+
self.freeze()
|
305
|
+
if self.server == None:
|
306
|
+
snapshot = self.get_ec2_connection().create_snapshot(self.volume_id)
|
307
|
+
else:
|
308
|
+
snapshot = self.server.ec2.create_snapshot(self.volume_id)
|
309
|
+
boto.log.info('Snapshot of Volume %s created: %s' % (self.name, snapshot))
|
310
|
+
except Exception:
|
311
|
+
boto.log.info('Snapshot error')
|
312
|
+
boto.log.info(traceback.format_exc())
|
313
|
+
finally:
|
314
|
+
status = self.unfreeze()
|
315
|
+
return status
|
316
|
+
|
317
|
+
def get_snapshot_range(self, snaps, start_date=None, end_date=None):
|
318
|
+
l = []
|
319
|
+
for snap in snaps:
|
320
|
+
if start_date and end_date:
|
321
|
+
if snap.date >= start_date and snap.date <= end_date:
|
322
|
+
l.append(snap)
|
323
|
+
elif start_date:
|
324
|
+
if snap.date >= start_date:
|
325
|
+
l.append(snap)
|
326
|
+
elif end_date:
|
327
|
+
if snap.date <= end_date:
|
328
|
+
l.append(snap)
|
329
|
+
else:
|
330
|
+
l.append(snap)
|
331
|
+
return l
|
332
|
+
|
333
|
+
def trim_snapshots(self, delete=False):
|
334
|
+
"""
|
335
|
+
Trim the number of snapshots for this volume. This method always
|
336
|
+
keeps the oldest snapshot. It then uses the parameters passed in
|
337
|
+
to determine how many others should be kept.
|
338
|
+
|
339
|
+
The algorithm is to keep all snapshots from the current day. Then
|
340
|
+
it will keep the first snapshot of the day for the previous seven days.
|
341
|
+
Then, it will keep the first snapshot of the week for the previous
|
342
|
+
four weeks. After than, it will keep the first snapshot of the month
|
343
|
+
for as many months as there are.
|
344
|
+
|
345
|
+
"""
|
346
|
+
snaps = self.get_snapshots()
|
347
|
+
# Always keep the oldest and the newest
|
348
|
+
if len(snaps) <= 2:
|
349
|
+
return snaps
|
350
|
+
snaps = snaps[1:-1]
|
351
|
+
now = datetime.datetime.now(snaps[0].date.tzinfo)
|
352
|
+
midnight = datetime.datetime(year=now.year, month=now.month,
|
353
|
+
day=now.day, tzinfo=now.tzinfo)
|
354
|
+
# Keep the first snapshot from each day of the previous week
|
355
|
+
one_week = datetime.timedelta(days=7, seconds=60*60)
|
356
|
+
print midnight-one_week, midnight
|
357
|
+
previous_week = self.get_snapshot_range(snaps, midnight-one_week, midnight)
|
358
|
+
print previous_week
|
359
|
+
if not previous_week:
|
360
|
+
return snaps
|
361
|
+
current_day = None
|
362
|
+
for snap in previous_week:
|
363
|
+
if current_day and current_day == snap.date.day:
|
364
|
+
snap.keep = False
|
365
|
+
else:
|
366
|
+
current_day = snap.date.day
|
367
|
+
# Get ourselves onto the next full week boundary
|
368
|
+
if previous_week:
|
369
|
+
week_boundary = previous_week[0].date
|
370
|
+
if week_boundary.weekday() != 0:
|
371
|
+
delta = datetime.timedelta(days=week_boundary.weekday())
|
372
|
+
week_boundary = week_boundary - delta
|
373
|
+
# Keep one within this partial week
|
374
|
+
partial_week = self.get_snapshot_range(snaps, week_boundary, previous_week[0].date)
|
375
|
+
if len(partial_week) > 1:
|
376
|
+
for snap in partial_week[1:]:
|
377
|
+
snap.keep = False
|
378
|
+
# Keep the first snapshot of each week for the previous 4 weeks
|
379
|
+
for i in range(0, 4):
|
380
|
+
weeks_worth = self.get_snapshot_range(snaps, week_boundary-one_week, week_boundary)
|
381
|
+
if len(weeks_worth) > 1:
|
382
|
+
for snap in weeks_worth[1:]:
|
383
|
+
snap.keep = False
|
384
|
+
week_boundary = week_boundary - one_week
|
385
|
+
# Now look through all remaining snaps and keep one per month
|
386
|
+
remainder = self.get_snapshot_range(snaps, end_date=week_boundary)
|
387
|
+
current_month = None
|
388
|
+
for snap in remainder:
|
389
|
+
if current_month and current_month == snap.date.month:
|
390
|
+
snap.keep = False
|
391
|
+
else:
|
392
|
+
current_month = snap.date.month
|
393
|
+
if delete:
|
394
|
+
for snap in snaps:
|
395
|
+
if not snap.keep:
|
396
|
+
boto.log.info('Deleting %s(%s) for %s' % (snap, snap.date, self.name))
|
397
|
+
snap.delete()
|
398
|
+
return snaps
|
399
|
+
|
400
|
+
def grow(self, size):
|
401
|
+
pass
|
402
|
+
|
403
|
+
def copy(self, snapshot):
|
404
|
+
pass
|
405
|
+
|
406
|
+
def get_snapshot_from_date(self, date):
|
407
|
+
pass
|
408
|
+
|
409
|
+
def delete(self, delete_ebs_volume=False):
|
410
|
+
if delete_ebs_volume:
|
411
|
+
self.detach()
|
412
|
+
ec2 = self.get_ec2_connection()
|
413
|
+
ec2.delete_volume(self.volume_id)
|
414
|
+
Model.delete(self)
|
415
|
+
|
416
|
+
def archive(self):
|
417
|
+
# snapshot volume, trim snaps, delete volume-id
|
418
|
+
pass
|
419
|
+
|
420
|
+
|