AccessPoemException.java
/*
* $Source$
* $Revision$
*
* Copyright (C) 2000 William Chesters
*
* Part of Melati (http://melati.org), a framework for the rapid
* development of clean, maintainable web applications.
*
* Melati is free software; Permission is granted to copy, distribute
* and/or modify this software under the terms either:
*
* a) the GNU General Public License as published by the Free Software
* Foundation; either version 2 of the License, or (at your option)
* any later version,
*
* or
*
* b) any version of the Melati Software License, as published
* at http://melati.org
*
* You should have received a copy of the GNU General Public License and
* the Melati Software License along with this program;
* if not, write to the Free Software Foundation, Inc.,
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA to obtain the
* GNU General Public License and visit http://melati.org to obtain the
* Melati Software License.
*
* Feel free to contact the Developers of Melati (http://melati.org),
* if you would like to work out a different arrangement than the options
* outlined here. It is our intention to allow Melati to be used by as
* wide an audience as possible.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* Contact details for copyright holder:
*
* William Chesters <williamc At paneris.org>
* http://paneris.org/~williamc
* Obrechtstraat 114, 2517VX Den Haag, The Netherlands
*/
package org.melati.poem;
/**
* Thrown when an authorisation problem occurs, that is when
* a {@link User} does not have the required {@link Capability}
* or is not in a {@link Group} with the required {@link Capability}
* to access a restricted object.
*/
public class AccessPoemException extends PoemException {
private static final long serialVersionUID = 1L;
/** The User's Token. */
public AccessToken token;
/** The required Capability. */
public Capability capability;
// This is required to report the exception outside of a session.
private String capabilityString;
public AccessPoemException(Exception problem,
AccessToken token, Capability capability) {
super(problem);
this.token = token;
this.capability = capability;
this.capabilityString = (capability == null ?
null : capability.toString());
}
public AccessPoemException(AccessToken token, Capability capability) {
this(null, token, capability);
}
public AccessPoemException(AccessPoemException e) {
this(e, e.token, e.capability);
}
public AccessPoemException() {
this(null, null);
}
/** @return null */
public String getActionDescription() {
return null;
}
/** @return The detail message */
public String getMessage() {
String ad = getActionDescription();
// Not sure what the rules are here.
if (capability != null && PoemThread.inSession()) {
capabilityString = capability.toString();
}
return
"You need the capability " + capabilityString +
(ad == null ? "" : " to " + ad) + " but your access token " +
token + " doesn't confer it";
}
/** @return the AccessToken */
public AccessToken getToken() {
return token;
}
}