org.brickred.socialauth.util.OAuthConfig Maven / Gradle / Ivy
/*
===========================================================================
Copyright (c) 2010 BrickRed Technologies Limited
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sub-license, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
===========================================================================
*/
package org.brickred.socialauth.util;
import java.io.Serializable;
import java.util.List;
import java.util.Map;
/**
* It contains the configuration of application like consumer key and consumer
* secret
*
* @author [email protected]
*
*/
public class OAuthConfig implements Serializable {
private static final long serialVersionUID = 7574560869168900919L;
private final String _consumerKey;
private final String _consumerSecret;
private final String _signatureMethod;
private final String _transportName;
private String id;
private Class> providerImplClass;
private String customPermissions;
private String requestTokenUrl;
private String authenticationUrl;
private String accessTokenUrl;
private String[] registeredPlugins;
private List pluginsScopes;
private boolean saveRawResponse;
private Map customProperties;
/**
*
* @param consumerKey
* Application consumer key
* @param consumerSecret
* Application consumer secret
* @param signatureMethod
* Signature Method type
* @param transportName
* Transport name
*/
public OAuthConfig(final String consumerKey, final String consumerSecret,
final String signatureMethod, final String transportName) {
_consumerKey = consumerKey;
_consumerSecret = consumerSecret;
if (signatureMethod == null || signatureMethod.length() == 0) {
_signatureMethod = Constants.HMACSHA1_SIGNATURE;
} else {
_signatureMethod = signatureMethod;
}
if (transportName == null || transportName.length() == 0) {
_transportName = MethodType.GET.toString();
} else {
_transportName = transportName;
}
}
public OAuthConfig(final String consumerKey, final String consumerSecret) {
_consumerKey = consumerKey;
_consumerSecret = consumerSecret;
_transportName = MethodType.GET.toString();
_signatureMethod = Constants.HMACSHA1_SIGNATURE;
}
/**
* Retrieves the consumer key
*
* @return the consumer key
*/
public String get_consumerKey() {
return _consumerKey;
}
/**
* Retrieves the consumer secret
*
* @return the consumer secret
*/
public String get_consumerSecret() {
return _consumerSecret;
}
/**
* Retrieves the signature method
*
* @return the signature method
*/
public String get_signatureMethod() {
return _signatureMethod;
}
/**
* Retrieves the transport name
*
* @return the transport name
*/
public String get_transportName() {
return _transportName;
}
/**
* Retrieves the provider id
*
* @return the provider id
*/
public String getId() {
return id;
}
/**
* Updates the provider id
*
* @param id
* the provider id
*/
public void setId(final String id) {
this.id = id;
}
/**
* Retrieves the provider implementation class
*
* @return the provider implementation class
*/
public Class> getProviderImplClass() {
return providerImplClass;
}
/**
* Updates the provider implementation class
*
* @param providerImplClass
* the provider implementation class
*/
public void setProviderImplClass(final Class> providerImplClass) {
this.providerImplClass = providerImplClass;
}
/**
* Retrieves custom permissions configured in properties file
*
* @return String of custom permissions
*/
public String getCustomPermissions() {
return customPermissions;
}
/**
* Updates custom permissions configured in properties file
*
* @param customPermissions
* String of comma seperated custom permissions
*/
public void setCustomPermissions(final String customPermissions) {
this.customPermissions = customPermissions;
}
/**
* Retrieves the authentication url
*
* @return the authentication url string
*/
public String getAuthenticationUrl() {
return authenticationUrl;
}
/**
* Updates the authentication url
*
* @param authenticationUrl
* the authentication url string
*/
public void setAuthenticationUrl(final String authenticationUrl) {
this.authenticationUrl = authenticationUrl;
}
/**
* Retrieves the access token url
*
* @return the access token url string
*/
public String getAccessTokenUrl() {
return accessTokenUrl;
}
/**
* Updates the access token url
*
* @param accessTokenUrl
* the access token url string
*/
public void setAccessTokenUrl(final String accessTokenUrl) {
this.accessTokenUrl = accessTokenUrl;
}
/**
* Retrieves the request token url
*
* @return the request token url string
*/
public String getRequestTokenUrl() {
return requestTokenUrl;
}
/**
* Updates the request token url
*
* @param requestTokenUrl
* the request token url string
*/
public void setRequestTokenUrl(final String requestTokenUrl) {
this.requestTokenUrl = requestTokenUrl;
}
/**
* Retrieves the registered plugins of a provider configured in properties
* file. String contains the fully qualified plugin class name
*
* @return String array of registered plugins
*/
public String[] getRegisteredPlugins() {
return registeredPlugins;
}
/**
* Updates the registered plugins configured in properties file
*
* @param registeredPlugins
* String array of plugins. String should contain fully qualified
* plugin class name
*/
public void setRegisteredPlugins(final String[] registeredPlugins) {
this.registeredPlugins = registeredPlugins;
}
/**
* Retrieves the list of plugins scopes
*
* @return list of plugins scope
*/
public List getPluginsScopes() {
return pluginsScopes;
}
/**
* Updates the plugins scopes
*
* @param pluginsScopes
* list of plugins scopes
*/
public void setPluginsScopes(final List pluginsScopes) {
this.pluginsScopes = pluginsScopes;
}
/**
* Returns status to save the raw response for profile and contacts. Default
* value is False.
*
* @return True/False to check whether raw response should save or not.
*/
public boolean isSaveRawResponse() {
return saveRawResponse;
}
/**
* Set this flag to True if raw response should be save for profile and
* contacts. Default it is False.
*
* @param saveRawResponse
* flag to config whether raw response should be saved or not.
*/
public void setSaveRawResponse(boolean saveRawResponse) {
this.saveRawResponse = saveRawResponse;
}
/**
* Returns custom properties for the provider
*
* @return map which contains custom properties
*/
public Map getCustomProperties() {
return customProperties;
}
/**
* Updates the custom properties
*
* @param customProperties
* map which store the custom properties required for the
* provider except conumer key, secret and scopes
*/
public void setCustomProperties(Map customProperties) {
this.customProperties = customProperties;
}
@Override
public String toString() {
StringBuilder result = new StringBuilder();
String NEW_LINE = System.getProperty("line.separator");
result.append(this.getClass().getName() + " Object {" + NEW_LINE);
result.append(" consumerKey: " + _consumerKey + NEW_LINE);
result.append(" consumerSecret: " + _consumerSecret + NEW_LINE);
result.append(" signatureMethod: " + _signatureMethod + NEW_LINE);
result.append(" transportName: " + _transportName + NEW_LINE);
result.append(" id: " + id + NEW_LINE);
result.append(" providerImplClass: " + providerImplClass + NEW_LINE);
result.append(" customPermissions: " + customPermissions + NEW_LINE);
result.append(" requestTokenUrl: " + requestTokenUrl + NEW_LINE);
result.append(" authenticationUrl: " + authenticationUrl + NEW_LINE);
result.append(" accessTokenUrl: " + accessTokenUrl + NEW_LINE);
result.append(" registeredPlugins: " + registeredPlugins + NEW_LINE);
result.append(" pluginsScopes: " + pluginsScopes + NEW_LINE);
result.append(" saveRawResponse: " + saveRawResponse + NEW_LINE);
if (customProperties != null) {
result.append(" customProperties: " + customProperties.toString()
+ NEW_LINE);
} else {
result.append(" customProperties: null" + NEW_LINE);
}
result.append("}");
return result.toString();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy