Upload media sebagai lampiran file

Panduan ini menjelaskan cara menggunakan metode upload pada resource Media Google Chat API untuk mengupload media (file) ke Google Chat, lalu melampirkannya ke sebuah pesan.

Saat pengguna mengirim pesan ke aplikasi Anda, Google Chat akan mengirimkan Peristiwa interaksi MESSAGE. Peristiwa interaksi yang diterima oleh aplikasi Anda menyertakan isi permintaan, yang merupakan Payload JSON yang mewakili peristiwa interaksi, termasuk lampiran apa pun. Tujuan data dalam lampiran dapat berbeda tergantung pada apakah lampiran itu konten yang diupload (file lokal) atau file yang disimpan di Drive. Tujuan Referensi Media mewakili file yang diupload ke Google Chat, seperti gambar, video, dan dokumen. Tujuan Referensi Attachment mewakili instance media—sebuah file—yang dilampirkan ke pesan. Attachment menyertakan metadata tentang lampiran, seperti di mana data disimpan.

Prasyarat

Python

  • Python 3.6 atau yang lebih baru
  • Alat pengelolaan paket pip
  • Library klien Google terbaru. Untuk menginstal atau memperbaruinya, jalankan perintah berikut di antarmuka command line Anda:
    pip3 install --upgrade google-api-python-client google-auth-oauthlib
    

Upload sebagai lampiran file

Untuk mengupload media dan melampirkannya ke pesan, teruskan teks berikut dalam permintaan::

  • Tentukan cakupan otorisasi chat.messages.create atau chat.messages.
  • Panggil metode Google Chat berikut:
    1. Untuk mengupload file, panggil metode Metode upload pada resource Media.
      • Tetapkan parent ke nama ruang ruang yang menghosting file.
      • Di body (isi permintaan), tetapkan filename ke nama permintaan yang diupload lampiran file.
      • Tetapkan media_body sebagai instance file yang akan diupload.
    2. Untuk membuat pesan dengan lampiran file yang diupload, panggil metode Metode create di Resource Messages.

Contoh berikut mengupload file gambar PNG dan melampirkannya ke pesan.

Python

  1. Di direktori kerja, buat file bernama chat_media_and_attachment_upload.py.
  2. Sertakan kode berikut di chat_media_and_attachment_upload.py:

    from google_auth_oauthlib.flow import InstalledAppFlow
    from googleapiclient.discovery import build
    from googleapiclient.http import MediaFileUpload
    
    # 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.messages.create"]
    
    def main():
        '''
        Authenticates with Chat API via user credentials,
        then uploads a file as media, creates a message, and
        attaches the file to the message.
        '''
    
        # 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.
        service = build('chat', 'v1', credentials=creds)
    
        # Upload a file to Google Chat.
        media = MediaFileUpload('test_image.png', mimetype='image/png')
    
        # Create a message and attach the uploaded file to it.
        attachment_uploaded = service.media().upload(
    
            # The space to upload the attachment in.
            #
            # Replace SPACE with a space name.
            # Obtain the space name from the spaces resource of Chat API,
            # or from a space's URL.
            parent='spaces/SPACE',
    
            # The filename of the attachment, including the file extension.
            body={'filename': 'test_image.png'},
    
            # Media resource of the attachment.
            media_body=media
    
        ).execute()
    
        print(attachment_uploaded)
    
        # Create a Chat message with attachment.
        result = service.spaces().messages().create(
    
            # The space to create the message in.
            #
            # Replace SPACE with a space name.
            # Obtain the space name from the spaces resource of Chat API,
            # or from a space's URL.
            #
            # Must match the space name that the attachment is uploaded to.
            parent='spaces/SPACE',
    
            # The message to create.
            body={
                'text': 'Hello, world!',
                'attachment': [attachment_uploaded]
            }
    
        ).execute()
    
        print(result)
    
    if __name__ == '__main__':
        main()
    
  3. Dalam kode, ganti SPACE dengan nama ruang untuk unggah lampiran itu, yang dapat Anda ambil dari Metode spaces.list di Chat API, atau dari URL ruang.

  4. Dalam direktori kerja, build dan jalankan contoh:

    python3 chat_media_and_attachment_upload.py
    

Chat API menampilkan isi respons yang berisi attachmentDataRef dengan detail tentang file yang diupload.

Batas dan pertimbangan

Saat mempersiapkan diri untuk mengunggah file dan melampirkannya ke pesan, perhatikan hal-hal berikut batasan dan pertimbangan: