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

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

Issue 1377933002: [catapult] - Copy Telemetry's gsutilz over to third_party. (Closed) Base URL: https://github.com/catapult-project/catapult.git@master
Patch Set: Rename to gsutil. Created 5 years, 3 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/lifecycle.py ('k') | third_party/gsutil/gslib/commands/ls.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: third_party/gsutil/gslib/commands/logging.py
diff --git a/third_party/gsutil/gslib/commands/logging.py b/third_party/gsutil/gslib/commands/logging.py
new file mode 100644
index 0000000000000000000000000000000000000000..dab9f52ce9002ef0a6ebe2c4502075b697077e7e
--- /dev/null
+++ b/third_party/gsutil/gslib/commands/logging.py
@@ -0,0 +1,253 @@
+# -*- coding: utf-8 -*-
+# 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.
+"""Implementation of logging configuration command for buckets."""
+
+from __future__ import absolute_import
+
+import sys
+
+from apitools.base.py import encoding
+
+from gslib.command import Command
+from gslib.command_argument import CommandArgument
+from gslib.cs_api_map import ApiSelector
+from gslib.exception import CommandException
+from gslib.help_provider import CreateHelpText
+from gslib.storage_url import StorageUrlFromString
+from gslib.third_party.storage_apitools import storage_v1_messages as apitools_messages
+from gslib.util import NO_MAX
+from gslib.util import UrlsAreForSingleProvider
+
+_SET_SYNOPSIS = """
+ gsutil logging set on -b logging_bucket [-o log_object_prefix] url...
+ gsutil logging set off url...
+"""
+
+_GET_SYNOPSIS = """
+ gsutil logging get url
+"""
+
+_SYNOPSIS = _SET_SYNOPSIS + _GET_SYNOPSIS.lstrip('\n') + '\n'
+
+_SET_DESCRIPTION = """
+<B>SET</B>
+ The set sub-command has two sub-commands:
+
+<B>ON</B>
+ The "gsutil set on" command will enable access logging of the
+ buckets named by the specified URLs, outputting log files in the specified
+ logging_bucket. logging_bucket must already exist, and all URLs must name
+ buckets (e.g., gs://bucket). The required bucket parameter specifies the
+ bucket to which the logs are written, and the optional log_object_prefix
+ parameter specifies the prefix for log object names. The default prefix
+ is the bucket name. For example, the command:
+
+ gsutil logging set on -b gs://my_logging_bucket -o AccessLog \\
+ gs://my_bucket1 gs://my_bucket2
+
+ will cause all read and write activity to objects in gs://mybucket1 and
+ gs://mybucket2 to be logged to objects prefixed with the name "AccessLog",
+ with those log objects written to the bucket gs://my_logging_bucket.
+
+ Next, you need to grant cloud-storage-analytics@google.com write access to
+ the log bucket, using this command:
+
+ gsutil acl ch -g cloud-storage-analytics@google.com:W gs://my_logging_bucket
+
+ Note that log data may contain sensitive information, so you should make
+ sure to set an appropriate default bucket ACL to protect that data. (See
+ "gsutil help defacl".)
+
+<B>OFF</B>
+ This command will disable access logging of the buckets named by the
+ specified URLs. All URLs must name buckets (e.g., gs://bucket).
+
+ No logging data is removed from the log buckets when you disable logging,
+ but Google Cloud Storage will stop delivering new logs once you have
+ run this command.
+
+"""
+
+_GET_DESCRIPTION = """
+<B>GET</B>
+ If logging is enabled for the specified bucket url, the server responds
+ with a JSON document that looks something like this:
+
+ {
+ "logObjectPrefix": "AccessLog",
+ "logBucket": "my_logging_bucket"
+ }
+
+ You can download log data from your log bucket using the gsutil cp command.
+
+"""
+
+_DESCRIPTION = """
+ Google Cloud Storage offers access logs and storage data in the form of
+ CSV files that you can download and view. Access logs provide information
+ for all of the requests made on a specified bucket in the last 24 hours,
+ while the storage logs provide information about the storage consumption of
+ that bucket for the last 24 hour period. The logs and storage data files
+ are automatically created as new objects in a bucket that you specify, in
+ 24 hour intervals.
+
+ The logging command has two sub-commands:
+""" + _SET_DESCRIPTION + _GET_DESCRIPTION + """
+
+<B>ACCESS LOG AND STORAGE DATA FIELDS</B>
+ For a complete list of access log fields and storage data fields, see:
+ https://developers.google.com/storage/docs/accesslogs#reviewing
+"""
+
+_DETAILED_HELP_TEXT = CreateHelpText(_SYNOPSIS, _DESCRIPTION)
+
+_get_help_text = CreateHelpText(_GET_SYNOPSIS, _GET_DESCRIPTION)
+_set_help_text = CreateHelpText(_SET_SYNOPSIS, _SET_DESCRIPTION)
+
+
+class LoggingCommand(Command):
+ """Implementation of gsutil logging command."""
+
+ # Command specification. See base class for documentation.
+ command_spec = Command.CreateCommandSpec(
+ 'logging',
+ command_name_aliases=['disablelogging', 'enablelogging', 'getlogging'],
+ usage_synopsis=_SYNOPSIS,
+ min_args=2,
+ max_args=NO_MAX,
+ supported_sub_args='b:o:',
+ file_url_ok=False,
+ provider_url_ok=False,
+ urls_start_arg=0,
+ gs_api_support=[ApiSelector.XML, ApiSelector.JSON],
+ gs_default_api=ApiSelector.JSON,
+ argparse_arguments=[
+ CommandArgument('mode', choices=['on', 'off']),
+ CommandArgument.MakeZeroOrMoreCloudBucketURLsArgument()
+ ]
+ )
+ # Help specification. See help_provider.py for documentation.
+ help_spec = Command.HelpSpec(
+ help_name='logging',
+ help_name_aliases=['loggingconfig', 'logs', 'log', 'getlogging',
+ 'enablelogging', 'disablelogging'],
+ help_type='command_help',
+ help_one_line_summary='Configure or retrieve logging on buckets',
+ help_text=_DETAILED_HELP_TEXT,
+ subcommand_help_text={'get': _get_help_text, 'set': _set_help_text},
+ )
+
+ def _Get(self):
+ """Gets logging configuration for a bucket."""
+ bucket_url, bucket_metadata = self.GetSingleBucketUrlFromArg(
+ self.args[0], bucket_fields=['logging'])
+
+ if bucket_url.scheme == 's3':
+ sys.stdout.write(self.gsutil_api.XmlPassThroughGetLogging(
+ bucket_url, provider=bucket_url.scheme))
+ else:
+ if (bucket_metadata.logging and bucket_metadata.logging.logBucket and
+ bucket_metadata.logging.logObjectPrefix):
+ sys.stdout.write(str(encoding.MessageToJson(
+ bucket_metadata.logging)) + '\n')
+ else:
+ sys.stdout.write('%s has no logging configuration.\n' % bucket_url)
+ return 0
+
+ def _Enable(self):
+ """Enables logging configuration for a bucket."""
+ # Disallow multi-provider 'logging set on' calls, because the schemas
+ # differ.
+ if not UrlsAreForSingleProvider(self.args):
+ raise CommandException('"logging set on" command spanning providers not '
+ 'allowed.')
+ target_bucket_url = None
+ target_prefix = None
+ for opt, opt_arg in self.sub_opts:
+ if opt == '-b':
+ target_bucket_url = StorageUrlFromString(opt_arg)
+ if opt == '-o':
+ target_prefix = opt_arg
+
+ if not target_bucket_url:
+ raise CommandException('"logging set on" requires \'-b <log_bucket>\' '
+ 'option')
+ if not target_bucket_url.IsBucket():
+ raise CommandException('-b option must specify a bucket URL.')
+
+ # Iterate over URLs, expanding wildcards and setting logging on each.
+ some_matched = False
+ for url_str in self.args:
+ bucket_iter = self.GetBucketUrlIterFromArg(url_str, bucket_fields=['id'])
+ for blr in bucket_iter:
+ url = blr.storage_url
+ some_matched = True
+ self.logger.info('Enabling logging on %s...', blr)
+ logging = apitools_messages.Bucket.LoggingValue(
+ logBucket=target_bucket_url.bucket_name,
+ logObjectPrefix=target_prefix or url.bucket_name)
+
+ bucket_metadata = apitools_messages.Bucket(logging=logging)
+ self.gsutil_api.PatchBucket(url.bucket_name, bucket_metadata,
+ provider=url.scheme, fields=['id'])
+ if not some_matched:
+ raise CommandException('No URLs matched')
+ return 0
+
+ def _Disable(self):
+ """Disables logging configuration for a bucket."""
+ # Iterate over URLs, expanding wildcards, and disabling logging on each.
+ some_matched = False
+ for url_str in self.args:
+ bucket_iter = self.GetBucketUrlIterFromArg(url_str, bucket_fields=['id'])
+ for blr in bucket_iter:
+ url = blr.storage_url
+ some_matched = True
+ self.logger.info('Disabling logging on %s...', blr)
+ logging = apitools_messages.Bucket.LoggingValue()
+
+ bucket_metadata = apitools_messages.Bucket(logging=logging)
+ self.gsutil_api.PatchBucket(url.bucket_name, bucket_metadata,
+ provider=url.scheme, fields=['id'])
+ if not some_matched:
+ raise CommandException('No URLs matched')
+ return 0
+
+ def RunCommand(self):
+ """Command entry point for the logging command."""
+ # Parse the subcommand and alias for the new logging command.
+ action_subcommand = self.args.pop(0)
+ if action_subcommand == 'get':
+ func = self._Get
+ elif action_subcommand == 'set':
+ state_subcommand = self.args.pop(0)
+ if not self.args:
+ self.RaiseWrongNumberOfArgumentsException()
+ if state_subcommand == 'on':
+ func = self._Enable
+ elif state_subcommand == 'off':
+ func = self._Disable
+ else:
+ raise CommandException((
+ 'Invalid subcommand "%s" for the "%s %s" command.\n'
+ 'See "gsutil help logging".') % (
+ state_subcommand, self.command_name, action_subcommand))
+ else:
+ raise CommandException(('Invalid subcommand "%s" for the %s command.\n'
+ 'See "gsutil help logging".') %
+ (action_subcommand, self.command_name))
+ self.ParseSubOpts(check_args=True)
+ func()
+ return 0
« no previous file with comments | « third_party/gsutil/gslib/commands/lifecycle.py ('k') | third_party/gsutil/gslib/commands/ls.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698