Ekspor/pemulihan Git

Agen Percakapan (Dialogflow CX) terintegrasi dengan beberapa penyedia Git (GitHub, Gitlab, Bitbucket, dan lainnya). Integrasi ini memudahkan Anda untuk mengekspor agen ke JSON untuk push ke penyedia Git, dan menarik dari penyedia Git untuk pemulihan agen. Format JSON yang diekspor dan dikirim ke penyedia Git adalah konten file zip yang diperluas dari agen yang diekspor.

Dengan menggunakan fitur ini, Anda dapat memanfaatkan fitur kontrol sumber penyedia Git seperti:

  • Peninjauan perubahan agen menggunakan alat peninjauan kode
  • Memeriksa perbedaan agen menggunakan alat perbedaan
  • Penggabungan

Batasan

Batasan berikut berlaku:

  • [Khusus versi integrasi lama] GitHub API memiliki batasan jumlah file yang dapat diperbarui dalam satu commit. Jika jumlah file melebihi 500, Anda mungkin tidak dapat melakukan push ke GitHub dari Agen Percakapan (Dialogflow CX). Dalam kasus tersebut, Anda dapat mengekspor agen sebagai zip dan menggunakan Git CLI di komputer untuk mendorong file agen ke GitHub. Batasan ini akan diatasi dalam rilis Agen Percakapan (Dialogflow CX) selanjutnya.
  • Repositori yang dihosting sendiri dengan akses pribadi GitHub tidak didukung, karena Agen Percakapan (Dialogflow CX) tidak dapat mengakses repositori ini.
  • Repositori Git tidak boleh berisi file apa pun selain file agen yang diekspor oleh ekspor agen. File lain apa pun di repositori akan dihapus pada setiap push.

Konfigurasi

Untuk mengonfigurasi fitur ini, Anda perlu mendapatkan token akses dari penyedia Git, menyimpan token tersebut di Secret Manager, dan memberikan resource secret ke Agen Percakapan (Dialogflow CX):

Token akses

Untuk mendapatkan token akses dari penyedia Git Anda:

GitHub

Anda perlu mendapatkan token pribadi GitHub Jika menggunakan token akses pribadi terperinci, Anda memerlukan akses izin berikut:

  • Izin Repositori > Konten: Baca dan tulis
  • Repository Permissions > Metadata: Hanya baca (harus dipilih secara otomatis setelah memilih izin Konten)

Gitlab

Anda perlu memperoleh token akses pribadi Gitlab.

Bitbucket

Anda perlu mendapatkan token akses Bitbucket.

Secret Manager

Setelah memiliki token akses, Anda perlu membuat secret untuk token:

  1. Aktifkan Secret Manager API.
  2. Buat secret.

Konfigurasi Agen Percakapan (Dialogflow CX)

Untuk mengonfigurasi integrasi ini bagi Agen Percakapan (Dialogflow CX):

  1. Berikan izin agen layanan Dialogflow untuk mengakses Secret Manager. Berikan peran Secret Manager Secret Accessor ke akun layanan gcp-sa-dialogflow.iam.gserviceaccount.com di project agen Anda. Lihat Memberikan peran IAM.
  2. Buka konfigurasi integrasi Git:
    • Konsol Agen Percakapan
      1. Buka tampilan setelan dengan mengklik ikon setelan di dekat pojok kanan atas.
      2. Scroll ke bawah, lalu klik Tambahkan integrasi Git.
    • Konsol Dialogflow CX
      1. Klik tab Kelola.
      2. Klik Git di bagian Pengujian & Deployment.
      3. Klik Buat baru.
  3. Berikan detail konfigurasi:
    1. Masukkan hal berikut:
      • Nama tampilan untuk koneksi GitHub.
      • URL repositori Git (misalnya: https://github.com/<path-to-repo>.git).
      • Tambahkan cabang Git yang akan berinteraksi dengan agen Anda. Anda dapat menetapkan cabang sebagai cabang default dengan mengklik ikon bintang di sampingnya.
      • Secret token akses, yang merupakan versi secret yang Anda buat dalam bentuk projects/*/secrets/*/versions/* untuk versi tertentu atau projects/*/secrets/*/versions/latest untuk versi terbaru.
    2. Klik Connect.
    3. Mungkin perlu waktu satu menit hingga layanan Git siap. Konsol akan menampilkan notifikasi.

Mendorong dan memulihkan

Setelah dikonfigurasi, Anda dapat mendorong/menarik agen ke/dari Git.

Tombol Push digunakan untuk mengekspor agen Anda dan membuat commit ke cabang Git yang dipilih di dropdown cabang Git. Commit ini akan terdiri dari seluruh agen, bukan perubahan tertentu, dan akan menghapus file yang ada di repositori.

Pengguna dengan peran Dialogflow Reader memiliki kemampuan untuk melakukan push ke repositori Git. Untuk mencegah push yang tidak diinginkan, konfigurasikan agen ini dengan token akses pribadi hanya baca.

Tombol Restore digunakan untuk mengambil data agen dari cabang Git yang dipilih di drop-down cabang Git dan memulihkan agen Agen Percakapan (Dialogflow CX) dari data ini. Tindakan ini akan menimpa agen Anda dengan cara yang sama seperti perilaku pemulihan agen.

Contoh kasus penggunaan

Contoh berikut mengilustrasikan cara fitur ini dapat digunakan oleh beberapa orang untuk mengusulkan perubahan agen yang berbeda ke agen produksi.

Pertimbangkan bahwa agen Anda menggunakan cabang Git berikut:

  • Prod: cabang untuk agen produksi Anda
  • Dev1: cabang untuk pengembangan agen
  • Dev2: cabang lain untuk pengembangan agen

Pengguna 1 ingin mengusulkan perubahan agen dan melakukan langkah-langkah berikut:

  1. Mengekspor agen produksi ke agen baru.
  2. Buat perubahan yang diinginkan pada salinan agen ini.
  3. Uji perubahan.
  4. Kirim agen yang diubah ke cabang Dev1.
  5. Buat permintaan penggabungan ke cabang Prod.

Pengguna 2 ingin mengusulkan perubahan agen dan melakukan langkah-langkah berikut:

  1. Mengekspor agen produksi ke agen baru.
  2. Buat perubahan yang diinginkan pada salinan agen ini.
  3. Uji perubahan.
  4. Kirim agen yang diubah ke cabang Dev2.
  5. Buat permintaan penggabungan ke cabang Prod.

Pengguna 3 meninjau permintaan penggabungan dari kedua pengguna dan melakukan langkah-langkah berikut:

  1. Menyelesaikan konflik.
  2. Melakukan commit pada perubahan yang disetujui.
  3. Memulihkan cabang Git produksi ke agen Agen Percakapan (Dialogflow CX) produksi.