/**
* Copyright 2005-2014 Restlet
*
* The contents of this file are subject to the terms of one of the following
* open source licenses: Apache 2.0 or or EPL 1.0 (the "Licenses"). You can
* select the license that you prefer but you may not use this file except in
* compliance with one of these Licenses.
*
* You can obtain a copy of the Apache 2.0 license at
* http://www.opensource.org/licenses/apache-2.0
*
* You can obtain a copy of the EPL 1.0 license at
* http://www.opensource.org/licenses/eclipse-1.0
*
* See the Licenses for the specific language governing permissions and
* limitations under the Licenses.
*
* Alternatively, you can obtain a royalty free commercial license with less
* limitations, transferable or non-transferable, directly at
* http://restlet.com/products/restlet-framework
*
* Restlet is a registered trademark of Restlet S.A.S.
*/
package org.restlet.ext.oauth.internal;
import java.util.Map;
import org.restlet.ext.oauth.GrantType;
import org.restlet.ext.oauth.ResponseType;
/**
* A POJO representing a OAuth client_id. Each client can have collected a
* number of authenticated users to allow working on their behalf.
*
* Implementors should implement the storage and retrieval.
*
* @author Kristoffer Gronowski
* @author Shotaro Uchida <fantom@xmaker.mx>
*/
public interface Client {
public static enum ClientType {
CONFIDENTIAL, PUBLIC
}
public static final String PROPERTY_APPLICATION_NAME = "application_name";
public static final String PROPERTY_DESCRIPTION = "description";
public static final String PROPERTY_SUPPORTED_FLOWS = "supported_flows";
/**
* Client id that the client has registered at the auth provider.
*
* @return the stored client id
*/
public String getClientId();
/**
* Client secret that the client has registered at the auth provider.
*
* @return the stored client secret
*/
public char[] getClientSecret();
public ClientType getClientType();
public Map<String, Object> getProperties();
/**
* Redirect URL that the client has registered at the auth provider.
*
* @return redirect callback url for code and token flows.
*/
public String[] getRedirectURIs();
public boolean isGrantTypeAllowed(GrantType grantType);
public boolean isResponseTypeAllowed(ResponseType responseType);
}