0.0.20250608 • Published 5 months ago

@maxim_mazurok/gapi.client.chat-v1 v0.0.20250608

Weekly downloads
-
License
MIT
Repository
github
Last release
5 months ago

TypeScript typings for Google Chat API v1

The Google Chat API lets you build Chat apps to integrate your services with Google Chat and manage Chat resources such as spaces, members, and messages. For detailed description please check documentation.

Installing

Install typings for Google Chat API:

npm install @types/gapi.client.chat-v1 --save-dev

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://chat.googleapis.com/$discovery/rest?version=v1',
  () => {
    // now we can use:
    // gapi.client.chat
  },
);
// 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('chat', 'v1', () => {
  // now we can use:
  // gapi.client.chat
});

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 = [
    // Delete conversations and spaces owned by your organization and remove access to associated files in Google Chat
    'https://www.googleapis.com/auth/chat.admin.delete',

    // View, add, update and remove members and managers in conversations owned by your organization
    'https://www.googleapis.com/auth/chat.admin.memberships',

    // View members and managers in conversations owned by your organization
    'https://www.googleapis.com/auth/chat.admin.memberships.readonly',

    // View or edit display name, description, and other metadata for all Google Chat conversations owned by your organization
    'https://www.googleapis.com/auth/chat.admin.spaces',

    // View display name, description, and other metadata for all Google Chat conversations owned by your organization
    'https://www.googleapis.com/auth/chat.admin.spaces.readonly',

    // On their own behalf, apps in Google Chat can delete conversations and spaces and remove access to associated files
    'https://www.googleapis.com/auth/chat.app.delete',

    // On their own behalf, apps in Google Chat can see, add, update, and remove members from conversations and spaces
    'https://www.googleapis.com/auth/chat.app.memberships',

    // On their own behalf, apps in Google Chat can create conversations and spaces and see or update their metadata (including history settings and access settings)
    'https://www.googleapis.com/auth/chat.app.spaces',

    // On their own behalf, apps in Google Chat can create conversations and spaces
    'https://www.googleapis.com/auth/chat.app.spaces.create',

    // Private Service: https://www.googleapis.com/auth/chat.bot
    'https://www.googleapis.com/auth/chat.bot',

    // View, create, and delete custom emoji in Google Chat
    'https://www.googleapis.com/auth/chat.customemojis',

    // View custom emoji in Google Chat
    'https://www.googleapis.com/auth/chat.customemojis.readonly',

    // Delete conversations and spaces and remove access to associated files in Google Chat
    'https://www.googleapis.com/auth/chat.delete',

    // Import spaces, messages, and memberships into Google Chat.
    'https://www.googleapis.com/auth/chat.import',

    // See, add, update, and remove members from conversations and spaces in Google Chat
    'https://www.googleapis.com/auth/chat.memberships',

    // Add and remove itself from conversations and spaces in Google Chat
    'https://www.googleapis.com/auth/chat.memberships.app',

    // View members in Google Chat conversations.
    'https://www.googleapis.com/auth/chat.memberships.readonly',

    // See, compose, send, update, and delete messages as well as their message content; add, see, and delete reactions to messages.
    'https://www.googleapis.com/auth/chat.messages',

    // Compose and send messages in Google Chat
    'https://www.googleapis.com/auth/chat.messages.create',

    // See, add, and delete reactions as well as their reaction content to messages in Google Chat
    'https://www.googleapis.com/auth/chat.messages.reactions',

    // Add reactions to messages in Google Chat
    'https://www.googleapis.com/auth/chat.messages.reactions.create',

    // View reactions as well as their reaction content to messages in Google Chat
    'https://www.googleapis.com/auth/chat.messages.reactions.readonly',

    // See messages as well as their reactions and message content in Google Chat
    'https://www.googleapis.com/auth/chat.messages.readonly',

    // Create conversations and spaces and see or update metadata (including history settings and access settings) in Google Chat
    'https://www.googleapis.com/auth/chat.spaces',

    // Create new conversations and spaces in Google Chat
    'https://www.googleapis.com/auth/chat.spaces.create',

    // View chat and spaces in Google Chat
    'https://www.googleapis.com/auth/chat.spaces.readonly',

    // View and modify last read time for Google Chat conversations
    'https://www.googleapis.com/auth/chat.users.readstate',

    // View last read time for Google Chat conversations
    'https://www.googleapis.com/auth/chat.users.readstate.readonly',

    // Read and update your space settings
    'https://www.googleapis.com/auth/chat.users.spacesettings',
  ],
  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 Google Chat API resources:

