This guide explains how to use the create
method on the Space
resource of
the Google Chat API to create a named space.
The
Space
resource
represents a place where people and Chat apps can send messages,
share files, and collaborate. There are several types of spaces:
- Direct messages (DMs) are conversations between two users or a user and a Chat app.
- Group chats are conversations between three or more users and Chat apps.
- Named spaces are persistent places where people send messages, share files, and collaborate.
A named space is a place where people send messages, share files, and
collaborate. Named spaces can include Chat apps. Named spaces
include extra features that unnamed group conversations and direct messages
don't have, such as space managers who can apply administrative settings,
descriptions, and add or remove people and apps. After creating a named space,
the only member of the space is the authenticated user. The space doesn't
include other people or apps; not even the Chat app
that creates it. To add people, create memberships in the space by calling the
create
method
on the
Member
resource.
To learn how, see Create a membership.
To create a named space with multiple members—an unnamed group chat between three or more people, or a direct message conversation between two people, or a person and the Chat app calling the Chat API—set up a space instead.
Prerequisites
Python
- A Business or Enterprise Google Workspace account with access to Google Chat.
- Set up your environment:
- Create a Google Cloud project.
- Configure the OAuth consent screen.
- Enable and configure the Google Chat API with a name, icon, and description for your Chat app.
- Install the Python Google API Client Library.
-
Create OAuth client ID credentials for a desktop application. To run the sample in this
guide, save the credentials as a JSON file named
client_secrets.json
to your local directory.
- Choose an authorization scope that supports user authentication.
Node.js
- A Business or Enterprise Google Workspace account with access to Google Chat.
- Set up your environment:
- Create a Google Cloud project.
- Configure the OAuth consent screen.
- Enable and configure the Google Chat API with a name, icon, and description for your Chat app.
- Install the Node.js Google API Client Library.
-
Create OAuth client ID credentials for a desktop application. To run the sample in this
guide, save the credentials as a JSON file named
client_secrets.json
to your local directory.
- Choose an authorization scope that supports user authentication.
Create a named space
To create a named space, pass the following in your request:
- Specify the
chat.spaces.create
orchat.spaces
authorization scope. - Call the
create
method on theSpace
resource. - Set
spaceType
toSPACE
. - Set
displayName
to the user-visible name of the space. In the following example,displayName
is set toAPI-made
. - Optionally, set other space attributes, like
spaceDetails
(a user-visible description and set of guidelines for the space).
Here's how to create a named space:
Python
- In your working directory, create a file named
chat_space_create_named.py
. Include the following code in
chat_space_create_named.py
:from google_auth_oauthlib.flow import InstalledAppFlow from googleapiclient.discovery import build # Define your app's authorization scopes. # When modifying these scopes, delete the file token.json, if it exists. SCOPES = ["https://www.googleapis.com/auth/chat.spaces.create"] def main(): ''' Authenticates with Chat API via user credentials, then creates a Chat space. ''' # Authenticate with Google Workspace # and get user authorization. flow = InstalledAppFlow.from_client_secrets_file( 'client_secrets.json', SCOPES) creds = flow.run_local_server() # Build a service endpoint for Chat API. chat = build('chat', 'v1', credentials=creds) # Use the service endpoint to call Chat API. result = chat.spaces().create( # Details about the space to create. body = { # To create a named space, set spaceType to SPACE. 'spaceType': 'SPACE', # The user-visible name of the space. 'displayName': 'API-made' } ).execute() # Prints details about the created space. print(result) if __name__ == '__main__': main()
In your working directory, build and run the sample:
python3 chat_space_create_named.py
Node.js
- In your working directory, create a file named
create-space.js
. Include the following code in
create-space.js
:const chat = require('@googleapis/chat'); const {authenticate} = require('@google-cloud/local-auth'); /** * Creates a new chat space. * @return {!Promise<!Object>} */ async function createSpace() { const scopes = [ 'https://www.googleapis.com/auth/chat.spaces.create', ]; const authClient = await authenticate({scopes, keyfilePath: 'client_secrets.json'}); const chatClient = await chat.chat({version: 'v1', auth: authClient}); return await chatClient.spaces.create( {requestBody: {spaceType: 'SPACE', displayName: 'API-made'}}); } createSpace().then(console.log);
In your working directory, run the sample:
node create-space.js
A named space is created. To navigate to the space, use the space's resource ID
to build the space's URL. You can find the resource ID from the space
name
in the Google Chat response body. For example, if your space's
name
is spaces/1234567
, you can navigate to the space using the following
URL: https://mail.google.com/chat/u/0/#chat/space/1234567
.
Related topics
- Add people and apps to the space by creating members.
- Post a message in the space by creating a message.
- Get details about a space.
- List spaces.
- Update a space.
- Delete a space.
- Set up a space.
- Find a direct message space.
- Make a space discoverable to specific users.