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

com.google.api.client.auth.oauth2.AuthorizationRequestUrl Maven / Gradle / Ivy

/*
 * Copyright (c) 2011 Google Inc.
 *
 * 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.google.api.client.auth.oauth2;

import com.google.api.client.http.GenericUrl;
import com.google.api.client.util.Joiner;
import com.google.api.client.util.Key;
import com.google.api.client.util.Preconditions;

import java.util.Collection;

/**
 * OAuth 2.0 URL builder for an authorization web page to allow the end user to authorize the
 * application to access their protected resources, as specified in Authorization Endpoint.
 *
 * 

* Sample usage for a web application: *

* *
  public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException {
    String url = new AuthorizationRequestUrl(
        "https://server.example.com/authorize", "s6BhdRkqt3", Arrays.asList("code")).setState("xyz")
        .setRedirectUri("https://client.example.com/rd").build();
    response.sendRedirect(url);
  }
 * 
* *

* Implementation is not thread-safe. *

* * @since 1.7 * @author Yaniv Inbar */ public class AuthorizationRequestUrl extends GenericUrl { /** * Response type, which must be * {@code "code"} for requesting an authorization code, {@code "token"} for requesting an access * token (implicit grant), or space-separated registered extension values. */ @Key("response_type") private String responseTypes; /** * URI that the authorization server directs the resource owner's user-agent back to the client * after a successful authorization grant (as specified in Redirection Endpoint) or * {@code null} for none. */ @Key("redirect_uri") private String redirectUri; /** * Space-separated list of scopes (as specified in Access Token Scope) or {@code null} * for none. */ @Key("scope") private String scopes; /** Client identifier. */ @Key("client_id") private String clientId; /** * State (an opaque value used by the client to maintain state between the request and callback, * as mentioned in Registration * Requirements) or {@code null} for none. */ @Key private String state; /** * @param authorizationServerEncodedUrl authorization server encoded URL * @param clientId client identifier * @param responseTypes response * type, which must be {@code "code"} for requesting an authorization code, * {@code "token"} for requesting an access token (implicit grant), or a list of registered * extension values to join with a space * @since 1.15 */ public AuthorizationRequestUrl( String authorizationServerEncodedUrl, String clientId, Collection responseTypes) { super(authorizationServerEncodedUrl); Preconditions.checkArgument(getFragment() == null); setClientId(clientId); setResponseTypes(responseTypes); } /** * Returns the Response type, which * must be {@code "code"} for requesting an authorization code, {@code "token"} for requesting an * access token (implicit grant), or space-separated registered extension values. */ public final String getResponseTypes() { return responseTypes; } /** * Sets the response type, which * must be {@code "code"} for requesting an authorization code, {@code "token"} for requesting an * access token (implicit grant), or a list of registered extension values to join with a space. * *

* Overriding is only supported for the purpose of calling the super implementation and changing * the return type, but nothing else. *

* * @since 1.15 */ public AuthorizationRequestUrl setResponseTypes(Collection responseTypes) { this.responseTypes = Joiner.on(' ').join(responseTypes); return this; } /** * Returns the URI that the authorization server directs the resource owner's user-agent back to * the client after a successful authorization grant (as specified in Redirection Endpoint) or * {@code null} for none. */ public final String getRedirectUri() { return redirectUri; } /** * Sets the URI that the authorization server directs the resource owner's user-agent back to the * client after a successful authorization grant (as specified in Redirection Endpoint) or * {@code null} for none. * *

* Overriding is only supported for the purpose of calling the super implementation and changing * the return type, but nothing else. *

*/ public AuthorizationRequestUrl setRedirectUri(String redirectUri) { this.redirectUri = redirectUri; return this; } /** * Returns the space-separated list of scopes (as specified in Access Token Scope) or {@code null} * for none. */ public final String getScopes() { return scopes; } /** * Sets the list of scopes (as specified in Access Token Scope) or {@code null} * for none. * *

* Overriding is only supported for the purpose of calling the super implementation and changing * the return type, but nothing else. *

* * @param scopes collection of scopes to be joined by a space separator (or a single value * containing multiple space-separated scopes) or {@code null} for none * @since 1.15 */ public AuthorizationRequestUrl setScopes(Collection scopes) { this.scopes = scopes == null || !scopes.iterator().hasNext() ? null : Joiner.on(' ').join(scopes); return this; } /** Returns the client identifier. */ public final String getClientId() { return clientId; } /** * Sets the client identifier. * *

* Overriding is only supported for the purpose of calling the super implementation and changing * the return type, but nothing else. *

*/ public AuthorizationRequestUrl setClientId(String clientId) { this.clientId = Preconditions.checkNotNull(clientId); return this; } /** * Returns the state (an opaque value used by the client to maintain state between the request and * callback, as mentioned in Registration Requirements) or * {@code null} for none. */ public final String getState() { return state; } /** * Sets the state (an opaque value used by the client to maintain state between the request and * callback, as mentioned in Registration Requirements) or * {@code null} for none. * *

* Overriding is only supported for the purpose of calling the super implementation and changing * the return type, but nothing else. *

*/ public AuthorizationRequestUrl setState(String state) { this.state = state; return this; } @Override public AuthorizationRequestUrl set(String fieldName, Object value) { return (AuthorizationRequestUrl) super.set(fieldName, value); } @Override public AuthorizationRequestUrl clone() { return (AuthorizationRequestUrl) super.clone(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy