
com.blazebit.query.connector.gcp.iam.PolicyDataFetcher Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of blaze-query-connector-google-gcp-iam Show documentation
Show all versions of blaze-query-connector-google-gcp-iam Show documentation
A multi-platform querying library
/*
* SPDX-License-Identifier: Apache-2.0
* Copyright Blazebit
*/
package com.blazebit.query.connector.gcp.iam;
import com.blazebit.query.connector.base.DataFormats;
import com.blazebit.query.connector.gcp.base.GcpConnectorConfig;
import com.blazebit.query.connector.gcp.base.GcpConventionContext;
import com.blazebit.query.spi.DataFetchContext;
import com.blazebit.query.spi.DataFetcher;
import com.blazebit.query.spi.DataFetcherException;
import com.blazebit.query.spi.DataFormat;
import com.google.api.gax.core.CredentialsProvider;
import com.google.api.gax.rpc.PermissionDeniedException;
import com.google.cloud.asset.v1.AssetServiceClient;
import com.google.cloud.asset.v1.AssetServiceSettings;
import com.google.cloud.asset.v1.IamPolicySearchResult;
import com.google.cloud.asset.v1.SearchAllIamPoliciesRequest;
import com.google.cloud.resourcemanager.v3.Organization;
import java.io.IOException;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
/**
* @author Christian Beikov
* @since 1.0.0
*/
public class PolicyDataFetcher implements DataFetcher, Serializable {
public static final PolicyDataFetcher INSTANCE = new PolicyDataFetcher();
private PolicyDataFetcher() {
}
@Override
public List fetch(DataFetchContext context) {
try {
List credentialsProviders = GcpConnectorConfig.GCP_CREDENTIALS_PROVIDER.getAll( context );
List list = new ArrayList<>();
List extends Organization> organizations = context.getSession().getOrFetch( Organization.class );
for ( CredentialsProvider credentialsProvider : credentialsProviders ) {
final AssetServiceSettings settings = AssetServiceSettings.newBuilder()
.setCredentialsProvider(credentialsProvider)
.build();
try (AssetServiceClient client = AssetServiceClient.create( settings )) {
try {
for ( Organization organization : organizations ) {
final SearchAllIamPoliciesRequest request = SearchAllIamPoliciesRequest.newBuilder()
.setScope( organization.getName() )
.build();
final AssetServiceClient.SearchAllIamPoliciesPagedResponse response = client.searchAllIamPolicies( request );
for ( IamPolicySearchResult instance : response.iterateAll() ) {
list.add( instance );
}
}
}
catch (PermissionDeniedException e) {
if ( "SERVICE_DISABLED".equals( e.getErrorDetails().getErrorInfo().getReason() ) ) {
// Ignore this exception, since there are no resources
continue;
}
throw e;
}
}
}
return list;
}
catch (IOException e) {
throw new DataFetcherException( "Could not fetch policy list", e );
}
}
@Override
public DataFormat getDataFormat() {
return DataFormats.beansConvention( IamPolicySearchResult.class, GcpConventionContext.INSTANCE );
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy