Java tutorial
/** * personium.io * Copyright 2014 FUJITSU LIMITED * * 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.fujitsu.dc.common.auth.token; import java.net.MalformedURLException; import java.util.List; import java.util.UUID; import org.apache.commons.lang.StringUtils; import org.joda.time.DateTime; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * TransCellToken??????????. ??. ???RefreshToken???Cell??????????? * ??????????Cell???????? ???????????? */ public final class TransCellRefreshToken extends LocalToken implements IRefreshToken, IExtRoleContainingToken { /** * . */ static Logger log = LoggerFactory.getLogger(TransCellRefreshToken.class); /** * ????. */ public static final String PREFIX_TC_REFRESH = "RT~"; /** * ?. */ public static final int REFRESH_TOKEN_EXPIRES_HOUR = 24; String id; String originalIssuer; /** * ?????. * @param id ??? * @param issuedAt (epoch??) * @param lifespan () * @param issuer URL * @param subject URL * @param origIssuer ??RefreshToken??????TransCell ? * @param origRoleList ??RefreshToken??????TransCell ??? * @param schema ??? */ public TransCellRefreshToken(final String id, final long issuedAt, final long lifespan, final String issuer, final String subject, final String origIssuer, final List<Role> origRoleList, final String schema) { super(issuedAt, lifespan, issuer, subject, schema); this.id = id; this.originalIssuer = origIssuer; this.roleList = origRoleList; } /** * ?????. * @param id ??? * @param issuedAt (epoch??) * @param issuer URL * @param subject URL * @param origIssuer ??RefreshToken??????TransCell ? * @param origRoleList ??RefreshToken??????TransCell ??? * @param schema ??? */ public TransCellRefreshToken(final String id, final long issuedAt, final String issuer, final String subject, final String origIssuer, final List<Role> origRoleList, final String schema) { this(id, issuedAt, REFRESH_TOKEN_EXPIRES_HOUR * MILLISECS_IN_AN_HOUR, issuer, subject, origIssuer, origRoleList, schema); } /** * ?????. * @param id ??? * @param issuer URL * @param subject URL * @param origIssuer ??RefreshToken??????TransCell ? * @param origRoleList ??RefreshToken??????TransCell ??? * @param schema ??? */ public TransCellRefreshToken(final String id, final String issuer, final String subject, final String origIssuer, final List<Role> origRoleList, final String schema) { this(id, new DateTime().getMillis(), issuer, subject, origIssuer, origRoleList, schema); } @Override public String toTokenString() { StringBuilder ret = new StringBuilder(PREFIX_TC_REFRESH); String[] items = new String[] { this.id, this.originalIssuer, this.makeRolesString() }; ret.append(this.doCreateTokenString(items)); return ret.toString(); } static final int IDX_COUNT = 8; static final int IDX_ID = 4; static final int IDX_ISSUED_AT = 0; static final int IDX_LIFESPAN = 1; static final int IDX_ISSUER = 7; static final int IDX_SUBJECT = 2; static final int IDX_ORIG_ISSUER = 5; static final int IDX_ORIG_ROLE_LIST = 6; static final int IDX_SCHEMA = 3; /** * issuer???Cell????. * @param token Token String * @param issuer Cell Root URL * @return ??CellLocalToken * @throws AbstractOAuth2Token.TokenParseException ???????? */ public static TransCellRefreshToken parse(final String token, final String issuer) throws AbstractOAuth2Token.TokenParseException { if (!token.startsWith(PREFIX_TC_REFRESH) || issuer == null) { throw AbstractOAuth2Token.PARSE_EXCEPTION; } String[] frag = LocalToken.doParse(token.substring(PREFIX_TC_REFRESH.length()), issuer, IDX_COUNT); try { TransCellRefreshToken ret = new TransCellRefreshToken(frag[IDX_ID], Long.valueOf(StringUtils.reverse(frag[IDX_ISSUED_AT])), Long.valueOf(frag[IDX_LIFESPAN]), frag[IDX_ISSUER], frag[IDX_SUBJECT], frag[IDX_ORIG_ISSUER], AbstractOAuth2Token.parseRolesString(frag[IDX_ORIG_ROLE_LIST]), frag[IDX_SCHEMA]); return ret; } catch (MalformedURLException e) { throw AbstractOAuth2Token.PARSE_EXCEPTION; } catch (IllegalStateException e) { throw AbstractOAuth2Token.PARSE_EXCEPTION; } } @Override public String getId() { return this.id; } @Override public IAccessToken refreshAccessToken(final long issuedAt, final String target, String url, List<Role> role) { if (target == null) { return new CellLocalAccessToken(issuedAt, url, this.getSubject(), role, this.getSchema()); } else { return new TransCellAccessToken(issuedAt, url, this.getSubject(), target, role, this.getSchema()); } } @Override public IRefreshToken refreshRefreshToken(final long issuedAt) { // TODO ? ROLE??????? return new TransCellRefreshToken(UUID.randomUUID().toString(), issuedAt, this.issuer, this.subject, this.originalIssuer, this.getRoles(), this.schema); } @Override public String getTarget() { return null; } @Override public String getExtCellUrl() { return this.originalIssuer; } @Override public List<Role> getRoleList() { return this.getRoles(); } }