/*
Creates a custom emoji. Custom emojis are only available for Google Workspace accounts, and the administrator must turn custom emojis on for the organization. For more information, see [Learn about custom emojis in Google Chat](https://support.google.com/chat/answer/12800149) and [Manage custom emoji permissions](https://support.google.com/a/answer/12850085). Requires [user authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user) with the [authorization scope](https://developers.google.com/workspace/chat/authenticate-authorize#chat-api-scopes): - `https://www.googleapis.com/auth/chat.customemojis`
*/
await gapi.client.chat.customEmojis.create({});

/*
Deletes a custom emoji. By default, users can only delete custom emoji they created. [Emoji managers](https://support.google.com/a/answer/12850085) assigned by the administrator can delete any custom emoji in the organization. See [Learn about custom emojis in Google Chat](https://support.google.com/chat/answer/12800149). Custom emojis are only available for Google Workspace accounts, and the administrator must turn custom emojis on for the organization. For more information, see [Learn about custom emojis in Google Chat](https://support.google.com/chat/answer/12800149) and [Manage custom emoji permissions](https://support.google.com/a/answer/12850085). Requires [user authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user) with the [authorization scope](https://developers.google.com/workspace/chat/authenticate-authorize#chat-api-scopes): - `https://www.googleapis.com/auth/chat.customemojis`
*/
await gapi.client.chat.customEmojis.delete({name: 'name'});

/*
Returns details about a custom emoji. Custom emojis are only available for Google Workspace accounts, and the administrator must turn custom emojis on for the organization. For more information, see [Learn about custom emojis in Google Chat](https://support.google.com/chat/answer/12800149) and [Manage custom emoji permissions](https://support.google.com/a/answer/12850085). Requires [user authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user) with one of the following [authorization scopes](https://developers.google.com/workspace/chat/authenticate-authorize#chat-api-scopes): - `https://www.googleapis.com/auth/chat.customemojis.readonly` - `https://www.googleapis.com/auth/chat.customemojis`
*/
await gapi.client.chat.customEmojis.get({name: 'name'});

/*
Lists custom emojis visible to the authenticated user. Custom emojis are only available for Google Workspace accounts, and the administrator must turn custom emojis on for the organization. For more information, see [Learn about custom emojis in Google Chat](https://support.google.com/chat/answer/12800149) and [Manage custom emoji permissions](https://support.google.com/a/answer/12850085). Requires [user authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user) with one of the following [authorization scopes](https://developers.google.com/workspace/chat/authenticate-authorize#chat-api-scopes): - `https://www.googleapis.com/auth/chat.customemojis.readonly` - `https://www.googleapis.com/auth/chat.customemojis`
*/
await gapi.client.chat.customEmojis.list({});

/*
Downloads media. Download is supported on the URI `/v1/media/{+name}?alt=media`.
*/
await gapi.client.chat.media.download({resourceName: 'resourceName'});

/*
Uploads an attachment. For an example, see [Upload media as a file attachment](https://developers.google.com/workspace/chat/upload-media-attachments). Requires user [authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user) with one of the following [authorization scopes](https://developers.google.com/workspace/chat/authenticate-authorize#chat-api-scopes): - `https://www.googleapis.com/auth/chat.messages.create` - `https://www.googleapis.com/auth/chat.messages` - `https://www.googleapis.com/auth/chat.import` (import mode spaces only) You can upload attachments up to 200 MB. Certain file types aren't supported. For details, see [File types blocked by Google Chat](https://support.google.com/chat/answer/7651457?&co=GENIE.Platform%3DDesktop#File%20types%20blocked%20in%20Google%20Chat).
*/
await gapi.client.chat.media.upload({parent: 'parent'});

/*
Completes the [import process](https://developers.google.com/workspace/chat/import-data) for the specified space and makes it visible to users. Requires [user authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user) and domain-wide delegation with the [authorization scope](https://developers.google.com/workspace/chat/authenticate-authorize#chat-api-scopes): - `https://www.googleapis.com/auth/chat.import` For more information, see [Authorize Google Chat apps to import data](https://developers.google.com/workspace/chat/authorize-import).
*/
await gapi.client.chat.spaces.completeImport({name: 'name'});

/*
Creates a space. Can be used to create a named space, or a group chat in `Import mode`. For an example, see [Create a space](https://developers.google.com/workspace/chat/create-spaces). Supports the following types of [authentication](https://developers.google.com/workspace/chat/authenticate-authorize): - [App authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-app) with [administrator approval](https://support.google.com/a?p=chat-app-auth) in [Developer Preview](https://developers.google.com/workspace/preview) and one of the following authorization scopes: - `https://www.googleapis.com/auth/chat.app.spaces.create` - `https://www.googleapis.com/auth/chat.app.spaces` - [User authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user) with one of the following authorization scopes: - `https://www.googleapis.com/auth/chat.spaces.create` - `https://www.googleapis.com/auth/chat.spaces` - `https://www.googleapis.com/auth/chat.import` (import mode spaces only) When authenticating as an app, the `space.customer` field must be set in the request. When authenticating as an app, the Chat app is added as a member of the space. However, unlike human authentication, the Chat app is not added as a space manager. By default, the Chat app can be removed from the space by all space members. To allow only space managers to remove the app from a space, set `space.permission_settings.manage_apps` to `managers_allowed`. Space membership upon creation depends on whether the space is created in `Import mode`: * **Import mode:** No members are created. * **All other modes:** The calling user is added as a member. This is: * The app itself when using app authentication. * The human user when using user authentication. If you receive the error message `ALREADY_EXISTS` when creating a space, try a different `displayName`. An existing space within the Google Workspace organization might already use this display name.
*/
await gapi.client.chat.spaces.create({});

/*
Deletes a named space. Always performs a cascading delete, which means that the space's child resources—like messages posted in the space and memberships in the space—are also deleted. For an example, see [Delete a space](https://developers.google.com/workspace/chat/delete-spaces). Supports the following types of [authentication](https://developers.google.com/workspace/chat/authenticate-authorize): - [App authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-app) with [administrator approval](https://support.google.com/a?p=chat-app-auth) in [Developer Preview](https://developers.google.com/workspace/preview) and the authorization scope: - `https://www.googleapis.com/auth/chat.app.delete` (only in spaces the app created) - [User authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user) with one of the following authorization scopes: - `https://www.googleapis.com/auth/chat.delete` - `https://www.googleapis.com/auth/chat.import` (import mode spaces only) - User authentication grants administrator privileges when an administrator account authenticates, `use_admin_access` is `true`, and the following authorization scope is used: - `https://www.googleapis.com/auth/chat.admin.delete`
*/
await gapi.client.chat.spaces.delete({name: 'name'});

/*
Returns the existing direct message with the specified user. If no direct message space is found, returns a `404 NOT_FOUND` error. For an example, see [Find a direct message](/chat/api/guides/v1/spaces/find-direct-message). With [app authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-app), returns the direct message space between the specified user and the calling Chat app. With [user authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user), returns the direct message space between the specified user and the authenticated user. Supports the following types of [authentication](https://developers.google.com/workspace/chat/authenticate-authorize): - [App authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-app) with the authorization scope: - `https://www.googleapis.com/auth/chat.bot` - [User authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user) with one of the following authorization scopes: - `https://www.googleapis.com/auth/chat.spaces.readonly` - `https://www.googleapis.com/auth/chat.spaces`
*/
await gapi.client.chat.spaces.findDirectMessage({});

/*
Returns details about a space. For an example, see [Get details about a space](https://developers.google.com/workspace/chat/get-spaces). Supports the following types of [authentication](https://developers.google.com/workspace/chat/authenticate-authorize): - [App authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-app) with one of the following authorization scopes: - `https://www.googleapis.com/auth/chat.bot` - `https://www.googleapis.com/auth/chat.app.spaces` with [administrator approval](https://support.google.com/a?p=chat-app-auth) - [User authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user) with one of the following authorization scopes: - `https://www.googleapis.com/auth/chat.spaces.readonly` - `https://www.googleapis.com/auth/chat.spaces` - User authentication grants administrator privileges when an administrator account authenticates, `use_admin_access` is `true`, and one of the following authorization scopes is used: - `https://www.googleapis.com/auth/chat.admin.spaces.readonly` - `https://www.googleapis.com/auth/chat.admin.spaces` App authentication has the following limitations: - `space.access_settings` is only populated when using the `chat.app.spaces` scope. - `space.predefind_permission_settings` and `space.permission_settings` are only populated when using the `chat.app.spaces` scope, and only for spaces the app created.
*/
await gapi.client.chat.spaces.get({name: 'name'});

/*
Lists spaces the caller is a member of. Group chats and DMs aren't listed until the first message is sent. For an example, see [List spaces](https://developers.google.com/workspace/chat/list-spaces). Supports the following types of [authentication](https://developers.google.com/workspace/chat/authenticate-authorize): - [App authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-app) with the authorization scope: - `https://www.googleapis.com/auth/chat.bot` - [User authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user) with one of the following authorization scopes: - `https://www.googleapis.com/auth/chat.spaces.readonly` - `https://www.googleapis.com/auth/chat.spaces` To list all named spaces by Google Workspace organization, use the [`spaces.search()`](https://developers.google.com/workspace/chat/api/reference/rest/v1/spaces/search) method using Workspace administrator privileges instead.
*/
await gapi.client.chat.spaces.list({});

/*
Updates a space. For an example, see [Update a space](https://developers.google.com/workspace/chat/update-spaces). If you're updating the `displayName` field and receive the error message `ALREADY_EXISTS`, try a different display name.. An existing space within the Google Workspace organization might already use this display name. Supports the following types of [authentication](https://developers.google.com/workspace/chat/authenticate-authorize): - [App authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-app) with [administrator approval](https://support.google.com/a?p=chat-app-auth) in [Developer Preview](https://developers.google.com/workspace/preview) and one of the following authorization scopes: - `https://www.googleapis.com/auth/chat.app.spaces` - [User authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user) with one of the following authorization scopes: - `https://www.googleapis.com/auth/chat.spaces` - `https://www.googleapis.com/auth/chat.import` (import mode spaces only) - User authentication grants administrator privileges when an administrator account authenticates, `use_admin_access` is `true`, and the following authorization scopes is used: - `https://www.googleapis.com/auth/chat.admin.spaces` App authentication has the following limitations: - To update either `space.predefined_permission_settings` or `space.permission_settings`, the app must be the space creator. - Updating the `space.access_settings.audience` is not supported for app authentication.
*/
await gapi.client.chat.spaces.patch({name: 'name'});

/*
Returns a list of spaces in a Google Workspace organization based on an administrator's search. Requires [user authentication with administrator privileges](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user#admin-privileges) and one of the following [authorization scopes](https://developers.google.com/workspace/chat/authenticate-authorize#chat-api-scopes): - `https://www.googleapis.com/auth/chat.admin.spaces.readonly` - `https://www.googleapis.com/auth/chat.admin.spaces` In the request, set `use_admin_access` to `true`.
*/
await gapi.client.chat.spaces.search({});

/*
Creates a space and adds specified users to it. The calling user is automatically added to the space, and shouldn't be specified as a membership in the request. For an example, see [Set up a space with initial members](https://developers.google.com/workspace/chat/set-up-spaces). To specify the human members to add, add memberships with the appropriate `membership.member.name`. To add a human user, use `users/{user}`, where `{user}` can be the email address for the user. For users in the same Workspace organization `{user}` can also be the `id` for the person from the People API, or the `id` for the user in the Directory API. For example, if the People API Person profile ID for `user@example.com` is `123456789`, you can add the user to the space by setting the `membership.member.name` to `users/user@example.com` or `users/123456789`. To specify the Google groups to add, add memberships with the appropriate `membership.group_member.name`. To add or invite a Google group, use `groups/{group}`, where `{group}` is the `id` for the group from the Cloud Identity Groups API. For example, you can use [Cloud Identity Groups lookup API](https://cloud.google.com/identity/docs/reference/rest/v1/groups/lookup) to retrieve the ID `123456789` for group email `group@example.com`, then you can add the group to the space by setting the `membership.group_member.name` to `groups/123456789`. Group email is not supported, and Google groups can only be added as members in named spaces. For a named space or group chat, if the caller blocks, or is blocked by some members, or doesn't have permission to add some members, then those members aren't added to the created space. To create a direct message (DM) between the calling user and another human user, specify exactly one membership to represent the human user. If one user blocks the other, the request fails and the DM isn't created. To create a DM between the calling user and the calling app, set `Space.singleUserBotDm` to `true` and don't specify any memberships. You can only use this method to set up a DM with the calling app. To add the calling app as a member of a space or an existing DM between two human users, see [Invite or add a user or app to a space](https://developers.google.com/workspace/chat/create-members). If a DM already exists between two users, even when one user blocks the other at the time a request is made, then the existing DM is returned. Spaces with threaded replies aren't supported. If you receive the error message `ALREADY_EXISTS` when setting up a space, try a different `displayName`. An existing space within the Google Workspace organization might already use this display name. Requires [user authentication](https://developers.google.com/workspace/chat/authenticate-authorize-chat-user) with one of the following [authorization scopes](https://developers.google.com/workspace/chat/authenticate-authorize#chat-api-scopes): - `https://www.googleapis.com/auth/chat.spaces.create` - `https://www.googleapis.com/auth/chat.spaces`
*/
await gapi.client.chat.spaces.setup({});
0.0.20250529

5 months ago

0.0.20250408

7 months ago

0.0.20250406

7 months ago

0.0.20250403

7 months ago

0.0.20250522

5 months ago

0.0.20250401

7 months ago

0.0.20250520

6 months ago

0.0.20241031

1 year ago

0.0.20250417

7 months ago

0.0.20250415

7 months ago

0.0.20250412

7 months ago

0.0.20250410

7 months ago

0.0.20250420

7 months ago

0.0.20250429

6 months ago

0.0.20250427

6 months ago

0.0.20250306

8 months ago

0.0.20250302

8 months ago

0.0.20250424

6 months ago

0.0.20250422

7 months ago

0.0.20250318

8 months ago

0.0.20250316

8 months ago

0.0.20250313

8 months ago

0.0.20250311

8 months ago

0.0.20250320

8 months ago

0.0.20250209

9 months ago

0.0.20250329

7 months ago

0.0.20250206

9 months ago

0.0.20250323

8 months ago

0.0.20250202

9 months ago

0.0.20250218

9 months ago

0.0.20250213

9 months ago

0.0.20250227

8 months ago

0.0.20250107

10 months ago

0.0.20250225

8 months ago

0.0.20250223

8 months ago

0.0.20250102

10 months ago

0.0.20250111

10 months ago

0.0.20250119

10 months ago

0.0.20250116

10 months ago

0.0.20250114

10 months ago

0.0.20250121

10 months ago

0.0.20250126

9 months ago

0.0.20250124

9 months ago

0.0.20250130

9 months ago

0.0.20241201

11 months ago

0.0.20241211

11 months ago

0.0.20241210

11 months ago

0.0.20241205

11 months ago

0.0.20241203

11 months ago

0.0.20241208

11 months ago

0.0.20241103

1 year ago

0.0.20250608

5 months ago

0.0.20250605

5 months ago

0.0.20241217

11 months ago

0.0.20241110

12 months ago

0.0.20241114

12 months ago

0.0.20241112

12 months ago

0.0.20241105

12 months ago

0.0.20241229

10 months ago

0.0.20241121

12 months ago

0.0.20250508

6 months ago

0.0.20241124

12 months ago

0.0.20250504

6 months ago

0.0.20250501

6 months ago

0.0.20241117

12 months ago

0.0.20241119

12 months ago

0.0.20250516

6 months ago

0.0.20250513

6 months ago

0.0.20250511

6 months ago

0.0.20241126

11 months ago

0.0.20241022

1 year ago

0.0.20241029

1 year ago

0.0.20241027

1 year ago

0.0.20241020

1 year ago

0.0.20241017

1 year ago

0.0.20241015

1 year ago

0.0.20241013

1 year ago

0.0.20240929

1 year ago

0.0.20240926

1 year ago

0.0.20240924

1 year ago

0.0.20241003

1 year ago

0.0.20241001

1 year ago

0.0.20241010

1 year ago

0.0.20241008

1 year ago

0.0.20241006

1 year ago

0.0.20240919

1 year ago

0.0.20240916

1 year ago

0.0.20240917

1 year ago

0.0.20240912

1 year ago

0.0.20240922

1 year ago

0.0.20240908

1 year ago

0.0.20240905

1 year ago

0.0.20240901

1 year ago

0.0.20240826

1 year ago

0.0.20240829

1 year ago

0.0.20240825

1 year ago

0.0.20240822

1 year ago

0.0.20240728

1 year ago

0.0.20240609

1 year ago

0.0.20240723

1 year ago

0.0.20240725

1 year ago

0.0.20240604

1 year ago

0.0.20240721

1 year ago

0.0.20240618

1 year ago

0.0.20240613

1 year ago

0.0.20240625

1 year ago

0.0.20240623

1 year ago

0.0.20240519

1 year ago

0.0.20240516

1 year ago

0.0.20240528

1 year ago

0.0.20240521

1 year ago

0.0.20240808

1 year ago

0.0.20240804

1 year ago

0.0.20240806

1 year ago

0.0.20240801

1 year ago

0.0.20240815

1 year ago

0.0.20240818

1 year ago

0.0.20240811

1 year ago

0.0.20240813

1 year ago

0.0.20240709

1 year ago

0.0.20240707

1 year ago

0.0.20240701

1 year ago

0.0.20240702

1 year ago

0.0.20240820

1 year ago

0.0.20240716

1 year ago

0.0.20240509

1 year ago

0.0.20240507

1 year ago

0.0.20240427

2 years ago

0.0.20240425

2 years ago

0.0.20240420

2 years ago

0.0.20240418

2 years ago

0.0.20240423

2 years ago

0.0.20240416

2 years ago

0.0.20240411

2 years ago

0.0.20240414

2 years ago

0.0.20240404

2 years ago

0.0.20240402

2 years ago

0.0.20240331

2 years ago

0.0.20240326

2 years ago

0.0.20240324

2 years ago

0.0.20240321

2 years ago

0.0.20240319

2 years ago

0.0.20240317

2 years ago

0.0.20240315

2 years ago

0.0.20240312

2 years ago

0.0.20240310

2 years ago

0.0.20240305

2 years ago

0.0.20240303

2 years ago

0.0.20240227

2 years ago

0.0.20240222

2 years ago

0.0.20240223

2 years ago

0.0.20240220

2 years ago

0.0.20240211

2 years ago

0.0.20240208

2 years ago

0.0.20240204

2 years ago

0.0.20240201

2 years ago

0.0.20240130

2 years ago

0.0.20240128

2 years ago

0.0.20240123

2 years ago

0.0.20240118

2 years ago

0.0.20240117

2 years ago

0.0.20240111

2 years ago

0.0.20240109

2 years ago

0.0.20240104

2 years ago

0.0.20240102

2 years ago

0.0.20231228

2 years ago

0.0.20231217

2 years ago

0.0.20231214

2 years ago

0.0.20231212

2 years ago

0.0.20231207

2 years ago

0.0.20231203

2 years ago

0.0.20231130

2 years ago

0.0.20230816

2 years ago

0.0.20231105

2 years ago

0.0.20231114

2 years ago

0.0.20230928

2 years ago

0.0.20230808

2 years ago

0.0.20230926

2 years ago

0.0.20230806

2 years ago

0.0.20230921

2 years ago

0.0.20230803

2 years ago

0.0.20230801

2 years ago

0.0.20231102

2 years ago

0.0.20230718

2 years ago

0.0.20230711

2 years ago

0.0.20231008

2 years ago

0.0.20230831

2 years ago

0.0.20230716

2 years ago

