#!/usr/bin/env python """CLI for dns, version v1.""" # NOTE: This file is autogenerated and should not be edited by hand. import code import os import platform import sys from apitools.base.protorpclite import message_types from apitools.base.protorpclite import messages from google.apputils import appcommands import gflags as flags import apitools.base.py as apitools_base from apitools.base.py import cli as apitools_base_cli import dns_v1_client as client_lib import dns_v1_messages as messages def _DeclareDnsFlags(): """Declare global flags in an idempotent way.""" if 'api_endpoint' in flags.FLAGS: return flags.DEFINE_string( 'api_endpoint', u'https://www.googleapis.com/dns/v1/', 'URL of the API endpoint to use.', short_name='dns_url') flags.DEFINE_string( 'history_file', u'~/.dns.v1.history', 'File with interactive shell history.') flags.DEFINE_multistring( 'add_header', [], 'Additional http headers (as key=value strings). ' 'Can be specified multiple times.') flags.DEFINE_string( 'service_account_json_keyfile', '', 'Filename for a JSON service account key downloaded' ' from the Developer Console.') flags.DEFINE_enum( 'alt', u'json', [u'json'], u'Data format for the response.') flags.DEFINE_string( 'fields', None, u'Selector specifying which fields to include in a partial response.') flags.DEFINE_string( 'key', None, u'API key. Your API key identifies your project and provides you with ' u'API access, quota, and reports. Required unless you provide an OAuth ' u'2.0 token.') flags.DEFINE_string( 'oauth_token', None, u'OAuth 2.0 token for the current user.') flags.DEFINE_boolean( 'prettyPrint', 'True', u'Returns response with indentations and line breaks.') flags.DEFINE_string( 'quotaUser', None, u'Available to use for quota purposes for server-side applications. Can' u' be any arbitrary string assigned to a user, but should not exceed 40' u' characters. Overrides userIp if both are provided.') flags.DEFINE_string( 'trace', None, 'A tracing token of the form "token:<tokenid>" to include in api ' 'requests.') flags.DEFINE_string( 'userIp', None, u'IP address of the site where the request originates. Use this if you ' u'want to enforce per-user limits.') FLAGS = flags.FLAGS apitools_base_cli.DeclareBaseFlags() _DeclareDnsFlags() def GetGlobalParamsFromFlags(): """Return a StandardQueryParameters based on flags.""" result = messages.StandardQueryParameters() if FLAGS['alt'].present: result.alt = messages.StandardQueryParameters.AltValueValuesEnum(FLAGS.alt) if FLAGS['fields'].present: result.fields = FLAGS.fields.decode('utf8') if FLAGS['key'].present: result.key = FLAGS.key.decode('utf8') if FLAGS['oauth_token'].present: result.oauth_token = FLAGS.oauth_token.decode('utf8') if FLAGS['prettyPrint'].present: result.prettyPrint = FLAGS.prettyPrint if FLAGS['quotaUser'].present: result.quotaUser = FLAGS.quotaUser.decode('utf8') if FLAGS['trace'].present: result.trace = FLAGS.trace.decode('utf8') if FLAGS['userIp'].present: result.userIp = FLAGS.userIp.decode('utf8') return result def GetClientFromFlags(): """Return a client object, configured from flags.""" log_request = FLAGS.log_request or FLAGS.log_request_response log_response = FLAGS.log_response or FLAGS.log_request_response api_endpoint = apitools_base.NormalizeApiEndpoint(FLAGS.api_endpoint) additional_http_headers = dict(x.split('=', 1) for x in FLAGS.add_header) credentials_args = { 'service_account_json_keyfile': os.path.expanduser(FLAGS.service_account_json_keyfile) } try: client = client_lib.DnsV1( api_endpoint, log_request=log_request, log_response=log_response, credentials_args=credentials_args, additional_http_headers=additional_http_headers) except apitools_base.CredentialsError as e: print 'Error creating credentials: %s' % e sys.exit(1) return client class PyShell(appcommands.Cmd): def Run(self, _): """Run an interactive python shell with the client.""" client = GetClientFromFlags() params = GetGlobalParamsFromFlags() for field in params.all_fields(): value = params.get_assigned_value(field.name) if value != field.default: client.AddGlobalParam(field.name, value) banner = """ == dns interactive console == client: a dns client apitools_base: base apitools module messages: the generated messages module """ local_vars = { 'apitools_base': apitools_base, 'client': client, 'client_lib': client_lib, 'messages': messages, } if platform.system() == 'Linux': console = apitools_base_cli.ConsoleWithReadline( local_vars, histfile=FLAGS.history_file) else: console = code.InteractiveConsole(local_vars) try: console.interact(banner) except SystemExit as e: return e.code class ChangesCreate(apitools_base_cli.NewCmd): """Command wrapping changes.Create.""" usage = """changes_create <project> <managedZone>""" def __init__(self, name, fv): super(ChangesCreate, self).__init__(name, fv) flags.DEFINE_string( 'change', None, u'A Change resource to be passed as the request body.', flag_values=fv) def RunWithArgs(self, project, managedZone): """Atomically update the ResourceRecordSet collection. Args: project: Identifies the project addressed by this request. managedZone: Identifies the managed zone addressed by this request. Can be the managed zone name or id. Flags: change: A Change resource to be passed as the request body. """ client = GetClientFromFlags() global_params = GetGlobalParamsFromFlags() request = messages.DnsChangesCreateRequest( project=project.decode('utf8'), managedZone=managedZone.decode('utf8'), ) if FLAGS['change'].present: request.change = apitools_base.JsonToMessage(messages.Change, FLAGS.change) result = client.changes.Create( request, global_params=global_params) print apitools_base_cli.FormatOutput(result) class ChangesGet(apitools_base_cli.NewCmd): """Command wrapping changes.Get.""" usage = """changes_get <project> <managedZone> <changeId>""" def __init__(self, name, fv): super(ChangesGet, self).__init__(name, fv) def RunWithArgs(self, project, managedZone, changeId): """Fetch the representation of an existing Change. Args: project: Identifies the project addressed by this request. managedZone: Identifies the managed zone addressed by this request. Can be the managed zone name or id. changeId: The identifier of the requested change, from a previous ResourceRecordSetsChangeResponse. """ client = GetClientFromFlags() global_params = GetGlobalParamsFromFlags() request = messages.DnsChangesGetRequest( project=project.decode('utf8'), managedZone=managedZone.decode('utf8'), changeId=changeId.decode('utf8'), ) result = client.changes.Get( request, global_params=global_params) print apitools_base_cli.FormatOutput(result) class ChangesList(apitools_base_cli.NewCmd): """Command wrapping changes.List.""" usage = """changes_list <project> <managedZone>""" def __init__(self, name, fv): super(ChangesList, self).__init__(name, fv) flags.DEFINE_integer( 'maxResults', None, u'Optional. Maximum number of results to be returned. If unspecified,' u' the server will decide how many results to return.', flag_values=fv) flags.DEFINE_string( 'pageToken', None, u'Optional. A tag returned by a previous list request that was ' u'truncated. Use this parameter to continue a previous list request.', flag_values=fv) flags.DEFINE_enum( 'sortBy', u'changeSequence', [u'changeSequence'], u'Sorting criterion. The only supported value is change sequence.', flag_values=fv) flags.DEFINE_string( 'sortOrder', None, u"Sorting order direction: 'ascending' or 'descending'.", flag_values=fv) def RunWithArgs(self, project, managedZone): """Enumerate Changes to a ResourceRecordSet collection. Args: project: Identifies the project addressed by this request. managedZone: Identifies the managed zone addressed by this request. Can be the managed zone name or id. Flags: maxResults: Optional. Maximum number of results to be returned. If unspecified, the server will decide how many results to return. pageToken: Optional. A tag returned by a previous list request that was truncated. Use this parameter to continue a previous list request. sortBy: Sorting criterion. The only supported value is change sequence. sortOrder: Sorting order direction: 'ascending' or 'descending'. """ client = GetClientFromFlags() global_params = GetGlobalParamsFromFlags() request = messages.DnsChangesListRequest( project=project.decode('utf8'), managedZone=managedZone.decode('utf8'), ) if FLAGS['maxResults'].present: request.maxResults = FLAGS.maxResults if FLAGS['pageToken'].present: request.pageToken = FLAGS.pageToken.decode('utf8') if FLAGS['sortBy'].present: request.sortBy = messages.DnsChangesListRequest.SortByValueValuesEnum(FLAGS.sortBy) if FLAGS['sortOrder'].present: request.sortOrder = FLAGS.sortOrder.decode('utf8') result = client.changes.List( request, global_params=global_params) print apitools_base_cli.FormatOutput(result) class ManagedZonesCreate(apitools_base_cli.NewCmd): """Command wrapping managedZones.Create.""" usage = """managedZones_create <project>""" def __init__(self, name, fv): super(ManagedZonesCreate, self).__init__(name, fv) flags.DEFINE_string( 'managedZone', None, u'A ManagedZone resource to be passed as the request body.', flag_values=fv) def RunWithArgs(self, project): """Create a new ManagedZone. Args: project: Identifies the project addressed by this request. Flags: managedZone: A ManagedZone resource to be passed as the request body. """ client = GetClientFromFlags() global_params = GetGlobalParamsFromFlags() request = messages.DnsManagedZonesCreateRequest( project=project.decode('utf8'), ) if FLAGS['managedZone'].present: request.managedZone = apitools_base.JsonToMessage(messages.ManagedZone, FLAGS.managedZone) result = client.managedZones.Create( request, global_params=global_params) print apitools_base_cli.FormatOutput(result) class ManagedZonesDelete(apitools_base_cli.NewCmd): """Command wrapping managedZones.Delete.""" usage = """managedZones_delete <project> <managedZone>""" def __init__(self, name, fv): super(ManagedZonesDelete, self).__init__(name, fv) def RunWithArgs(self, project, managedZone): """Delete a previously created ManagedZone. Args: project: Identifies the project addressed by this request. managedZone: Identifies the managed zone addressed by this request. Can be the managed zone name or id. """ client = GetClientFromFlags() global_params = GetGlobalParamsFromFlags() request = messages.DnsManagedZonesDeleteRequest( project=project.decode('utf8'), managedZone=managedZone.decode('utf8'), ) result = client.managedZones.Delete( request, global_params=global_params) print apitools_base_cli.FormatOutput(result) class ManagedZonesGet(apitools_base_cli.NewCmd): """Command wrapping managedZones.Get.""" usage = """managedZones_get <project> <managedZone>""" def __init__(self, name, fv): super(ManagedZonesGet, self).__init__(name, fv) def RunWithArgs(self, project, managedZone): """Fetch the representation of an existing ManagedZone. Args: project: Identifies the project addressed by this request. managedZone: Identifies the managed zone addressed by this request. Can be the managed zone name or id. """ client = GetClientFromFlags() global_params = GetGlobalParamsFromFlags() request = messages.DnsManagedZonesGetRequest( project=project.decode('utf8'), managedZone=managedZone.decode('utf8'), ) result = client.managedZones.Get( request, global_params=global_params) print apitools_base_cli.FormatOutput(result) class ManagedZonesList(apitools_base_cli.NewCmd): """Command wrapping managedZones.List.""" usage = """managedZones_list <project>""" def __init__(self, name, fv): super(ManagedZonesList, self).__init__(name, fv) flags.DEFINE_string( 'dnsName', None, u'Restricts the list to return only zones with this domain name.', flag_values=fv) flags.DEFINE_integer( 'maxResults', None, u'Optional. Maximum number of results to be returned. If unspecified,' u' the server will decide how many results to return.', flag_values=fv) flags.DEFINE_string( 'pageToken', None, u'Optional. A tag returned by a previous list request that was ' u'truncated. Use this parameter to continue a previous list request.', flag_values=fv) def RunWithArgs(self, project): """Enumerate ManagedZones that have been created but not yet deleted. Args: project: Identifies the project addressed by this request. Flags: dnsName: Restricts the list to return only zones with this domain name. maxResults: Optional. Maximum number of results to be returned. If unspecified, the server will decide how many results to return. pageToken: Optional. A tag returned by a previous list request that was truncated. Use this parameter to continue a previous list request. """ client = GetClientFromFlags() global_params = GetGlobalParamsFromFlags() request = messages.DnsManagedZonesListRequest( project=project.decode('utf8'), ) if FLAGS['dnsName'].present: request.dnsName = FLAGS.dnsName.decode('utf8') if FLAGS['maxResults'].present: request.maxResults = FLAGS.maxResults if FLAGS['pageToken'].present: request.pageToken = FLAGS.pageToken.decode('utf8') result = client.managedZones.List( request, global_params=global_params) print apitools_base_cli.FormatOutput(result) class ProjectsGet(apitools_base_cli.NewCmd): """Command wrapping projects.Get.""" usage = """projects_get <project>""" def __init__(self, name, fv): super(ProjectsGet, self).__init__(name, fv) def RunWithArgs(self, project): """Fetch the representation of an existing Project. Args: project: Identifies the project addressed by this request. """ client = GetClientFromFlags() global_params = GetGlobalParamsFromFlags() request = messages.DnsProjectsGetRequest( project=project.decode('utf8'), ) result = client.projects.Get( request, global_params=global_params) print apitools_base_cli.FormatOutput(result) class ResourceRecordSetsList(apitools_base_cli.NewCmd): """Command wrapping resourceRecordSets.List.""" usage = """resourceRecordSets_list <project> <managedZone>""" def __init__(self, name, fv): super(ResourceRecordSetsList, self).__init__(name, fv) flags.DEFINE_integer( 'maxResults', None, u'Optional. Maximum number of results to be returned. If unspecified,' u' the server will decide how many results to return.', flag_values=fv) flags.DEFINE_string( 'name', None, u'Restricts the list to return only records with this fully qualified' u' domain name.', flag_values=fv) flags.DEFINE_string( 'pageToken', None, u'Optional. A tag returned by a previous list request that was ' u'truncated. Use this parameter to continue a previous list request.', flag_values=fv) flags.DEFINE_string( 'type', None, u'Restricts the list to return only records of this type. If present,' u' the "name" parameter must also be present.', flag_values=fv) def RunWithArgs(self, project, managedZone): """Enumerate ResourceRecordSets that have been created but not yet deleted. Args: project: Identifies the project addressed by this request. managedZone: Identifies the managed zone addressed by this request. Can be the managed zone name or id. Flags: maxResults: Optional. Maximum number of results to be returned. If unspecified, the server will decide how many results to return. name: Restricts the list to return only records with this fully qualified domain name. pageToken: Optional. A tag returned by a previous list request that was truncated. Use this parameter to continue a previous list request. type: Restricts the list to return only records of this type. If present, the "name" parameter must also be present. """ client = GetClientFromFlags() global_params = GetGlobalParamsFromFlags() request = messages.DnsResourceRecordSetsListRequest( project=project.decode('utf8'), managedZone=managedZone.decode('utf8'), ) if FLAGS['maxResults'].present: request.maxResults = FLAGS.maxResults if FLAGS['name'].present: request.name = FLAGS.name.decode('utf8') if FLAGS['pageToken'].present: request.pageToken = FLAGS.pageToken.decode('utf8') if FLAGS['type'].present: request.type = FLAGS.type.decode('utf8') result = client.resourceRecordSets.List( request, global_params=global_params) print apitools_base_cli.FormatOutput(result) def main(_): appcommands.AddCmd('pyshell', PyShell) appcommands.AddCmd('changes_create', ChangesCreate) appcommands.AddCmd('changes_get', ChangesGet) appcommands.AddCmd('changes_list', ChangesList) appcommands.AddCmd('managedZones_create', ManagedZonesCreate) appcommands.AddCmd('managedZones_delete', ManagedZonesDelete) appcommands.AddCmd('managedZones_get', ManagedZonesGet) appcommands.AddCmd('managedZones_list', ManagedZonesList) appcommands.AddCmd('projects_get', ProjectsGet) appcommands.AddCmd('resourceRecordSets_list', ResourceRecordSetsList) apitools_base_cli.SetupLogger() if hasattr(appcommands, 'SetDefaultCommand'): appcommands.SetDefaultCommand('pyshell') run_main = apitools_base_cli.run_main if __name__ == '__main__': appcommands.Run()