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

com.nimbusds.oauth2.sdk.id.Actor Maven / Gradle / Ivy

Go to download

OAuth 2.0 SDK with OpenID Connection extensions for developing client and server applications.

There is a newer version: 11.20.1
Show newest version
/*
 * 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 java.io.Serializable;
import java.util.Objects;

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;


/**
 * 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) {
		if (subject == null) {
			throw new IllegalArgumentException("The subject must not be null");
		}
		this.subject = 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); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy