/** * Copyright 2015 Google Inc. All Rights Reserved. * * 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. */ /* jshint maxlen: false */ import createAPIRequest from '../../lib/apirequest'; /** * Google OAuth2 API * * Obtains end-user authorization grants for use with other Google APIs. * * @example * const google = require('googleapis'); * const oauth2 = google.oauth2('v2'); * * @namespace oauth2 * @type {Function} * @version v2 * @variation v2 * @param {object=} options Options for Oauth2 */ function Oauth2(options) { // eslint-disable-line const self = this; self._options = options || {}; /** * oauth2.getCertForOpenIdConnect * * * * @alias oauth2.getCertForOpenIdConnect * @memberOf! oauth2(v2) * * @param {object=} params Parameters for request * @param {object} [options] Optionally override request options, such as `url`, `method`, and `encoding`. * @param {callback} callback The callback that handles the response. * @return {object} Request object */ this.getCertForOpenIdConnect = function (params, options, callback) { if (typeof options === 'function') { callback = options; options = {}; } options || (options = {}); const rootUrl = options.rootUrl || 'https://www.googleapis.com/'; const parameters = { options: Object.assign({ url: (rootUrl + '/oauth2/v2/certs').replace(/([^:]\/)\/+/g, '$1'), method: 'GET' }, options), params: params, requiredParams: [], pathParams: [], context: self }; return createAPIRequest(parameters, callback); }; /** * oauth2.tokeninfo * * * * @alias oauth2.tokeninfo * @memberOf! oauth2(v2) * * @param {object=} params Parameters for request * @param {string=} params.access_token * @param {string=} params.id_token * @param {string=} params.token_handle * @param {object} [options] Optionally override request options, such as `url`, `method`, and `encoding`. * @param {callback} callback The callback that handles the response. * @return {object} Request object */ this.tokeninfo = function (params, options, callback) { if (typeof options === 'function') { callback = options; options = {}; } options || (options = {}); const rootUrl = options.rootUrl || 'https://www.googleapis.com/'; const parameters = { options: Object.assign({ url: (rootUrl + '/oauth2/v2/tokeninfo').replace(/([^:]\/)\/+/g, '$1'), method: 'POST' }, options), params: params, requiredParams: [], pathParams: [], context: self }; return createAPIRequest(parameters, callback); }; self.userinfo = { /** * oauth2.userinfo.get * * * * @alias oauth2.userinfo.get * @memberOf! oauth2(v2) * * @param {object=} params Parameters for request * @param {object} [options] Optionally override request options, such as `url`, `method`, and `encoding`. * @param {callback} callback The callback that handles the response. * @return {object} Request object */ get: function (params, options, callback) { if (typeof options === 'function') { callback = options; options = {}; } options || (options = {}); const rootUrl = options.rootUrl || 'https://www.googleapis.com/'; const parameters = { options: Object.assign({ url: (rootUrl + '/oauth2/v2/userinfo').replace(/([^:]\/)\/+/g, '$1'), method: 'GET' }, options), params: params, requiredParams: [], pathParams: [], context: self }; return createAPIRequest(parameters, callback); }, v2: { me: { /** * oauth2.userinfo.v2.me.get * * * * @alias oauth2.userinfo.v2.me.get * @memberOf! oauth2(v2) * * @param {object=} params Parameters for request * @param {object} [options] Optionally override request options, such as `url`, `method`, and `encoding`. * @param {callback} callback The callback that handles the response. * @return {object} Request object */ get: function (params, options, callback) { if (typeof options === 'function') { callback = options; options = {}; } options || (options = {}); const rootUrl = options.rootUrl || 'https://www.googleapis.com/'; const parameters = { options: Object.assign({ url: (rootUrl + '/userinfo/v2/me').replace(/([^:]\/)\/+/g, '$1'), method: 'GET' }, options), params: params, requiredParams: [], pathParams: [], context: self }; return createAPIRequest(parameters, callback); } } } }; } /** * @typedef Jwk * @memberOf! oauth2(v2) * @type object * @property {object[]} keys */ /** * @typedef Tokeninfo * @memberOf! oauth2(v2) * @type object * @property {string} access_type The access type granted with this token. It can be offline or online. * @property {string} audience Who is the intended audience for this token. In general the same as issued_to. * @property {string} email The email address of the user. Present only if the email scope is present in the request. * @property {integer} expires_in The expiry time of the token, as number of seconds left until expiry. * @property {string} issued_to To whom was the token issued to. In general the same as audience. * @property {string} scope The space separated list of scopes granted to this token. * @property {string} token_handle The token handle associated with this token. * @property {string} user_id The obfuscated user id. * @property {boolean} verified_email Boolean flag which is true if the email address is verified. Present only if the email scope is present in the request. */ /** * @typedef Userinfoplus * @memberOf! oauth2(v2) * @type object * @property {string} email The user's email address. * @property {string} family_name The user's last name. * @property {string} gender The user's gender. * @property {string} given_name The user's first name. * @property {string} hd The hosted domain e.g. example.com if the user is Google apps user. * @property {string} id The obfuscated ID of the user. * @property {string} link URL of the profile page. * @property {string} locale The user's preferred locale. * @property {string} name The user's full name. * @property {string} picture URL of the user's picture image. * @property {boolean} verified_email Boolean flag which is true if the email address is verified. Always verified because we only return the user's primary email address. */ export = Oauth2;