All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.netflix.spinnaker.clouddriver.google.config.GoogleCredentialsConfiguration Maven / Gradle / Ivy

/*
 * Copyright 2022 OpsMx, Inc.
 *
 * 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.
 */

package com.netflix.spinnaker.clouddriver.google.config;

import com.netflix.spinnaker.clouddriver.google.ComputeVersion;
import com.netflix.spinnaker.clouddriver.google.GoogleCloudProvider;
import com.netflix.spinnaker.clouddriver.google.GoogleExecutor;
import com.netflix.spinnaker.clouddriver.google.security.GoogleNamedAccountCredentials;
import com.netflix.spinnaker.clouddriver.names.NamerRegistry;
import com.netflix.spinnaker.clouddriver.security.CredentialsInitializerSynchronizable;
import com.netflix.spinnaker.config.GoogleConfiguration;
import com.netflix.spinnaker.credentials.CredentialsLifecycleHandler;
import com.netflix.spinnaker.credentials.CredentialsRepository;
import com.netflix.spinnaker.credentials.CredentialsTypeBaseConfiguration;
import com.netflix.spinnaker.credentials.CredentialsTypeProperties;
import com.netflix.spinnaker.credentials.MapBackedCredentialsRepository;
import com.netflix.spinnaker.credentials.definition.AbstractCredentialsLoader;
import com.netflix.spinnaker.credentials.poller.Poller;
import com.netflix.spinnaker.kork.configserver.ConfigFileService;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class GoogleCredentialsConfiguration {
  private static final Logger log = LoggerFactory.getLogger(GoogleCredentialsConfiguration.class);

  @Autowired NamerRegistry namerRegistry;

  @Bean
  public CredentialsTypeBaseConfiguration<
          GoogleNamedAccountCredentials, GoogleConfigurationProperties.ManagedAccount>
      googleCredentialsProperties(
          ApplicationContext applicationContext,
          GoogleConfigurationProperties configurationProperties,
          ConfigFileService configFileService,
          GoogleConfiguration.DeployDefaults googleDeployDefaults,
          GoogleExecutor googleExecutor,
          String clouddriverUserAgentApplicationName) {

    return new CredentialsTypeBaseConfiguration(
        applicationContext,
        CredentialsTypeProperties
            .builder()
            .type(GoogleNamedAccountCredentials.CREDENTIALS_TYPE)
            .credentialsDefinitionClass(GoogleConfigurationProperties.ManagedAccount.class)
            .credentialsClass(GoogleNamedAccountCredentials.class)
            .credentialsParser(
                a -> {
                  try {
                    String jsonKey = configFileService.getContents(a.getJsonPath());

                    return new GoogleNamedAccountCredentials.Builder()
                        .name(a.getName())
                        .environment(
                            StringUtils.isEmpty(a.getEnvironment())
                                ? a.getName()
                                : a.getEnvironment())
                        .accountType(
                            StringUtils.isEmpty(a.getAccountType())
                                ? a.getName()
                                : a.getAccountType())
                        .project(a.getProject())
                        .computeVersion(
                            a.isAlphaListed() ? ComputeVersion.ALPHA : ComputeVersion.DEFAULT)
                        .jsonKey(jsonKey)
                        .serviceAccountId(a.getServiceAccountId())
                        .serviceAccountProject(a.getServiceAccountProject())
                        .imageProjects(a.getImageProjects())
                        .requiredGroupMembership(a.getRequiredGroupMembership())
                        .permissions(a.getPermissions().build())
                        .applicationName(clouddriverUserAgentApplicationName)
                        .consulConfig(a.getConsul())
                        .instanceTypeDisks(googleDeployDefaults.getInstanceTypeDisks())
                        .userDataFile(a.getUserDataFile())
                        .regionsToManage(
                            a.getRegions(), configurationProperties.getDefaultRegions())
                        .namer(namerRegistry.getNamingStrategy(a.getNamingStrategy()))
                        .build();
                  } catch (Exception e) {
                    log.info("Error loading Google credentials: " + e.getMessage() + ".");
                    return null;
                  }
                })
            .defaultCredentialsSource(configurationProperties::getAccounts)
            .build());
  }

  @Bean
  public CredentialsInitializerSynchronizable googleCredentialsInitializerSynchronizable(
      AbstractCredentialsLoader loader) {
    final Poller poller = new Poller<>(loader);
    return new CredentialsInitializerSynchronizable() {
      @Override
      public void synchronize() {
        poller.run();
      }
    };
  }

  @Bean
  @ConditionalOnMissingBean(
      value = GoogleNamedAccountCredentials.class,
      parameterizedContainer = CredentialsRepository.class)
  public CredentialsRepository googleCredentialsRepository(
      CredentialsLifecycleHandler eventHandler) {
    return new MapBackedCredentialsRepository<>(GoogleCloudProvider.getID(), eventHandler);
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy