Files
alfresco-community-repo/source/java/org/alfresco/repo/oauth2/OAuth2CredentialsStoreServiceImpl.java
Alan Davis 91eb2644ad Merged 5.2.N (5.2.1) to HEAD (5.2)
125781 rmunteanu: Merged 5.1.N (5.1.2) to 5.2.N (5.2.1)
      125603 rmunteanu: Merged 5.1.1 (5.1.1) to 5.1.N (5.1.2)
         125484 slanglois: MNT-16155 Update source headers - remove old Copyrights from Java and JSP dource files


git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@127808 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
2016-06-03 16:40:56 +00:00

278 lines
9.7 KiB
Java

package org.alfresco.repo.oauth2;
import java.util.Date;
import java.util.List;
import org.alfresco.error.AlfrescoRuntimeException;
import org.alfresco.query.CannedQueryPageDetails;
import org.alfresco.query.PagingRequest;
import org.alfresco.query.PagingResults;
import org.alfresco.repo.remotecredentials.OAuth2CredentialsInfoImpl;
import org.alfresco.repo.remotecredentials.RemoteCredentialsModel;
import org.alfresco.service.cmr.oauth2.OAuth2CredentialsStoreService;
import org.alfresco.service.cmr.remotecredentials.OAuth2CredentialsInfo;
import org.alfresco.service.cmr.remotecredentials.RemoteCredentialsService;
import org.alfresco.service.cmr.remoteticket.NoSuchSystemException;
/**
* @author Jared Ottley
*/
public class OAuth2CredentialsStoreServiceImpl implements OAuth2CredentialsStoreService
{
private RemoteCredentialsService remoteCredentialsService;
public void setRemoteCredentialsService(RemoteCredentialsService remoteCredentialsService)
{
this.remoteCredentialsService = remoteCredentialsService;
}
/**
* Add or Update OAuth2 Credentials for the current user to the OAuth2
* Credential Store
*
* @param remoteSystemId String
* @param accessToken String
* @param refreshToken String
* @param expiresAt Date
* @param issuedAt if null, the current Datetime will be used
* @return OAuth2CredentialsInfo
*/
@Override
public OAuth2CredentialsInfo storePersonalOAuth2Credentials(String remoteSystemId,
String accessToken, String refreshToken, Date expiresAt, Date issuedAt)
throws NoSuchSystemException
{
OAuth2CredentialsInfo credentials = buildPersonalOAuth2CredentialsInfo(remoteSystemId,
accessToken, refreshToken, expiresAt, issuedAt);
if (credentials.getNodeRef() != null)
{
return (OAuth2CredentialsInfo) remoteCredentialsService.updateCredentials(credentials);
}
else
{
return (OAuth2CredentialsInfo) remoteCredentialsService.createPersonCredentials(
remoteSystemId, credentials);
}
}
/**
* Add Shared OAuth2 Credentials to the OAuth2 Credential Store
*
* @param remoteSystemId String
* @param accessToken String
* @param refreshToken String
* @param expiresAt Date
* @param issuedAt Date
* @return OAuth2CredentialsInfo
*/
@Override
public OAuth2CredentialsInfo storeSharedOAuth2Credentials(String remoteSystemId,
String accessToken, String refreshToken, Date expiresAt, Date issuedAt)
throws NoSuchSystemException
{
OAuth2CredentialsInfo credentials = buildSharedOAuth2CredentialsInfo(remoteSystemId,
accessToken, refreshToken, expiresAt, issuedAt);
return (OAuth2CredentialsInfo) remoteCredentialsService.createSharedCredentials(
remoteSystemId, credentials);
}
/**
* @param exisitingCredentials OAuth2CredentialsInfo
* @param remoteSystemId String
* @param accessToken String
* @param refreshToken String
* @param expiresAt Date
* @param issuedAt Date
* @return OAuth2CredentialsInfo
*/
@Override
public OAuth2CredentialsInfo updateSharedOAuth2Credentials(
OAuth2CredentialsInfo exisitingCredentials, String remoteSystemId,
String accessToken, String refreshToken, Date expiresAt, Date issuedAt)
throws NoSuchSystemException
{
List<OAuth2CredentialsInfo> shared = listSharedOAuth2Credentials(remoteSystemId);
for (OAuth2CredentialsInfo credential : shared)
{
if (credential.getNodeRef().equals(exisitingCredentials.getNodeRef()))
{
OAuth2CredentialsInfoImpl credentials = new OAuth2CredentialsInfoImpl(
exisitingCredentials.getNodeRef(),
exisitingCredentials.getRemoteSystemName(),
exisitingCredentials.getRemoteSystemContainerNodeRef());
credentials.setOauthAccessToken(accessToken);
credentials.setOauthRefreshToken(refreshToken);
credentials.setOauthTokenExpiresAt(expiresAt);
if (issuedAt != null)
{
credentials.setOauthTokenIssuedAt(issuedAt);
}
else
{
credentials.setOauthTokenIssuedAt(new Date());
}
return (OAuth2CredentialsInfo) remoteCredentialsService
.updateCredentials(credentials);
}
}
throw new AlfrescoRuntimeException(
"Cannot update Credentials which haven't been persisted yet!");
}
/**
* @param remoteSystemId String
* @param accessToken String
* @param refreshToken String
* @param expiresAt Date
* @param issuedAt Date
* @return OAuth2CredentialsInfo
*/
private OAuth2CredentialsInfo buildPersonalOAuth2CredentialsInfo(String remoteSystemId,
String accessToken, String refreshToken, Date expiresAt, Date issuedAt)
{
OAuth2CredentialsInfoImpl credentials = new OAuth2CredentialsInfoImpl();
OAuth2CredentialsInfoImpl existing = (OAuth2CredentialsInfoImpl) getPersonalOAuth2Credentials(remoteSystemId);
if (existing != null)
{
credentials = existing;
}
credentials.setOauthAccessToken(accessToken);
credentials.setOauthRefreshToken(refreshToken);
credentials.setOauthTokenExpiresAt(expiresAt);
if (issuedAt != null)
{
credentials.setOauthTokenIssuedAt(issuedAt);
}
else
{
credentials.setOauthTokenIssuedAt(new Date());
}
return credentials;
}
/**
* @param remoteSystemId String
* @param accessToken String
* @param refreshToken String
* @param expiresAt Date
* @param issuedAt Date
* @return OAuth2CredentialsInfo
*/
private OAuth2CredentialsInfo buildSharedOAuth2CredentialsInfo(String remoteSystemId,
String accessToken, String refreshToken, Date expiresAt, Date issuedAt)
{
OAuth2CredentialsInfoImpl credentials = new OAuth2CredentialsInfoImpl();
credentials.setOauthAccessToken(accessToken);
credentials.setOauthRefreshToken(refreshToken);
credentials.setOauthTokenExpiresAt(expiresAt);
if (issuedAt != null)
{
credentials.setOauthTokenIssuedAt(issuedAt);
}
else
{
credentials.setOauthTokenIssuedAt(new Date());
}
return credentials;
}
/**
* Get the current users OAuth2Credentials for the remote systems
*
* @param remoteSystemId String
* @return OAuth2CredentialsInfo
*/
@Override
public OAuth2CredentialsInfo getPersonalOAuth2Credentials(String remoteSystemId)
throws NoSuchSystemException
{
return (OAuth2CredentialsInfo) remoteCredentialsService
.getPersonCredentials(remoteSystemId);
}
/**
* @param remoteSystemId String
* @return List<OAuth2CredentialInfo>
*/
@Override
public List<OAuth2CredentialsInfo> listSharedOAuth2Credentials(String remoteSystemId)
throws NoSuchSystemException
{
PagingRequest paging = new PagingRequest(CannedQueryPageDetails.DEFAULT_PAGE_SIZE);
@SuppressWarnings("unchecked")
PagingResults<OAuth2CredentialsInfo> pagingResults = (PagingResults<OAuth2CredentialsInfo>) remoteCredentialsService
.listSharedCredentials(remoteSystemId,
RemoteCredentialsModel.TYPE_OAUTH2_CREDENTIALS, paging);
return pagingResults.getPage();
}
/**
* Delete the current users OAuth2 Credentials for the remote system
*
* @param remoteSystemId String
* @return boolean
*/
@Override
public boolean deletePersonalOAuth2Credentials(String remoteSystemId)
throws NoSuchSystemException
{
OAuth2CredentialsInfo credentials = getPersonalOAuth2Credentials(remoteSystemId);
if (credentials == null) { return false; }
remoteCredentialsService.deleteCredentials(credentials);
return true;
}
@Override
public boolean deleteSharedOAuth2Credentials(String remoteSystemId,
OAuth2CredentialsInfo credentials) throws NoSuchSystemException
{
List<OAuth2CredentialsInfo> shared = listSharedOAuth2Credentials(remoteSystemId);
if (shared.isEmpty()) { return false; }
for (OAuth2CredentialsInfo credential : shared)
{
if (credential.getNodeRef().equals(credentials.getNodeRef()))
{
remoteCredentialsService.deleteCredentials(credential);
}
else
{
return false;
}
}
return true;
}
/**
* @param succeeded boolean
* @param credentials OAuth2CredentialsInfo
* @return OAuth2CredentialsInfo
*/
@Override
public OAuth2CredentialsInfo updateCredentialsAuthenticationSucceeded(boolean succeeded,
OAuth2CredentialsInfo credentials)
{
return (OAuth2CredentialsInfo) remoteCredentialsService
.updateCredentialsAuthenticationSucceeded(succeeded, credentials);
}
}