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

com.amazonaws.auth.InstanceProfileCredentialsProvider Maven / Gradle / Ivy

There is a newer version: 2.0.0
Show newest version
/*
 * Copyright 2012-2022 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License").
 * You may not use this file except in compliance with the License.
 * A copy of the License is located at
 *
 *  http://aws.amazon.com/apache2.0
 *
 * or in the "license" file accompanying this file. This file 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.amazonaws.auth;

import com.amazonaws.AmazonClientException;
import com.amazonaws.SDKGlobalConfiguration;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import java.io.Closeable;
import java.io.IOException;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.TimeUnit;

/**
 * Credentials provider implementation that loads credentials from the Amazon EC2 Instance Metadata Service.
 *
 * 

When using {@link InstanceProfileCredentialsProvider} with asynchronous refreshing it is * strongly recommended to explicitly call {@link #close()} to release the async thread.

*/ public class InstanceProfileCredentialsProvider implements AWSCredentialsProvider, Closeable { private static final Log LOG = LogFactory.getLog(InstanceProfileCredentialsProvider.class); /** * The wait time, after which the background thread initiates a refresh to * load latest credentials if needed. */ private static final int ASYNC_REFRESH_INTERVAL_TIME_MINUTES = 1; /** * The default InstanceProfileCredentialsProvider that can be shared by * multiple CredentialsProvider instance threads to shrink the amount of * requests to EC2 metadata service. */ private static final InstanceProfileCredentialsProvider INSTANCE = new InstanceProfileCredentialsProvider(); private final InstanceMetadataServiceCredentialsFetcher credentialsFetcher; /** * The executor service used for refreshing the credentials in the * background. */ private volatile ScheduledExecutorService executor; private volatile boolean shouldRefresh = false; /** * @deprecated for the singleton method {@link #getInstance()}. */ @Deprecated public InstanceProfileCredentialsProvider() { this(false); } /** * Spins up a new thread to refresh the credentials asynchronously if * refreshCredentialsAsync is set to true, otherwise the credentials will be * refreshed from the instance metadata service synchronously, * *

It is strongly recommended to reuse instances of this credentials provider, especially * when async refreshing is used since a background thread is created.

* * @param refreshCredentialsAsync * true if credentials needs to be refreshed asynchronously else * false. */ public InstanceProfileCredentialsProvider(boolean refreshCredentialsAsync) { this(refreshCredentialsAsync, true); } /** * Spins up a new thread to refresh the credentials asynchronously. * *

It is strongly recommended to reuse instances of this credentials provider, especially * when async refreshing is used since a background thread is created.

* * @param eagerlyRefreshCredentialsAsync * when set to false will not attempt to refresh credentials asynchronously * until after a call has been made to {@link #getCredentials()} - ensures that * {@link ContainerCredentialsFetcher#getCredentials()} is only hit when this CredentialProvider is actually required */ public static InstanceProfileCredentialsProvider createAsyncRefreshingProvider(final boolean eagerlyRefreshCredentialsAsync) { return new InstanceProfileCredentialsProvider(true, eagerlyRefreshCredentialsAsync); } private InstanceProfileCredentialsProvider(boolean refreshCredentialsAsync, final boolean eagerlyRefreshCredentialsAsync) { credentialsFetcher = new InstanceMetadataServiceCredentialsFetcher(); if (!SDKGlobalConfiguration.isEc2MetadataDisabled()) { if (refreshCredentialsAsync) { executor = Executors.newScheduledThreadPool(1, new ThreadFactory() { public Thread newThread(Runnable r) { Thread t = Executors.defaultThreadFactory().newThread(r); t.setName("instance-profile-credentials-refresh"); t.setDaemon(true); return t; } }); executor.scheduleWithFixedDelay(new Runnable() { @Override public void run() { try { if (shouldRefresh) credentialsFetcher.getCredentials(); } catch (AmazonClientException ace) { handleAsyncRefreshError(ace); } catch (RuntimeException re) { handleAsyncRefreshError(re); } } private void handleAsyncRefreshError(Exception e) { LOG.warn("Failed when refreshing credentials asynchronously.", e); } }, 0, ASYNC_REFRESH_INTERVAL_TIME_MINUTES, TimeUnit.MINUTES); } } } /** * Returns a singleton {@link InstanceProfileCredentialsProvider} that does not refresh credentials asynchronously. * *

* See {@link #InstanceProfileCredentialsProvider(boolean)} or {@link #createAsyncRefreshingProvider(boolean)} for * asynchronous credentials refreshing. *

*/ public static InstanceProfileCredentialsProvider getInstance() { return INSTANCE; } @Override protected void finalize() throws Throwable { if (executor != null) { executor.shutdownNow(); } } /** * {@inheritDoc} * * @throws AmazonClientException if {@link SDKGlobalConfiguration#isEc2MetadataDisabled()} is true */ @Override public AWSCredentials getCredentials() { if (SDKGlobalConfiguration.isEc2MetadataDisabled()) { throw new AmazonClientException("AWS_EC2_METADATA_DISABLED is set to true, not loading credentials from EC2 Instance " + "Metadata service"); } AWSCredentials creds = credentialsFetcher.getCredentials(); shouldRefresh = true; return creds; } @Override public void refresh() { if (credentialsFetcher != null) { credentialsFetcher.refresh(); } } @Override public void close() throws IOException { if (executor != null) { executor.shutdownNow(); executor = null; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy