| /* |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You 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 org.apache.jackrabbit.api.security.authentication.token; |
| |
| import javax.jcr.Credentials; |
| import java.util.HashMap; |
| |
| /** |
| * <code>TokenCredentials</code> implements the <code>Credentials</code> |
| * interface and represents single token credentials. Similar to |
| * {@link javax.jcr.SimpleCredentials} this credentials implementation allows |
| * to set additional attributes. |
| */ |
| public final class TokenCredentials implements Credentials { |
| |
| private final String token; |
| private final HashMap<String, String> attributes = new HashMap<String, String>(); |
| |
| /** |
| * Create a new instance. |
| * |
| * @param token A token string used to create this credentials instance. |
| * @throws IllegalArgumentException If the specified token is <code>null</code> |
| * or empty string. |
| */ |
| public TokenCredentials(String token) throws IllegalArgumentException { |
| if (token == null || token.length() == 0) { |
| throw new IllegalArgumentException("Invalid token '" + token + "'"); |
| } |
| this.token = token; |
| } |
| |
| /** |
| * Returns the token this credentials are built from. |
| * |
| * @return the token. |
| */ |
| public String getToken() { |
| return token; |
| } |
| |
| /** |
| * Stores an attribute in this credentials instance. |
| * |
| * @param name a <code>String</code> specifying the name of the attribute |
| * @param value the <code>Object</code> to be stored |
| */ |
| public void setAttribute(String name, String value) { |
| // name cannot be null |
| if (name == null) { |
| throw new IllegalArgumentException("name cannot be null"); |
| } |
| |
| // null value is the same as removeAttribute() |
| if (value == null) { |
| removeAttribute(name); |
| return; |
| } |
| |
| synchronized (attributes) { |
| attributes.put(name, value); |
| } |
| } |
| |
| /** |
| * Returns the value of the named attribute as an <code>Object</code>, or |
| * <code>null</code> if no attribute of the given name exists. |
| * |
| * @param name a <code>String</code> specifying the name of the attribute |
| * @return an <code>Object</code> containing the value of the attribute, or |
| * <code>null</code> if the attribute does not exist |
| */ |
| public String getAttribute(String name) { |
| synchronized (attributes) { |
| return (attributes.get(name)); |
| } |
| } |
| |
| /** |
| * Removes an attribute from this credentials instance. |
| * |
| * @param name a <code>String</code> specifying the name of the attribute to |
| * remove |
| */ |
| public void removeAttribute(String name) { |
| synchronized (attributes) { |
| attributes.remove(name); |
| } |
| } |
| |
| /** |
| * Returns the names of the attributes available to this credentials |
| * instance. This method returns an empty array if the credentials instance |
| * has no attributes available to it. |
| * |
| * @return a string array containing the names of the stored attributes |
| */ |
| public String[] getAttributeNames() { |
| synchronized (attributes) { |
| return attributes.keySet().toArray(new String[attributes.keySet().size()]); |
| } |
| } |
| } |