1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

restored configurabilty of scopes (#54485)

This commit is contained in:
Brian Coca 2019-03-27 16:59:56 -04:00 committed by Adam Miller
parent 6e12517164
commit ba50c6e06e

View file

@ -48,6 +48,10 @@ DOCUMENTATION = '''
- The type of credential used. - The type of credential used.
required: True required: True
choices: ['application', 'serviceaccount', 'machineaccount'] choices: ['application', 'serviceaccount', 'machineaccount']
scopes:
description: list of authentication scopes
type: list
default: ['https://www.googleapis.com/auth/compute']
service_account_file: service_account_file:
description: description:
- The path of a Service Account JSON file if serviceaccount is selected as type. - The path of a Service Account JSON file if serviceaccount is selected as type.
@ -85,6 +89,9 @@ filters:
- scheduling.automaticRestart = true AND machineType = n1-standard-1 - scheduling.automaticRestart = true AND machineType = n1-standard-1
service_account_file: /tmp/service_account.json service_account_file: /tmp/service_account.json
auth_kind: serviceaccount auth_kind: serviceaccount
scopes:
- 'https://www.googleapis.com/auth/cloud-platform'
- 'https://www.googleapis.com/auth/compute.readonly'
keyed_groups: keyed_groups:
# Create groups from GCE labels # Create groups from GCE labels
- prefix: gcp - prefix: gcp
@ -119,6 +126,8 @@ class InventoryModule(BaseInventoryPlugin, Constructable, Cacheable):
NAME = 'gcp_compute' NAME = 'gcp_compute'
_instances = r"https://www.googleapis.com/compute/v1/projects/%s/zones/%s/instances"
def __init__(self): def __init__(self):
super(InventoryModule, self).__init__() super(InventoryModule, self).__init__()
@ -149,13 +158,6 @@ class InventoryModule(BaseInventoryPlugin, Constructable, Cacheable):
return True return True
return False return False
def self_link(self, project, zone):
'''
:param params: a dict containing all of the fields relevant to build URL
:return the formatted URL as a string.
'''
return "https://www.googleapis.com/compute/v1/projects/%s/zones/%s/instances" % (project, zone)
def fetch_list(self, params, link, query): def fetch_list(self, params, link, query):
''' '''
:param params: a dict containing all of the fields relevant to build URL :param params: a dict containing all of the fields relevant to build URL
@ -349,7 +351,7 @@ class InventoryModule(BaseInventoryPlugin, Constructable, Cacheable):
params = { params = {
'filters': self.get_option('filters'), 'filters': self.get_option('filters'),
'projects': self.get_option('projects'), 'projects': self.get_option('projects'),
'scopes': ['https://www.googleapis.com/auth/compute'], 'scopes': self.get_option('scopes'),
'zones': self.get_option('zones'), 'zones': self.get_option('zones'),
'auth_kind': self.get_option('auth_kind'), 'auth_kind': self.get_option('auth_kind'),
'service_account_file': self.get_option('service_account_file'), 'service_account_file': self.get_option('service_account_file'),
@ -385,7 +387,7 @@ class InventoryModule(BaseInventoryPlugin, Constructable, Cacheable):
else: else:
zones = params['zones'] zones = params['zones']
for zone in zones: for zone in zones:
link = self.self_link(project, zone) link = self._instances % (project, zone)
params['zone'] = zone params['zone'] = zone
resp = self.fetch_list(params, link, query) resp = self.fetch_list(params, link, query)
self._add_hosts(resp.get('items'), config_data) self._add_hosts(resp.get('items'), config_data)