org.apache.shindig.auth.BlobCrypterSecurityToken Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of shindig-common Show documentation
Show all versions of shindig-common Show documentation
Common java code for Shindig
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.shindig.auth;
import java.util.EnumSet;
import java.util.Map;
/**
* Authentication based on a provided BlobCrypter.
*
* Wire format is "<container>:<encrypted-and-signed-token>"
*
* Container is included so different containers can use different security tokens if necessary.
*/
public class BlobCrypterSecurityToken extends AbstractSecurityToken {
private static final EnumSet MAP_KEYS = EnumSet.of(
Keys.OWNER, Keys.VIEWER, Keys.APP_URL, Keys.MODULE_ID, Keys.EXPIRES, Keys.TRUSTED_JSON
);
/**
* Create a new security token.
*
* @param container container that is issuing the token
* @param domain domain to use for signed fetch with default signed fetch key.
* @param activeUrl
* @param values Other values to init into the token.
*/
public BlobCrypterSecurityToken(String container, String domain, String activeUrl, Map values) {
if (values != null) {
loadFromMap(values);
}
setContainer(container).setDomain(domain).setActiveUrl(activeUrl);
}
// Our tokens are static, we could change this to periodically update the token.
public String getUpdatedToken() {
return null;
}
public String getAuthenticationMode() {
return AuthenticationMode.SECURITY_TOKEN_URL_PARAMETER.name();
}
public boolean isAnonymous() {
return false;
}
public String getActiveUrl() {
String activeUrl = super.getActiveUrl();
if (activeUrl == null) {
throw new UnsupportedOperationException("No active URL available");
}
return activeUrl;
}
// Legacy value for signed fetch, opensocial 0.8 prefers opensocial_app_url
@Override
public String getAppId() {
return getAppUrl();
}
protected EnumSet getMapKeys() {
return MAP_KEYS;
}
public static BlobCrypterSecurityToken fromToken(SecurityToken token) {
String activeUrl = null;
try {
activeUrl = token.getActiveUrl();
} catch (UnsupportedOperationException e) {}
BlobCrypterSecurityToken interpretedToken = new BlobCrypterSecurityToken(
token.getContainer(), token.getDomain(), activeUrl, null);
interpretedToken
.setAppId(token.getAppId())
.setAppUrl(token.getAppUrl())
.setExpiresAt(token.getExpiresAt())
.setModuleId(token.getModuleId())
.setOwnerId(token.getOwnerId())
.setTrustedJson(token.getTrustedJson())
.setViewerId(token.getViewerId());
return interpretedToken;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy