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

com.google.api.client.googleapis.json.GoogleApi Maven / Gradle / Ivy

/*
 * Copyright (c) 2010 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.googleapis.json;

import com.google.api.client.escape.CharEscapers;
import com.google.api.client.googleapis.GoogleTransport;
import com.google.api.client.googleapis.json.DiscoveryDocument.ServiceDefinition;
import com.google.api.client.googleapis.json.DiscoveryDocument.ServiceMethod;
import com.google.api.client.http.GenericUrl;
import com.google.api.client.http.HttpRequest;
import com.google.api.client.http.HttpTransport;
import com.google.api.client.repackaged.com.google.common.base.Preconditions;
import com.google.api.client.util.DataUtil;

import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

/**
 * Manages HTTP requests for a version of a Google API service with a simple
 * interface based on the new experimental Discovery API.
 *
 * @since 1.1
 * @author Yaniv Inbar
 */
public final class GoogleApi {

  /**
   * (Required) Name of the Google API, for example buzz.
   */
  public String name;

  /**
   * (Required) Version of the Google API, for example v1.
   */
  public String version;

  /**
   * HTTP transport required for building requests in
   * {@link #buildRequest(String, Object)}.
   * 

* It is initialized using {@link GoogleTransport#create()}. */ public HttpTransport transport = GoogleTransport.create(); /** * Service definition, normally set by {@link #load()}. */ public ServiceDefinition serviceDefinition; /** * Forces the discovery document to be loaded, even if the service definition * has already been loaded. */ public void load() throws IOException { DiscoveryDocument doc = DiscoveryDocument.load(this.name); this.serviceDefinition = doc.apiDefinition.get(this.version); Preconditions.checkNotNull( this.serviceDefinition, "version not found: %s", this.version); } /** * Creates an HTTP request based on the given method name and parameters. *

* If the discovery document has not yet been loaded, it will call * {@link #load()}. *

* * @param fullyQualifiedMethodName name of method as defined in Discovery * document of format "resourceName.methodName" * @param parameters user defined key / value data mapping or {@code null} for * none * @return HTTP request * @throws IOException I/O exception reading */ public HttpRequest buildRequest( String fullyQualifiedMethodName, Object parameters) throws IOException { // load service method String name = this.name; String version = this.version; HttpTransport transport = this.transport; ServiceDefinition serviceDefinition = this.serviceDefinition; Preconditions.checkNotNull(name); Preconditions.checkNotNull(version); Preconditions.checkNotNull(transport); Preconditions.checkNotNull(fullyQualifiedMethodName); if (serviceDefinition == null) { load(); } ServiceMethod method = serviceDefinition.getResourceMethod(fullyQualifiedMethodName); Preconditions.checkNotNull( method, "method not found: %s", fullyQualifiedMethodName); // Create request for specified method HttpRequest request = transport.buildRequest(); request.method = method.httpMethod; HashMap requestMap = new HashMap(); for (Map.Entry entry : DataUtil.mapOf(parameters).entrySet()) { Object value = entry.getValue(); if (value != null) { requestMap.put(entry.getKey(), value.toString()); } } GenericUrl url = new GenericUrl(serviceDefinition.baseUrl); // parse path URL String pathUrl = method.pathUrl; StringBuilder pathBuf = new StringBuilder(); int cur = 0; int length = pathUrl.length(); while (cur < length) { int next = pathUrl.indexOf('{', cur); if (next == -1) { pathBuf.append(pathUrl.substring(cur)); break; } pathBuf.append(pathUrl.substring(cur, next)); int close = pathUrl.indexOf('}', next + 2); String varName = pathUrl.substring(next + 1, close); cur = close + 1; String value = requestMap.remove(varName); if (value == null) { throw new IllegalArgumentException( "missing required path parameter: " + varName); } pathBuf.append(CharEscapers.escapeUriPath(value)); } url.appendRawPath(pathBuf.toString()); // all other parameters are assumed to be query parameters url.putAll(requestMap); request.url = url; return request; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy