google-chat-samples

Chat Bot Samples for Google Chat.

APACHE-2.0 License

Stars
491

Google Chat code samples

This repository contains the code samples for Google Chat apps. There are folders of samples dependent on language and platform. Generally the Java and Python samples live in each respective directory, but JavaScript has multiple form factors (client-side, server-side/Node.js, Google Apps Script [also server side], and Cloud Functions [GCP or Firebase]).

Which JS platform you choose depends on the type of app application you're using/writing. Apps Script features tighter integration with Google Workspace data and applications, while Google Cloud Functions has a tighter integration with Google Cloud Platform services and APIs. Finally, mobile apps or mobile web apps are more likely to want to take advantage of Cloud Functions for Firebase. It is also generally straightforward to port from one JS implementation to another, for example, to Node.js.

In each folder, you can find a language-specific implementation of the one or more of the following code samples:

  • Basic app: This app receives event notices and messages from Google
    Chat and responds synchronously with simple text responses. This sample
    demonstrates how to create an HTTP endpoint app using
    Google App Engine.
  • Basic async app: This app receives event notices and messages from
    Google Chat and responds asynchronously with simple text responses. The
    responses will appear in the same thread that raised the original event or
    message. This sample is an HTTP endpoint app built upon
    Google App Engine.
  • Pub/Sub app: This app uses
    Google Cloud Pub/Sub to receive messages
    from Google Chat. The app responds back to Google Chat asynchronously.
  • Card app: This app receives event notices and messages from Google
    Chat and responds synchronously with a
    card-formatted
    response. This sample is an HTTP endpoint app built upon
    Google App Engine.
  • Vote app: This app demonstrates updating interactive cards by providing
    a platform whereby users can vote on topics, such as who can do lunch today,
    who wants to play ball at lunch, etc. Samples can feature images or be
    text-only.

For additional details about how to set up and run each sample, consult the README file included with the sample.

Note: The Google Chat application, and the developer platform, are only available to Google Workspace accounts. You will not be able to develop or test a app with an @gmail.com account.

Contributing changes

See CONTRIBUTING.md.

Licensing

This is not an official product.

This library is licensed under Apache 2.0. Full license text is available in LICENSE.