0.0.20231012

2 years ago

0.0.20231011

2 years ago

0.0.20230829

2 years ago

0.0.20230708

2 years ago

0.0.20230827

2 years ago

0.0.20230706

2 years ago

0.0.20230821

2 years ago

0.0.20231116

2 years ago

0.0.20230822

2 years ago

0.0.20230704

2 years ago

0.0.20231121

2 years ago

0.0.20231003

2 years ago

0.0.20231005

2 years ago

0.0.20231029

2 years ago

0.0.20230729

2 years ago

0.0.20231017

2 years ago

0.0.20230723

2 years ago

0.0.20231019

2 years ago

0.0.20230727

2 years ago

0.0.20231024

2 years ago

0.0.20231026

2 years ago

0.0.20230910

2 years ago

0.0.20230914

2 years ago

0.0.20230912

2 years ago

0.0.20230629

2 years ago

0.0.20230905

2 years ago

0.0.20230627

2 years ago

0.0.20230903

2 years ago

0.0.20230622

2 years ago

0.0.20230625

2 years ago

0.0.20230618

2 years ago

0.0.20230611

2 years ago

0.0.20230608

2 years ago

0.0.20230525

2 years ago

0.0.20230606

2 years ago

0.0.20230603

2 years ago

0.0.20230530

2 years ago

0.0.20230514

2 years ago

0.0.20230518

2 years ago

0.0.20230516

2 years ago

0.0.20230521

2 years ago

0.0.20230502

3 years ago

0.0.20230504

3 years ago

0.0.20230427

3 years ago

0.0.20230412

3 years ago

0.0.20230413

3 years ago

0.0.20230418

3 years ago

0.0.20230420

3 years ago

0.0.20230326

3 years ago

0.0.20230404

3 years ago

0.0.20230402

3 years ago

0.0.20230328

3 years ago

0.0.20230406

3 years ago

0.0.20230330

3 years ago

0.0.20230314

3 years ago

0.0.20230319

3 years ago

0.0.20230323

3 years ago

0.0.20230425

3 years ago

0.0.20230304

3 years ago

0.0.20230423

3 years ago

0.0.20230302

3 years ago

0.0.20230309

3 years ago

0.0.20230307

3 years ago

0.0.20230312

3 years ago

0.0.20230216

3 years ago

0.0.20230219

3 years ago

0.0.20230221

3 years ago

0.0.20230205

3 years ago

0.0.20230129

3 years ago

0.0.20230126

3 years ago

0.0.20230209

3 years ago

0.0.20230207

3 years ago

0.0.20230131

3 years ago

0.0.20230212

3 years ago

0.0.20230202

3 years ago

0.0.20221115

3 years ago

0.0.20230115

3 years ago

0.0.20221213

3 years ago

0.0.20221112

3 years ago

0.0.20230119

3 years ago

0.0.20221110

3 years ago

0.0.20221208

3 years ago

0.0.20230103

3 years ago

0.0.20221206

3 years ago

0.0.20230123

3 years ago

0.0.20230101

3 years ago

0.0.20221204

3 years ago

0.0.20221105

3 years ago

0.0.20221126

3 years ago

0.0.20221103

3 years ago

0.0.20221122

3 years ago

0.0.20221120

3 years ago

0.0.20221219

3 years ago

0.0.20221013

3 years ago

0.0.20221011

3 years ago

0.0.20221009

3 years ago

0.0.20221029

3 years ago

0.0.20221020

3 years ago

0.0.20221006

3 years ago

0.0.20221027

3 years ago

0.0.20221025

3 years ago

0.0.20221101

3 years ago

0.0.20221001

3 years ago

0.0.20220927

3 years ago

0.0.20221019

3 years ago

0.0.20220925

3 years ago

0.0.20220917

3 years ago

0.0.20220906

3 years ago

0.0.20220818

3 years ago

0.0.20220819

3 years ago

0.0.20220920

3 years ago

0.0.20220914

3 years ago

0.0.20220826

3 years ago

0.0.20220915

3 years ago

0.0.20220904

3 years ago

0.0.20220816

3 years ago

0.0.20220811

3 years ago

0.0.20220805

3 years ago