ManageIQ/manageiq

View on GitHub
lib/ansible/runner/credential/google_credential.rb

Summary

Maintainability
A
0 mins
Test Coverage
A
100%
module Ansible
  class Runner
    class GoogleCredential < Credential
      def self.auth_type
        "ManageIQ::Providers::EmbeddedAnsible::AutomationManager::GoogleCredential"
      end

      # Modeled off of gce injectors for awx:
      #
      #   https://github.com/ansible/awx/blob/1242ee2b/awx/main/models/credential/injectors.py#L18-L42
      #
      def env_vars
        {
          "GCE_EMAIL"                 => auth.userid || "",
          "GCE_PROJECT"               => auth.project || "",
          "GCE_CREDENTIALS_FILE_PATH" => gce_credentials_file
        }
      end

      def write_config_files
        write_gce_credentials_file
      end

      private

      def write_gce_credentials_file
        json_data = {
          :type                        => "service_account",
          :private_key                 => auth.auth_key || "",
          :client_email                => auth.userid || "",
          :project_id                  => auth.project || "",
          :auth_uri                    => "https://accounts.google.com/o/oauth2/auth",
          :token_uri                   => "https://oauth2.googleapis.com/token",
          :auth_provider_x509_cert_url => "https://www.googleapis.com/oauth2/v1/certs"
        }

        if auth.userid.present?
          client_x509_cert_url = "https://www.googleapis.com/robot/v1/metadata/x509/#{CGI.escape(auth.userid)}"
          json_data[:client_x509_cert_url] = client_x509_cert_url
        end

        File.write(gce_credentials_file, json_data.to_json)
        File.chmod(0o0600, gce_credentials_file)
      end

      def gce_credentials_file
        File.join(base_dir, "gce_credentials")
      end
    end
  end
end