2018-10-08 10:50:39 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-03-16 12:50:48 -04:00
|
|
|
require 'google/apis/compute_v1'
|
2017-09-26 07:34:49 -04:00
|
|
|
require 'google/apis/container_v1'
|
2019-09-22 20:06:29 -04:00
|
|
|
require 'google/apis/container_v1beta1'
|
2017-12-15 17:54:50 -05:00
|
|
|
require 'google/apis/cloudbilling_v1'
|
2017-12-15 13:39:15 -05:00
|
|
|
require 'google/apis/cloudresourcemanager_v1'
|
2017-09-26 07:34:49 -04:00
|
|
|
|
2017-09-25 03:10:25 -04:00
|
|
|
module GoogleApi
|
|
|
|
module CloudPlatform
|
2017-09-30 11:54:22 -04:00
|
|
|
class Client < GoogleApi::Auth
|
2019-09-10 04:11:43 -04:00
|
|
|
SCOPE = 'https://www.googleapis.com/auth/cloud-platform'
|
2017-10-06 05:23:53 -04:00
|
|
|
LEAST_TOKEN_LIFE_TIME = 10.minutes
|
2019-09-10 04:11:43 -04:00
|
|
|
CLUSTER_MASTER_AUTH_USERNAME = 'admin'
|
2019-10-29 14:06:15 -04:00
|
|
|
CLUSTER_IPV4_CIDR_BLOCK = '/16'
|
2019-12-15 16:07:47 -05:00
|
|
|
CLUSTER_OAUTH_SCOPES = [
|
|
|
|
"https://www.googleapis.com/auth/devstorage.read_only",
|
|
|
|
"https://www.googleapis.com/auth/logging.write",
|
|
|
|
"https://www.googleapis.com/auth/monitoring"
|
|
|
|
].freeze
|
2017-10-01 04:48:21 -04:00
|
|
|
|
2017-09-25 13:11:26 -04:00
|
|
|
class << self
|
2017-09-30 11:54:22 -04:00
|
|
|
def session_key_for_token
|
2017-09-25 13:11:26 -04:00
|
|
|
:cloud_platform_access_token
|
|
|
|
end
|
2017-10-02 04:13:46 -04:00
|
|
|
|
|
|
|
def session_key_for_expires_at
|
|
|
|
:cloud_platform_expires_at
|
|
|
|
end
|
2017-10-06 08:28:40 -04:00
|
|
|
|
2017-10-06 10:14:14 -04:00
|
|
|
def new_session_key_for_redirect_uri
|
|
|
|
SecureRandom.hex.tap do |state|
|
|
|
|
yield session_key_for_redirect_uri(state)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def session_key_for_redirect_uri(state)
|
|
|
|
"cloud_platform_second_redirect_uri_#{state}"
|
2017-10-06 08:28:40 -04:00
|
|
|
end
|
2017-09-25 13:11:26 -04:00
|
|
|
end
|
|
|
|
|
2017-09-25 03:10:25 -04:00
|
|
|
def scope
|
2017-10-03 10:44:06 -04:00
|
|
|
SCOPE
|
2017-09-25 03:10:25 -04:00
|
|
|
end
|
|
|
|
|
2017-10-02 04:13:46 -04:00
|
|
|
def validate_token(expires_at)
|
|
|
|
return false unless access_token
|
|
|
|
return false unless expires_at
|
|
|
|
|
|
|
|
# Making sure that the token will have been still alive during the cluster creation.
|
2017-10-06 05:23:53 -04:00
|
|
|
return false if token_life_time(expires_at) < LEAST_TOKEN_LIFE_TIME
|
2017-10-02 04:13:46 -04:00
|
|
|
|
|
|
|
true
|
|
|
|
end
|
|
|
|
|
2017-09-26 10:05:12 -04:00
|
|
|
def projects_zones_clusters_get(project_id, zone, cluster_id)
|
2017-09-26 07:34:49 -04:00
|
|
|
service = Google::Apis::ContainerV1::ContainerService.new
|
|
|
|
service.authorization = access_token
|
|
|
|
|
2017-12-03 20:19:02 -05:00
|
|
|
service.get_zone_cluster(project_id, zone, cluster_id, options: user_agent_header)
|
2017-09-25 03:10:25 -04:00
|
|
|
end
|
|
|
|
|
2019-09-22 20:06:29 -04:00
|
|
|
def projects_zones_clusters_create(project_id, zone, cluster_name, cluster_size, machine_type:, legacy_abac:, enable_addons: [])
|
|
|
|
service = Google::Apis::ContainerV1beta1::ContainerService.new
|
2017-09-26 07:34:49 -04:00
|
|
|
service.authorization = access_token
|
|
|
|
|
2019-09-22 20:06:29 -04:00
|
|
|
cluster_options = make_cluster_options(cluster_name, cluster_size, machine_type, legacy_abac, enable_addons)
|
|
|
|
|
|
|
|
request_body = Google::Apis::ContainerV1beta1::CreateClusterRequest.new(cluster_options)
|
2017-09-26 07:34:49 -04:00
|
|
|
|
2017-12-03 20:19:02 -05:00
|
|
|
service.create_cluster(project_id, zone, request_body, options: user_agent_header)
|
2017-09-26 07:34:49 -04:00
|
|
|
end
|
2017-09-25 13:11:26 -04:00
|
|
|
|
2017-09-26 10:05:12 -04:00
|
|
|
def projects_zones_operations(project_id, zone, operation_id)
|
|
|
|
service = Google::Apis::ContainerV1::ContainerService.new
|
|
|
|
service.authorization = access_token
|
|
|
|
|
2017-12-03 20:19:02 -05:00
|
|
|
service.get_zone_operation(project_id, zone, operation_id, options: user_agent_header)
|
2017-09-26 10:05:12 -04:00
|
|
|
end
|
|
|
|
|
2017-09-30 11:54:22 -04:00
|
|
|
def parse_operation_id(self_link)
|
2017-10-05 05:17:21 -04:00
|
|
|
m = self_link.match(%r{projects/.*/zones/.*/operations/(.*)})
|
|
|
|
m[1] if m
|
2017-09-25 03:10:25 -04:00
|
|
|
end
|
2017-10-06 05:23:53 -04:00
|
|
|
|
|
|
|
private
|
|
|
|
|
2019-09-22 20:06:29 -04:00
|
|
|
def make_cluster_options(cluster_name, cluster_size, machine_type, legacy_abac, enable_addons)
|
|
|
|
{
|
|
|
|
cluster: {
|
|
|
|
name: cluster_name,
|
|
|
|
initial_node_count: cluster_size,
|
|
|
|
node_config: {
|
2019-12-15 16:07:47 -05:00
|
|
|
machine_type: machine_type,
|
|
|
|
oauth_scopes: CLUSTER_OAUTH_SCOPES
|
2019-09-22 20:06:29 -04:00
|
|
|
},
|
|
|
|
master_auth: {
|
|
|
|
username: CLUSTER_MASTER_AUTH_USERNAME,
|
|
|
|
client_certificate_config: {
|
|
|
|
issue_client_certificate: true
|
|
|
|
}
|
|
|
|
},
|
|
|
|
legacy_abac: {
|
|
|
|
enabled: legacy_abac
|
|
|
|
},
|
2019-10-10 08:06:19 -04:00
|
|
|
ip_allocation_policy: {
|
2019-10-29 14:06:15 -04:00
|
|
|
use_ip_aliases: true,
|
|
|
|
cluster_ipv4_cidr_block: CLUSTER_IPV4_CIDR_BLOCK
|
2019-10-10 08:06:19 -04:00
|
|
|
},
|
2019-12-15 16:07:47 -05:00
|
|
|
addons_config: make_addons_config(enable_addons)
|
2019-09-22 20:06:29 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2019-12-15 16:07:47 -05:00
|
|
|
def make_addons_config(enable_addons)
|
|
|
|
enable_addons.each_with_object({}) do |addon, hash|
|
|
|
|
hash[addon] = { disabled: false }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-10-06 05:23:53 -04:00
|
|
|
def token_life_time(expires_at)
|
|
|
|
DateTime.strptime(expires_at, '%s').to_time.utc - Time.now.utc
|
|
|
|
end
|
2017-12-03 18:53:04 -05:00
|
|
|
|
|
|
|
def user_agent_header
|
2017-12-04 07:43:45 -05:00
|
|
|
Google::Apis::RequestOptions.new.tap do |options|
|
|
|
|
options.header = { 'User-Agent': "GitLab/#{Gitlab::VERSION.match('(\d+\.\d+)').captures.first} (GPN:GitLab;)" }
|
|
|
|
end
|
2017-12-03 18:53:04 -05:00
|
|
|
end
|
2017-09-25 03:10:25 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|