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

org.cloudfoundry.identity.uaa.oauth.openid.IdToken Maven / Gradle / Ivy

The newest version!
package org.cloudfoundry.identity.uaa.oauth.openid;

import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.google.common.collect.ImmutableList;
import org.cloudfoundry.identity.uaa.oauth.AuthTimeDateConverter;

import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;

import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.ACR;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.AUTH_TIME;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.CID;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.CLIENT_ID;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.EMAIL_VERIFIED;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.EXP;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.FAMILY_NAME;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.GIVEN_NAME;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.GRANT_TYPE;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.IAT;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.PHONE_NUMBER;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.PREVIOUS_LOGON_TIME;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.REVOCATION_SIGNATURE;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.USER_ATTRIBUTES;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.USER_ID;
import static org.cloudfoundry.identity.uaa.oauth.token.ClaimConstants.USER_NAME;

@JsonInclude(JsonInclude.Include.NON_NULL)
public class IdToken {
    public static final String ACR_VALUES_KEY = "values";
    public final String sub;
    public final List aud;
    public final String iss;
    public final Date exp;
    public final Date iat;
    @JsonIgnore
    public final Date authTime;
    public final Set amr;
    public final Set acr;
    public final String azp;
    @JsonProperty(GIVEN_NAME)
    public final String givenName;
    @JsonProperty(FAMILY_NAME)
    public final String familyName;
    @JsonProperty(PREVIOUS_LOGON_TIME)
    public final Long previousLogonTime;
    @JsonProperty(PHONE_NUMBER)
    public final String phoneNumber;
    public final Set roles;
    @JsonProperty(USER_ATTRIBUTES)
    public final Map> userAttributes;
    public final List scope = ImmutableList.of("openid");
    @JsonProperty(EMAIL_VERIFIED)
    public final Boolean emailVerified;
    public final String nonce;
    public final String email;
    @JsonProperty(CID)
    public final String clientId;
    @JsonProperty(GRANT_TYPE)
    public final String grantType;
    @JsonProperty(USER_NAME)
    public final String userName;
    public final String zid;
    public final String origin;
    public final String jti;
    @JsonProperty(REVOCATION_SIGNATURE)
    public final String revSig;

    public IdToken(String sub,
                   List aud,
                   String iss,
                   Date exp,
                   Date iat,
                   Date authTime,
                   Set amr,
                   Set acr,
                   String azp,
                   String givenName,
                   String familyName,
                   Long previousLogonTime,
                   String phoneNumber,
                   Set roles,
                   Map> userAttributes,
                   Boolean emailVerified,
                   String nonce,
                   String email,
                   String clientId,
                   String grantType,
                   String userName,
                   String zid,
                   String origin,
                   String jti,
                   String revSig) {
        this.sub = sub;
        this.aud = aud;
        this.iss = iss;
        this.exp = exp;
        this.iat = iat;
        this.authTime = authTime;
        this.amr = amr;
        this.acr = acr;
        this.azp = azp;
        this.givenName = givenName;
        this.familyName = familyName;
        this.previousLogonTime = previousLogonTime;
        this.phoneNumber = phoneNumber;
        this.roles = roles;
        this.userAttributes = userAttributes;
        this.emailVerified = emailVerified;
        this.nonce = nonce;
        this.email = email;
        this.clientId = clientId;
        this.grantType = grantType;
        this.userName = userName;
        this.zid = zid;
        this.origin = origin;
        this.jti = jti;
        this.revSig = revSig;
    }

    @JsonProperty(ACR)
    public Map> getAcr() {
        if (acr == null) {
            return null;
        }
        HashMap> acrMap = new HashMap<>();
        acrMap.put(ACR_VALUES_KEY, acr);
        return acrMap;
    }

    @JsonProperty(CLIENT_ID)
    public String getClientId() {
        return clientId;
    }

    @JsonProperty(EXP)
    public Long getExpInSeconds() {
        return exp.getTime() / 1000;
    }

    @JsonProperty(IAT)
    public Long getIatInSeconds() {
        return iat.getTime() / 1000;
    }

    @JsonProperty(AUTH_TIME)
    public Long getAuthTimeInSeconds() {
        return AuthTimeDateConverter.dateToAuthTime(authTime);
    }

    @JsonProperty(USER_ID)
    public String userId() {
        return sub;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy