blob: 6ed50383dcbadc714ac0126a4a5d480627434904 [file] [log] [blame]
# 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