com.nimbusds.oauth2.sdk.id.Actor Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of oauth2-oidc-sdk Show documentation
Show all versions of oauth2-oidc-sdk Show documentation
OAuth 2.0 SDK with OpenID Connection extensions for developing client
and server applications.
/*
* oauth2-oidc-sdk
*
* Copyright 2012-2016, Connect2id Ltd and contributors.
*
* 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.nimbusds.oauth2.sdk.id;
import com.nimbusds.oauth2.sdk.ParseException;
import com.nimbusds.oauth2.sdk.util.JSONObjectUtils;
import net.jcip.annotations.Immutable;
import net.minidev.json.JSONAware;
import net.minidev.json.JSONObject;
import java.io.Serializable;
import java.util.Objects;
/**
* Authorised actor in impersonation and delegation cases.
*/
@Immutable
public final class Actor implements Serializable, Comparable, JSONAware {
private static final long serialVersionUID = 4171395610729169757L;
/**
* The actor subject.
*/
private final Subject subject;
/**
* Optional issuer for the actor subject.
*/
private final Issuer issuer;
/**
* Optional parent for the actor.
*/
private final Actor parent;
/**
* Creates a new actor.
*
* @param subject The subject. Must not be {@code null}.
*/
public Actor(final Subject subject) {
this(subject, null, null);
}
/**
* Creates a new actor.
*
* @param subject The subject. Must not be {@code null}.
* @param issuer Optional issuer for the subject, {@code null} if
* not specified.
* @param parent Optional parent for the actor, {@code null} if none.
*/
public Actor(final Subject subject, final Issuer issuer, final Actor parent) {
this.subject = Objects.requireNonNull(subject);
this.issuer = issuer;
this.parent = parent;
}
/**
* Returns the subject.
*
* @return The subject.
*/
public Subject getSubject() {
return subject;
}
/**
* Returns the optional issuer for the subject.
*
* @return The issuer, {@code null} if not specified.
*/
public Issuer getIssuer() {
return issuer;
}
/**
* Returns the optional parent for this actor.
*
* @return The optional parent for the actor, {@code null} if none.
*/
public Actor getParent() {
return parent;
}
/**
* Returns a JSON object representation of this actor.
*
* Simple example:
*
*
* {
* "sub" : "[email protected]"
* }
*
*
* With nesting:
*
*
* {
* "sub" : "consumer.example.com-web-application",
* "iss" : "https://issuer.example.net",
* "act" : { "sub":"[email protected]" }
* }
*
*
* @return The JSON object.
*/
public JSONObject toJSONObject() {
JSONObject o = new JSONObject();
o.put("sub", subject.getValue());
if (issuer != null) {
o.put("iss", issuer.getValue());
}
if (parent != null) {
o.put("act", parent.toJSONObject());
}
return o;
}
@Override
public int compareTo(final Actor other) {
return toJSONString().compareTo(other.toJSONString());
}
@Override
public String toJSONString() {
return toJSONObject().toJSONString();
}
@Override
public String toString() {
return toJSONString();
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (!(o instanceof Actor)) return false;
Actor actor = (Actor) o;
return getSubject().equals(actor.getSubject()) && Objects.equals(getIssuer(), actor.getIssuer()) && Objects.equals(getParent(), actor.getParent());
}
@Override
public int hashCode() {
return Objects.hash(getSubject(), getIssuer(), getParent());
}
/**
* Parses an actor from the specified JSON object representation.
*
* Simple example:
*
*
* {
* "sub" : "[email protected]"
* }
*
*
* With nesting:
*
*
* {
* "sub" : "consumer.example.com-web-application",
* "iss" : "https://issuer.example.net",
* "act" : { "sub":"[email protected]" }
* }
*
*
* @param jsonObject The JSON object. Must not be {@code null}.
*
* @return The actor.
*
* @throws ParseException If parsing failed.
*/
public static Actor parse(final JSONObject jsonObject)
throws ParseException {
Subject sub = new Subject(JSONObjectUtils.getString(jsonObject, "sub"));
Issuer iss = null;
if (jsonObject.containsKey("iss")) {
iss = new Issuer(JSONObjectUtils.getString(jsonObject, "iss"));
}
Actor parent = parseTopLevel(jsonObject);
return new Actor(sub, iss, parent);
}
/**
* Parses an actor from the specified top-level JSON object contains
* an optional actor JSON representation.
*
* Simple example:
*
*
* {
* "aud" : "https://consumer.example.com",
* "iss" : "https://issuer.example.com",
* "exp" : 1443904177,
* "nbf" : 1443904077,
* "sub" : "[email protected]",
* "act" : { "sub" : "[email protected]" }
* }
*
*
* With nesting:
*
*
* {
* "aud" : "https://backend.example.com",
* "iss" : "https://issuer.example.com",
* "exp" : 1443904100,
* "nbf" : 1443904000,
* "sub" : "[email protected]",
* "act" : { "sub" : "consumer.example.com-web-application",
* "iss" : "https://issuer.example.net",
* "act" : { "sub":"[email protected]" } }
* }
*
*
* @param jsonObject The top-level JSON object to parse. Must not be
* {@code null}.
*
* @return The actor, {@code null} if not specified.
*
* @throws ParseException If parsing failed.
*/
public static Actor parseTopLevel(final JSONObject jsonObject)
throws ParseException {
JSONObject actSpec = JSONObjectUtils.getJSONObject(jsonObject, "act", null);
if (actSpec == null) return null;
return parse(actSpec);
}
}