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

Unified Diff: gslib/commands/stat.py

Issue 698893003: Update checked in version of gsutil to version 4.6 (Closed) Base URL: http://dart.googlecode.com/svn/third_party/gsutil/
Patch Set: Created 6 years, 1 month 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 | « gslib/commands/signurl.py ('k') | gslib/commands/test.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: gslib/commands/stat.py
===================================================================
--- gslib/commands/stat.py (revision 33376)
+++ gslib/commands/stat.py (working copy)
@@ -1,3 +1,4 @@
+# -*- coding: utf-8 -*-
# Copyright 2013 Google Inc. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
@@ -11,50 +12,41 @@
# 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.
+"""Implementation of Unix-like stat command for cloud storage providers."""
from __future__ import absolute_import
-import binascii
+
import logging
-import re
-import sys
+from gslib.bucket_listing_ref import BucketListingObject
+from gslib.cloud_api import AccessDeniedException
+from gslib.cloud_api import NotFoundException
from gslib.command import Command
-from gslib.command import COMMAND_NAME
-from gslib.command import COMMAND_NAME_ALIASES
-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.cs_api_map import ApiSelector
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 PrintFullInfoAboutUri
+from gslib.exception import InvalidUrlError
+from gslib.storage_url import ContainsWildcard
+from gslib.storage_url import StorageUrlFromString
from gslib.util import NO_MAX
-from boto import InvalidUriError
+from gslib.util import PrintFullInfoAboutObject
-_detailed_help_text = ("""
+
+_DETAILED_HELP_TEXT = ("""
<B>SYNOPSIS</B>
- gsutil stat uri...
+ gsutil stat url...
<B>DESCRIPTION</B>
- The stat command will output details about the specified object URIs.
+ The stat command will output details about the specified object URLs.
It is similar to running:
gsutil ls -L gs://some-bucket/some-object
- but is more efficient because it avoids performing bucket listings and extra
- ACL GET's before reading each object's metadata. It performs a single HTTP
- HEAD request per listed object.
+ but is more efficient because it avoids performing bucket listings gets the
+ minimum necessary amount of object metadata.
The gsutil stat command will, however, perform bucket listings if you specify
- URIs using wildcards.
+ URLs using wildcards.
If run with the gsutil -q option nothing will be printed, e.g.:
@@ -74,55 +66,71 @@
object with that name, the operation will fail.
""")
+
# TODO: Add ability to stat buckets.
-
class StatCommand(Command):
"""Implementation of gsutil stat command."""
- # Command specification (processed by parent class).
- command_spec = {
- # Name of command.
- COMMAND_NAME : 'stat',
- # List of command name aliases.
- COMMAND_NAME_ALIASES : [],
- # 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 : '',
- # 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,
- }
- help_spec = {
- # Name of command or auxiliary help info for which this help applies.
- HELP_NAME : 'stat',
- # List of help name aliases.
- HELP_NAME_ALIASES : [],
- # Type of help:
- HELP_TYPE : HelpType.COMMAND_HELP,
- # One line summary of this help.
- HELP_ONE_LINE_SUMMARY : 'Display object status',
- # The full help text.
- HELP_TEXT : _detailed_help_text,
- }
+ # Command specification. See base class for documentation.
+ command_spec = Command.CreateCommandSpec(
+ 'stat',
+ command_name_aliases=[],
+ min_args=1,
+ max_args=NO_MAX,
+ supported_sub_args='',
+ file_url_ok=False,
+ provider_url_ok=False,
+ urls_start_arg=0,
+ gs_api_support=[ApiSelector.XML, ApiSelector.JSON],
+ gs_default_api=ApiSelector.JSON,
+ )
+ # Help specification. See help_provider.py for documentation.
+ help_spec = Command.HelpSpec(
+ help_name='stat',
+ help_name_aliases=[],
+ help_type='command_help',
+ help_one_line_summary='Display object status',
+ help_text=_DETAILED_HELP_TEXT,
+ subcommand_help_text={},
+ )
- # Command entry point.
def RunCommand(self):
- for uri_str in self.args:
- uri = self.suri_builder.StorageUri(uri_str)
- if not uri.names_object():
- raise CommandException('The stat command only works with object URIs')
- for blr in self.WildcardIterator(uri):
+ """Command entry point for stat command."""
+ # List of fields we'll print for stat objects.
+ stat_fields = ['updated', 'cacheControl', 'contentDisposition',
+ 'contentEncoding', 'contentLanguage', 'size', 'contentType',
+ 'componentCount', 'metadata', 'crc32c', 'md5Hash', 'etag',
+ 'generation', 'metageneration']
+ found_nonmatching_arg = False
+ for url_str in self.args:
+ arg_matches = 0
+ url = StorageUrlFromString(url_str)
+ if not url.IsObject():
+ raise CommandException('The stat command only works with object URLs')
+ try:
+ if ContainsWildcard(url_str):
+ blr_iter = self.WildcardIterator(url_str).IterObjects(
+ bucket_listing_fields=stat_fields)
+ else:
+ single_obj = self.gsutil_api.GetObjectMetadata(
+ url.bucket_name, url.object_name, generation=url.generation,
+ provider=url.scheme, fields=stat_fields)
+ blr_iter = [BucketListingObject(url, root_object=single_obj)]
+ for blr in blr_iter:
+ if blr.IsObject():
+ arg_matches += 1
+ if logging.getLogger().isEnabledFor(logging.INFO):
+ PrintFullInfoAboutObject(blr, incl_acl=False)
+ except AccessDeniedException:
+ print 'You aren\'t authorized to read %s - skipping' % url_str
+ except InvalidUrlError:
+ raise
+ except NotFoundException:
+ pass
+ if not arg_matches:
if logging.getLogger().isEnabledFor(logging.INFO):
- PrintFullInfoAboutUri(blr.uri, False, self.headers)
- else:
- try:
- uri.get_key(False, headers=self.headers)
- except InvalidUriError as e:
- return 1
+ print 'No URLs matched %s' % url_str
+ found_nonmatching_arg = True
+ if found_nonmatching_arg:
+ return 1
return 0
« no previous file with comments | « gslib/commands/signurl.py ('k') | gslib/commands/test.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698