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

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

Go to download

Google OAuth Client Library for Java. Functionality that works on all supported Java platforms, including Java 5 (or higher) desktop (SE) and web (EE), Android, and Google App Engine.

There is a newer version: 1.37.0
Show newest version
/*
 * 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.HttpExecuteInterceptor;
import com.google.api.client.http.HttpRequest;
import com.google.api.client.http.HttpRequestInitializer;
import com.google.api.client.http.UrlEncodedContent;
import com.google.api.client.util.Data;
import com.google.api.client.util.Preconditions;
import java.io.IOException;
import java.util.Map;

/**
 * Client credentials specified as URL-encoded parameters in the HTTP request body as specified in
 * Client Password
 *
 * 

This implementation assumes that the {@link HttpRequest#getContent()} is {@code null} or an * instance of {@link UrlEncodedContent}. This is used as the client authentication in {@link * TokenRequest#setClientAuthentication(HttpExecuteInterceptor)}. * *

Sample usage: * *

 * static void requestAccessToken() throws IOException {
 * try {
 * TokenResponse response = new AuthorizationCodeTokenRequest(new NetHttpTransport(),
 * new JacksonFactory(), new GenericUrl("https://server.example.com/token"),
 * "SplxlOBeZQQYbYS6WxSbIA").setRedirectUri("https://client.example.com/rd")
 * .setClientAuthentication(
 * new ClientParametersAuthentication("s6BhdRkqt3", "7Fjfp0ZBr1KtDRbnfVdmIw")).execute();
 * System.out.println("Access token: " + response.getAccessToken());
 * } catch (TokenResponseException e) {
 * if (e.getDetails() != null) {
 * System.err.println("Error: " + e.getDetails().getError());
 * if (e.getDetails().getErrorDescription() != null) {
 * System.err.println(e.getDetails().getErrorDescription());
 * }
 * if (e.getDetails().getErrorUri() != null) {
 * System.err.println(e.getDetails().getErrorUri());
 * }
 * } else {
 * System.err.println(e.getMessage());
 * }
 * }
 * }
 * 
* *

Implementation is immutable and thread-safe. * * @since 1.7 * @author Yaniv Inbar */ public class ClientParametersAuthentication implements HttpRequestInitializer, HttpExecuteInterceptor { /** Client identifier issued to the client during the registration process. */ private final String clientId; /** Client secret or {@code null} for none. */ private final String clientSecret; /** * @param clientId client identifier issued to the client during the registration process * @param clientSecret client secret or {@code null} for none */ public ClientParametersAuthentication(String clientId, String clientSecret) { this.clientId = Preconditions.checkNotNull(clientId); this.clientSecret = clientSecret; } public void initialize(HttpRequest request) throws IOException { request.setInterceptor(this); } public void intercept(HttpRequest request) throws IOException { Map data = Data.mapOf(UrlEncodedContent.getContent(request).getData()); data.put("client_id", clientId); if (clientSecret != null) { data.put("client_secret", clientSecret); } } /** Returns the client identifier issued to the client during the registration process. */ public final String getClientId() { return clientId; } /** Returns the client secret or {@code null} for none. */ public final String getClientSecret() { return clientSecret; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy