blob: a05ca60ae0185faa79d6cd0d49f45fbbe25f8efd [file] [log] [blame]
/*
* #%L
* Apache Geronimo JAX-RS Spec 2.0
* %%
* Copyright (C) 2003 - 2014 The Apache Software Foundation
* %%
* 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.
* #L%
*/
package javax.ws.rs;
import javax.ws.rs.core.Response;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import static javax.ws.rs.core.HttpHeaders.WWW_AUTHENTICATE;
import static javax.ws.rs.core.Response.Status.UNAUTHORIZED;
public class NotAuthorizedException extends ClientErrorException {
private static final long serialVersionUID = -3156040750581929702L;
private transient List<Object> challenges;
public NotAuthorizedException(Object challenge, Object... moreChallenges) {
super(createUnauthorizedResponse(challenge, moreChallenges));
this.challenges = cacheChallenges(challenge, moreChallenges);
}
public NotAuthorizedException(String message, Object challenge, Object... moreChallenges) {
super(message, createUnauthorizedResponse(challenge, moreChallenges));
this.challenges = cacheChallenges(challenge, moreChallenges);
}
public NotAuthorizedException(Response response) {
super(validate(response, UNAUTHORIZED));
}
public NotAuthorizedException(String message, Response response) {
super(message, validate(response, UNAUTHORIZED));
}
public NotAuthorizedException(Throwable cause, Object challenge, Object... moreChallenges) {
super(createUnauthorizedResponse(challenge, moreChallenges), cause);
this.challenges = cacheChallenges(challenge, moreChallenges);
}
public NotAuthorizedException(String message, Throwable cause, Object challenge, Object... moreChallenges) {
super(message, createUnauthorizedResponse(challenge, moreChallenges), cause);
this.challenges = cacheChallenges(challenge, moreChallenges);
}
public NotAuthorizedException(Response response, Throwable cause) {
super(validate(response, UNAUTHORIZED), cause);
}
public NotAuthorizedException(String message, Response response, Throwable cause) {
super(message, validate(response, UNAUTHORIZED), cause);
}
public List<Object> getChallenges() {
if (challenges == null) {
this.challenges = getResponse().getHeaders().get(WWW_AUTHENTICATE);
}
return challenges;
}
private static Response createUnauthorizedResponse(Object challenge, Object[] otherChallenges) {
if (challenge == null) {
throw new NullPointerException("Primary challenge parameter must not be null.");
}
Response.ResponseBuilder builder = Response.status(UNAUTHORIZED).header(WWW_AUTHENTICATE, challenge);
if (otherChallenges != null) {
for (Object oc : otherChallenges) {
builder.header(WWW_AUTHENTICATE, oc);
}
}
return builder.build();
}
private static List<Object> cacheChallenges(Object challenge, Object[] moreChallenges) {
List<Object> temp = new ArrayList<Object>(1 + ((moreChallenges == null) ? 0 : moreChallenges.length));
temp.add(challenge);
if (moreChallenges != null) {
temp.addAll(Arrays.asList(moreChallenges));
}
return Collections.unmodifiableList(temp);
}
}