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

io.openraven.magpie.plugins.gcp.discovery.services.DataprocDiscovery Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2021 Open Raven 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 io.openraven.magpie.plugins.gcp.discovery.services;

import com.fasterxml.jackson.databind.ObjectMapper;
import com.google.api.gax.core.CredentialsProvider;
import com.google.api.gax.core.CredentialsProvider;
import com.google.cloud.dataproc.v1.*;
import io.openraven.magpie.api.Emitter;
import io.openraven.magpie.api.MagpieGcpResource;
import io.openraven.magpie.api.Session;
import io.openraven.magpie.data.gcp.data.DataProcCluster;
import io.openraven.magpie.data.gcp.data.DataProcJob;
import io.openraven.magpie.plugins.gcp.discovery.exception.DiscoveryExceptions;
import io.openraven.magpie.plugins.gcp.discovery.GCPUtils;
import io.openraven.magpie.plugins.gcp.discovery.VersionedMagpieEnvelopeProvider;
import org.slf4j.Logger;

import java.io.IOException;
import java.util.List;
import java.util.Optional;

public class DataprocDiscovery implements GCPDiscovery {
  private static final String SERVICE = "dataproc";

  private static final List AVAILABLE_LOCATIONS = List.of(
    "asia-east1",
    "asia-east2",
    "asia-northeast1",
    "asia-northeast2",
    "asia-northeast3",
    "asia-south1",
    "asia-southeast1",
    "asia-southeast2",
    "australia-southeast1",
    "australia-southeast2",
    "europe-central2",
    "europe-north1",
    "europe-west1",
    "europe-west2",
    "europe-west3",
    "europe-west4",
    "europe-west5",
    "europe-west6",
    "northamerica-northeast1",
    "southamerica-east1",
    "us-central1",
    "us-east1",
    "us-east4",
    "us-west1",
    "us-west2",
    "us-west3",
    "us-west4",
    "global");

  @Override
  public String service() {
    return SERVICE;
  }

  public void discover(ObjectMapper mapper, String projectId, Session session, Emitter emitter, Logger logger, Optional maybeCredentialsProvider) {
    AVAILABLE_LOCATIONS.forEach(location -> {
      discoverClusters(mapper, projectId, session, emitter, location, maybeCredentialsProvider);
      discoverJobs(mapper, projectId, session, emitter, location, maybeCredentialsProvider);
    });
  }

  private void discoverClusters(ObjectMapper mapper, String projectId, Session session, Emitter emitter, String location, Optional maybeCredentialsProvider) {
    final String RESOURCE_TYPE = DataProcCluster.RESOURCE_TYPE;

    try {
        final ClusterControllerSettings.Builder builder = ClusterControllerSettings.newBuilder();
        maybeCredentialsProvider.ifPresent(builder::setCredentialsProvider);
        var clusterControllerConfig = location.equals("global") ?
        builder.build() :
        builder
          .setEndpoint("-dataproc.googleapis.com:443".replace("", location))
          .build();
      try (var client = ClusterControllerClient.create(clusterControllerConfig)){
        for (var cluster : client.listClusters(projectId, location).iterateAll()) {
          String assetId = String.format("%s::%s", RESOURCE_TYPE, cluster.getClusterName());
          var data = new MagpieGcpResource.MagpieGcpResourceBuilder(mapper, assetId)
            .withProjectId(projectId)
            .withResourceType(RESOURCE_TYPE)
            .withRegion(location)
            .withConfiguration(GCPUtils.asJsonNode(cluster))
            .build();

          emitter.emit(VersionedMagpieEnvelopeProvider.create(session, List.of(fullService() + ":cluster"), data.toJsonNode()));
        }
      }
    } catch (IOException e) {
      DiscoveryExceptions.onDiscoveryException(RESOURCE_TYPE, e);
    }
  }

  private void discoverJobs(ObjectMapper mapper, String projectId, Session session, Emitter emitter, String location, Optional maybeCredentialsProvider) {
    final String RESOURCE_TYPE = DataProcJob.RESOURCE_TYPE;

    try {
        final JobControllerSettings.Builder builder = JobControllerSettings.newBuilder();
        maybeCredentialsProvider.ifPresent(builder::setCredentialsProvider);
        var clusterControllerConfig = location.equals("global") ?
        builder.build() :
        builder
          .setEndpoint("-dataproc.googleapis.com:443".replace("", location))
          .build();
      try (var client = JobControllerClient.create(clusterControllerConfig)){
        for (var job : client.listJobs(projectId, location).iterateAll()) {
          String assetId = String.format("%s::%s", RESOURCE_TYPE, job.getReference().getJobId());
          var data = new MagpieGcpResource.MagpieGcpResourceBuilder(mapper, assetId)
            .withProjectId(projectId)
            .withResourceType(RESOURCE_TYPE)
            .withRegion(location)
            .withConfiguration(GCPUtils.asJsonNode(job))
            .build();

          emitter.emit(VersionedMagpieEnvelopeProvider.create(session, List.of(fullService() + ":job"), data.toJsonNode()));
        }
      }
    } catch (IOException e) {
      DiscoveryExceptions.onDiscoveryException(RESOURCE_TYPE, e);
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy