npm.io
0.4.20260618 • Published 4d ago

@maxim_mazurok/gapi.client.cloudfunctions-v2

Licence
MIT
Version
0.4.20260618
Deps
2
Size
101 kB
Vulns
0
Weekly
0
Stars
58

TypeScript typings for Cloud Functions API v2

Manages lightweight user-provided functions executed in response to events. For detailed description please check documentation.

Installing

Install typings for Cloud Functions API:

npm install @types/gapi.client.cloudfunctions-v2 --save-dev

TypeScript 6.0+

TypeScript 6.0 changed types to default to []. You must now explicitly list type packages in tsconfig.json:

{
  "compilerOptions": {
    "types": [
      "gapi",
      "gapi.auth2",
      "gapi.client",
      "gapi.client.cloudfunctions-v2"
    ]
  }
}

Usage

You need to initialize Google API client in your code:

gapi.load('client', () => {
  // now we can use gapi.client
  // ...
});

Then load api client wrapper:

gapi.client.load(
  'https://cloudfunctions.googleapis.com/$discovery/rest?version=v2',
  () => {
    // now we can use:
    // gapi.client.cloudfunctions
  },
);
// Deprecated, use discovery document URL, see https://github.com/google/google-api-javascript-client/blob/master/docs/reference.md#----gapiclientloadname----version----callback--
gapi.client.load('cloudfunctions', 'v2', () => {
  // now we can use:
  // gapi.client.cloudfunctions
});

Don't forget to authenticate your client before sending any request to resources:

// declare client_id registered in Google Developers Console
var client_id = '',
  scope = [
    // See, edit, configure, and delete your Google Cloud data and see the email address for your Google Account.
    'https://www.googleapis.com/auth/cloud-platform',
  ],
  immediate = true;
// ...

gapi.auth.authorize(
  {client_id: client_id, scope: scope, immediate: immediate},
  authResult => {
    if (authResult && !authResult.error) {
      /* handle successful authorization */
    } else {
      /* handle authorization error */
    }
  },
);

After that you can use Cloud Functions API resources:

For provenance information see Provenance section on NPM