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

com.ibm.cloud.objectstorage.auth.JsonFileCredentialsProvider 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.13.4
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.ibm.cloud.objectstorage.auth;

import com.ibm.cloud.objectstorage.SdkClientException;
import com.ibm.cloud.objectstorage.oauth.DefaultTokenManager;
import com.ibm.cloud.objectstorage.oauth.TokenManager;

import java.io.File;
import java.io.IOException;

/**
 * {@link AWSCredentialsProvider} implementation that loads IBM security
 * credentials from a json file provided on initialization.
 * 

* The IBM API key is expected to be in the apiKey * property and the IBM resource instance id is expected to be in the * resource_instance_id property. */ public class JsonFileCredentialsProvider implements AWSCredentialsProvider { private final String credentialsFilePath; private TokenManager tokenManager = null; /** * Creates a new PropertiesFileCredentialsProvider that will attempt to load * a custom file from the path specified to read IBM security credentials. * * @param credentialsFilePath * The custom classpath resource path to a json file from * which the IBM security credentials should be loaded. * * For example, *

    *
  • /etc/somewhere/cos_credentials
  • *
*/ public JsonFileCredentialsProvider(String credentialsFilePath) { if (credentialsFilePath == null) throw new IllegalArgumentException( "Credentials file path cannot be null"); this.credentialsFilePath = credentialsFilePath; } public AWSCredentials getCredentials() { try { JsonCredentials credentials = new JsonCredentials(new File(this.credentialsFilePath)); if(credentials.getApiKey() != null && tokenManager == null){ tokenManager = new DefaultTokenManager(credentials.getApiKey()); } credentials.setTokenManager(tokenManager); return credentials; } catch (IOException e) { throw new SdkClientException( "Unable to load IBM credentials from the " + credentialsFilePath + " file", e); } } public void refresh() { } @Override public String toString() { return getClass().getSimpleName() + "(" + credentialsFilePath + ")"; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy