Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(50)

Unified Diff: third_party/gsutil/gslib/commands/mb.py

Issue 12317103: Added gsutil to depot tools (Closed) Base URL: https://chromium.googlesource.com/chromium/tools/depot_tools.git@master
Patch Set: Created 7 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « third_party/gsutil/gslib/commands/ls.py ('k') | third_party/gsutil/gslib/commands/mv.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: third_party/gsutil/gslib/commands/mb.py
diff --git a/third_party/gsutil/gslib/commands/mb.py b/third_party/gsutil/gslib/commands/mb.py
new file mode 100644
index 0000000000000000000000000000000000000000..6ed50383dcbadc714ac0126a4a5d480627434904
--- /dev/null
+++ b/third_party/gsutil/gslib/commands/mb.py
@@ -0,0 +1,172 @@
+# Copyright 2011 Google Inc. All Rights Reserved.
+#
+# Licensed 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.
+
+from gslib.command import Command
+from gslib.command import COMMAND_NAME
+from gslib.command import COMMAND_NAME_ALIASES
+from gslib.command import CONFIG_REQUIRED
+from gslib.command import FILE_URIS_OK
+from gslib.command import MAX_ARGS
+from gslib.command import MIN_ARGS
+from gslib.command import PROVIDER_URIS_OK
+from gslib.command import SUPPORTED_SUB_ARGS
+from gslib.command import URIS_START_ARG
+from gslib.exception import CommandException
+from gslib.help_provider import HELP_NAME
+from gslib.help_provider import HELP_NAME_ALIASES
+from gslib.help_provider import HELP_ONE_LINE_SUMMARY
+from gslib.help_provider import HELP_TEXT
+from gslib.help_provider import HelpType
+from gslib.help_provider import HELP_TYPE
+from gslib.util import NO_MAX
+
+_detailed_help_text = ("""
+<B>SYNOPSIS</B>
+ gsutil mb [-c storage_class] [-l location] [-p proj_id] uri...
+
+
+<B>DESCRIPTION</B>
+ The mb command creates a new bucket. Google Cloud Storage has a single
+ namespace, so you will not be allowed to create a bucket with a name already
+ in use by another user. You can, however, carve out parts of the bucket name
+ space corresponding to your company's domain name (see "gsutil help naming").
+
+ If you don't specify a project ID using the -p option, the bucket
+ will be created using the default project ID specified in your gsutil
+ configuration file (see "gsutil help config"). For more details about
+ projects see "gsutil help projects".
+
+ The -c and -l options specify the storage class and location, respectively,
+ for the bucket. Once a bucket is created in a given location and with a
+ given storage class, it cannot be moved to a different location, and the
+ storage class cannot be changed. Instead, you would need to create a new
+ bucket and move the data over and then delete the original bucket.
+
+
+<B>BUCKET STORAGE CLASSES</B>
+ If you don't specify a -c option, the bucket will be created with the default
+ (standard) storage class.
+
+ If you specify -c DURABLE_REDUCED_AVAILABILITY (or -c DRA), it causes the data
+ stored in the bucket to use durable reduced availability storage. Buckets
+ created with this storage class have lower availability than standard storage
+ class buckets, but durability equal to that of buckets created with standard
+ storage class. This option allows users to reduce costs for data for which
+ lower availability is acceptable. Durable Reduced Availability storage would
+ not be appropriate for "hot" objects (i.e., objects being accessed frequently)
+ or for interactive workloads; however, it might be appropriate for other types
+ of applications. See the online documentation for pricing and SLA details.
+
+
+<B>BUCKET LOCATIONS</B>
+ If you don't specify a -l option, the bucket will be created in the default
+ location (US). Otherwise, you can specify one of the available locations:
+ US (United States) or EU (Europe).
+
+
+<B>OPTIONS</B>
+ -c storage_class Can be DRA (or DURABLE_REDUCED_AVAILABILITY) or S (or
+ STANDARD). Default is STANDARD.
+
+ -l location Can be US or EU. Default is US. Locations are case
+ insensitive.
+
+ -p proj_id Specifies the project ID under which to create the bucket.
+""")
+
+
+class MbCommand(Command):
+ """Implementation of gsutil mb command."""
+
+ # Command specification (processed by parent class).
+ command_spec = {
+ # Name of command.
+ COMMAND_NAME : 'mb',
+ # List of command name aliases.
+ COMMAND_NAME_ALIASES : ['makebucket', 'createbucket', 'md', 'mkdir'],
+ # Min number of args required by this command.
+ MIN_ARGS : 1,
+ # Max number of args required by this command, or NO_MAX.
+ MAX_ARGS : NO_MAX,
+ # Getopt-style string specifying acceptable sub args.
+ SUPPORTED_SUB_ARGS : 'c:l:p:',
+ # True if file URIs acceptable for this command.
+ FILE_URIS_OK : False,
+ # True if provider-only URIs acceptable for this command.
+ PROVIDER_URIS_OK : False,
+ # Index in args of first URI arg.
+ URIS_START_ARG : 0,
+ # True if must configure gsutil before running command.
+ CONFIG_REQUIRED : True,
+ }
+ help_spec = {
+ # Name of command or auxiliary help info for which this help applies.
+ HELP_NAME : 'mb',
+ # List of help name aliases.
+ HELP_NAME_ALIASES : ['createbucket', 'makebucket', 'md', 'mkdir',
+ 'location', 'dra', 'dras', 'reduced_availability',
+ 'durable_reduced_availability',
+ 'rr', 'reduced_redundancy',
+ 'standard', 'storage class' ],
+ # Type of help:
+ HELP_TYPE : HelpType.COMMAND_HELP,
+ # One line summary of this help.
+ HELP_ONE_LINE_SUMMARY : 'Make buckets',
+ # The full help text.
+ HELP_TEXT : _detailed_help_text,
+ }
+
+ # Command entry point.
+ def RunCommand(self):
+ location = ''
+ storage_class = ''
+ if self.sub_opts:
+ for o, a in self.sub_opts:
+ if o == '-l':
+ location = a
+ elif o == '-p':
+ self.proj_id_handler.SetProjectId(a)
+ elif o == '-c':
+ storage_class = self._Normalize_Storage_Class(a)
+
+ if not self.headers:
+ headers = {}
+ else:
+ headers = self.headers.copy()
+
+ for bucket_uri_str in self.args:
+ bucket_uri = self.suri_builder.StorageUri(bucket_uri_str)
+ if not bucket_uri.names_bucket():
+ raise CommandException('The mb command requires a URI that specifies a '
+ 'bucket.\n"%s" is not valid.' % bucket_uri)
+ self.proj_id_handler.FillInProjectHeaderIfNeeded('mb', bucket_uri,
+ headers)
+ print 'Creating %s...' % bucket_uri
+ # Pass storage_class param only if this is a GCS bucket. (In S3 the
+ # storage class is specified on the key object.)
+ if bucket_uri.scheme == 'gs':
+ bucket_uri.create_bucket(headers=headers, location=location,
+ storage_class=storage_class)
+ else:
+ bucket_uri.create_bucket(headers=headers, location=location)
+
+ return 0
+
+ def _Normalize_Storage_Class(self, sc):
+ sc = sc.upper()
+ if sc in ('DRA', 'DURABLE_REDUCED_AVAILABILITY'):
+ return 'DURABLE_REDUCED_AVAILABILITY'
+ if sc in ('S', 'STD', 'STANDARD'):
+ return 'STANDARD'
+ return sc
« no previous file with comments | « third_party/gsutil/gslib/commands/ls.py ('k') | third_party/gsutil/gslib/commands/mv.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698