Bu sayfada, harici tetikleyicileri kullanarak bir Chat alanına eşzamansız mesajlar göndermek için webhook'un nasıl ayarlanacağı açıklanmaktadır. Örneğin, bir sunucu kullanımdan kaldırıldığında Chat'te nöbetçi personeli bilgilendirmek için bir izleme uygulaması yapılandırabilirsiniz. Bir sohbet uygulamasıyla senkron mesaj göndermek için Mesaj gönderme başlıklı makaleyi inceleyin.
Bu tür bir mimari tasarımda, iletişim tek yönlü olduğundan kullanıcılar webhook veya bağlı harici uygulamayla etkileşimde bulunamaz. Webhook'lar sohbet edemez. Kullanıcılardan veya Chat uygulaması etkileşim etkinliklerinden mesaj alamaz ya da bu kullanıcılara ve etkinliklere yanıt veremezler. Mesajlara yanıt vermek için webhook yerine Chat uygulaması oluşturun.
Webhook teknik olarak bir Chat uygulaması olmasa da (webhook'lar, standart HTTP isteklerini kullanarak uygulamaları bağlar) bu sayfada basitleştirme amacıyla Chat uygulaması olarak adlandırılır. Her webhook yalnızca kaydedildiği Chat alanında çalışır. Gelen webhook'lar, doğrudan mesajlarda çalışır ancak yalnızca tüm kullanıcılar Chat uygulamalarını etkinleştirdiğinde çalışır. Webhook'ları Google Workspace Marketplace'te yayınlayamazsınız.
Aşağıdaki şemada, Chat'e bağlı bir webhook'un mimarisi gösterilmektedir:
Yukarıdaki şemada, bir Chat uygulamasının bilgi akışı şu şekildedir:
- Chat uygulaması mantığı, proje yönetim sistemi veya destek kaydı aracı gibi harici üçüncü taraf hizmetlerinden bilgi alır.
- Chat uygulaması mantığı, belirli bir Chat alanına webhook URL'si kullanarak mesaj gönderebilen bir bulut veya şirket içi sistemde barındırılır.
- Kullanıcılar, söz konusu Chat alanında Chat uygulamasından mesaj alabilir ancak Chat uygulamasıyla etkileşimde bulunamaz.
Ön koşullar
Python
- Google Chat'e erişimi olan bir Business veya Enterprise Google Workspace hesabı. Google Workspace kuruluşunuz, kullanıcıların gelen webhook'lar eklemesine ve kullanmasına izin vermelidir.
- Python 3.6 veya sonraki sürümler
- pip paket yönetim aracı
httplib2
kitaplığı. Kitaplığı yüklemek için komut satırı arayüzünüzde aşağıdaki komutu çalıştırın:pip install httplib2
Google Chat alanı. Google Chat API'yi kullanarak alan oluşturmak için Alan oluşturma başlıklı makaleyi inceleyin. Chat'te oluşturmak için Yardım Merkezi belgelerini ziyaret edin.
Node.js
- Google Chat'e erişimi olan bir Business veya Enterprise Google Workspace hesabı. Google Workspace kuruluşunuz, kullanıcıların gelen webhook'lar eklemesine ve kullanmasına izin vermelidir.
- Node.js 14 veya daha yeni bir sürüm
- npm paket yönetim aracı
- Google Chat alanı. Google Chat API'yi kullanarak alan oluşturmak için Alan oluşturma başlıklı makaleyi inceleyin. Chat'te oluşturmak için Yardım Merkezi belgelerini ziyaret edin.
Java
- Google Chat'e erişimi olan bir Business veya Enterprise Google Workspace hesabı. Google Workspace kuruluşunuz, kullanıcıların gelen webhook'lar eklemesine ve kullanmasına izin vermelidir.
- Java 11 veya üzeri
- Maven paket yönetimi aracı
- Google Chat alanı. Google Chat API'yi kullanarak alan oluşturmak için Alan oluşturma başlıklı makaleyi inceleyin. Chat'te oluşturmak için Yardım Merkezi belgelerini ziyaret edin.
Apps Komut Dosyası
- Google Chat'e erişimi olan bir Business veya Enterprise Google Workspace hesabı. Google Workspace kuruluşunuz, kullanıcıların gelen webhook'lar eklemesine ve kullanmasına izin vermelidir.
- Bağımsız bir Apps Komut Dosyası projesi oluşturun ve Gelişmiş Chat Hizmeti'ni etkinleştirin.
- Google Chat alanı. Google Chat API'yi kullanarak alan oluşturmak için Alan oluşturma başlıklı makaleyi inceleyin. Chat'te oluşturmak için Yardım Merkezi belgelerini ziyaret edin.
Web kancası oluşturma
Webhook oluşturmak için mesaj almak istediğiniz Chat alanına kaydedin ve ardından mesaj gönderen bir komut dosyası yazın.
Gelen webhook'u kaydetme
- Tarayıcıda Chat'i açın. Webhook'lar Chat mobil uygulamasından yapılandırılamaz.
- Webhook eklemek istediğiniz alana gidin.
- Alan başlığının yanındaki daha fazla genişletme okunu, ardından Uygulamalar ve entegrasyonlar'ı tıklayın.
Web kancaları ekle'yi tıklayın.Kullanıcıların Chat uygulamalarını yüklemesine izin verme başlıklı makaleyi inceleyin.
Ad alanına
Quickstart Webhook
girin.Avatar URL'si alanına
https://developers.google.com/chat/images/chat-product-icon.png
girin.Kaydet'i tıklayın.
Web kancası URL'sini kopyalamak için
Diğer'i ve ardından Bağlantıyı kopyala'yı tıklayın.
Webhook komut dosyasını yazma
Örnek webhook komut dosyası, webhook URL'sine bir POST
isteği göndererek webhook'un kaydedildiği alana bir mesaj gönderir. Chat API, Message
örneğiyle yanıt verir.
Webhook komut dosyası oluşturmayı öğrenmek için bir dil seçin:
Python
Çalışma dizininizde
quickstart.py
adlı bir dosya oluşturun.quickstart.py
bölümüne aşağıdaki kodu yapıştırın:url
değişkeninin değerini, webhook'u kaydederken kopyaladığınız webhook URL'siyle değiştirin.
Node.js
Çalışma dizininizde
index.js
adlı bir dosya oluşturun.index.js
bölümüne aşağıdaki kodu yapıştırın:url
değişkeninin değerini, webhook'u kaydederken kopyaladığınız webhook URL'siyle değiştirin.
Java
Çalışma dizininizde
pom.xml
adlı bir dosya oluşturun.pom.xml
bölümünde aşağıdakileri kopyalayıp yapıştırın:Çalışma dizininizde aşağıdaki dizin yapısını oluşturun
src/main/java
.src/main/java
dizinindeApp.java
adlı bir dosya oluşturun.App.java
bölümüne aşağıdaki kodu yapıştırın:URL
değişkeninin değerini, webhook'u kaydederken kopyaladığınız webhook URL'siyle değiştirin.
Apps Komut Dosyası
Tarayıcıda Apps Komut Dosyası'na gidin.
Yeni Proje'yi tıklayın.
Aşağıdaki kodu yapıştırın:
url
değişkeninin değerini, webhook'u kaydederken kopyaladığınız webhook URL'siyle değiştirin.
Webhook komut dosyasını çalıştırma
CLI'da komut dosyasını çalıştırın:
Python
python3 quickstart.py
Node.js
node index.js
Java
mvn compile exec:java -Dexec.mainClass=App
Apps Komut Dosyası
- Çalıştır'ı tıklayın.
Kodu çalıştırdığınızda webhook, kaydettiğiniz alana bir mesaj gönderir.
Mesaj dizisi başlatma veya yanıtlama
İleti isteği gövdesinin bir parçası olarak
spaces.messages.thread.threadKey
belirtin. Bir ileti dizisini başlatmanıza veya yanıtlama durumunuza bağlı olarakthreadKey
için aşağıdaki değerleri kullanın:Bir ileti dizisi başlatıyorsanız
threadKey
değerini rastgele bir dizeye ayarlayın ancak ileti dizisine yanıt göndermek için bu değeri not edin.Bir ileti dizisini yanıtlarken ileti dizisi başlatıldığında ayarlanan
threadKey
değerini belirtin. Örneğin, ilk mesajdaMY-THREAD
kullanılan ileti dizisine yanıt göndermek içinMY-THREAD
değerini ayarlayın.
Belirtilen
threadKey
bulunamazsa ileti dizisinin davranışını tanımlayın:Bir mesaj dizisini yanıtlayın veya yeni bir mesaj dizisi başlatın. Webhook URL'sine
messageReplyOption=REPLY_MESSAGE_FALLBACK_TO_NEW_THREAD
parametresini ekleyin. Bu URL parametresinin iletilmesi, Chat'in belirtilenthreadKey
kullanılarak mevcut bir ileti dizisini aramasını sağlar. Bir tane bulunursa mesaj, söz konusu ileti dizisine yanıt olarak yayınlanır. Eşleşme bulunamazsa ileti, ilgilithreadKey
ile eşleşen yeni bir ileti dizisi başlatır.İleti dizisini yanıtlayın veya hiçbir şey yapmayın. Webhook URL'sine
messageReplyOption=REPLY_MESSAGE_OR_FAIL
parametresini ekleyin. Bu URL parametresinin iletilmesi, Chat'in belirtilenthreadKey
kullanılarak mevcut bir ileti dizisini aramasını sağlar. Bir tane bulunursa mesaj, söz konusu ileti dizisine yanıt olarak yayınlanır. Hiçbiri bulunamazsa mesaj gönderilmez.
Daha fazla bilgi için
messageReplyOption
sayfasına bakın.
Aşağıdaki kod örneği, bir mesaj dizisini başlatır veya yanıtlar:
Python
Node.js
Apps Komut Dosyası
Hataları işleme
Webhook istekleri aşağıdakiler dahil olmak üzere çeşitli nedenlerle başarısız olabilir:
- Geçersiz istek.
- Webhook veya webhook'u barındıran alan silinir.
- Ağ bağlantısı veya kota sınırları gibi aralıklı sorunlar.
Webhook'unuzu oluştururken hataları uygun şekilde ele almak için şunları yapmalısınız:
- Hatayı günlüğe kaydetme
- Zamana dayalı, kota veya ağ bağlantısı hataları için eksponansiyel geri yüklemeyle isteği yeniden deneme.
- Hiçbir şey yapmayın. Bu, webhook mesajı göndermek önemli değilse uygundur.
Google Chat API, hataları google.rpc.Status
olarak döndürür.
Bu, karşılaşılan hata türünü belirten bir HTTP hatası code
içerir: istemci hatası (400 serisi) veya sunucu hatası (500 serisi). Tüm HTTP eşlemelerini incelemek için google.rpc.Code
bölümüne bakın.
{
"code": 503,
"message": "The service is currently unavailable.",
"status": "UNAVAILABLE"
}
HTTP durum kodlarını yorumlama ve hataları işleme hakkında bilgi edinmek için Hatalar bölümüne bakın.
Sınırlamalar ve dikkat edilmesi gereken noktalar
- Google Chat API'de webhook ile mesaj oluştururken yanıt, mesajın tamamını içermiyor.
Yanıtta yalnızca
name
vethread.name
alanları dolduruluyor. - Webhook'lar,
spaces.messages.create
için alan başına kotaya tabidir: Saniyede 1 istek, alandaki tüm webhook'lar arasında paylaşılır. Chat, aynı alanda saniyede 1 sorguyu aşan webhook isteklerini de reddedebilir. Chat API kotaları hakkında daha fazla bilgi için Kullanım sınırları başlıklı makaleyi inceleyin.