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

com.amazonaws.auth.json.JsonConfigFile Maven / Gradle / Ivy

Go to download

A single bundled dependency that includes all service and dependent JARs with third-party libraries relocated to different namespaces.

There is a newer version: 2.14.0
Show newest version
/* 
* Copyright 2017 IBM Corp. 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. 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.amazonaws.auth.json;

import java.io.File;

import com.amazonaws.SdkClientException;
import com.amazonaws.auth.AWSCredentials;
import com.amazonaws.auth.AWSCredentialsProvider;
import com.amazonaws.auth.JsonCredentials;
import com.amazonaws.auth.json.internal.JsonStaticCredentialsProvider;
import com.amazonaws.profile.path.AwsProfileFileLocationProvider;
import com.amazonaws.util.ValidationUtils;
import com.amazonaws.auth.json.BasicJsonConfigLoader;

public class JsonConfigFile {

    private final File credentialFile;
    /**
     * Cache credential provider as credentials are requested.
     */
    private AWSCredentialsProvider credentialProvider;
    private volatile long credentialFileLastModified;
    private volatile JsonCredentials credentials;

    /**
     * Loads the IBM credentials file from the default location (~/.bluemix/cos_credentials) or from
     * an alternate location if IBM_CREDENTIAL_JSON_FILE is set.
     */
    public JsonConfigFile() throws SdkClientException {
        this(getCredentialsJsonFile());
    }

    /**
     * Loads the IBM credentials from the file. The path of the file is specified as a
     * parameter to the constructor.
     */
    public JsonConfigFile(String filePath) {
        this(new File(validateFilePath(filePath)));
    }

    private static String validateFilePath(String filePath) {
        if (filePath == null) {
            throw new IllegalArgumentException(
                    "Unable to load IBM credentials: specified file path is null.");
        }
        return filePath;
    }

    /**
     * Loads the IBM credentials from the file. The reference to the file is specified as a
     * parameter to the constructor.
     */
    public JsonConfigFile(File file) throws SdkClientException {
        credentialFile = ValidationUtils.assertNotNull(file, "IBM credential file");
        credentialFileLastModified = file.lastModified();
        credentials = loadCredentials(file);
    }

    /**
     * Returns the IBM credentials.
     */
    public AWSCredentials getCredentials() {
        if (credentialProvider != null) {
            return credentialProvider.getCredentials();
        } else {
            credentialProvider = new JsonStaticCredentialsProvider(credentials);
            return credentialProvider.getCredentials();
        }
    }

    /**
     * Reread data from disk.
     */
    public void refresh() {
        if (credentialFile.lastModified() > credentialFileLastModified) {
            credentialFileLastModified = credentialFile.lastModified();
            credentials = loadCredentials(credentialFile);
        }
        credentialProvider = new JsonStaticCredentialsProvider(credentials);
    }

    private static File getCredentialsJsonFile() {
        return AwsProfileFileLocationProvider.IBM_CREDENTIALS_LOCATION_PROVIDER.getLocation();
    }
    
    private static JsonCredentials loadCredentials(File file) {
        return BasicJsonConfigLoader.INSTANCE.loadCredentials(file);
    }
  
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy