মিথুনের সাথে Google চ্যাটের জন্য অ্যাপ তৈরি করুন

১. শুরু করার আগে

জেমিনির সাথে গুগল চ্যাট অ্যাপগুলি কী কী?

জেমিনি সহ গুগল চ্যাট অ্যাপগুলি নিম্নলিখিত কাজ করে:

  • আপনার পরিষেবা এবং রিসোর্সগুলিকে Google Chat-এ আনুন, যা ব্যবহারকারীদের কথোপকথন থেকে বেরিয়ে না গিয়ে তথ্য পেতে এবং পদক্ষেপ নিতে সাহায্য করে।
  • জেনারেটিভ এআই মডেল জেমিনির সাথে একীভূত করুন, যাতে তারা আপনার কর্মপ্রবাহকে সুবিন্যস্ত করার জন্য নির্দিষ্ট সময়ে টেক্সট বা ছবির মতো ডেটা তৈরি বা অনুসন্ধান করতে পারে।

কেন গুগল চ্যাট অ্যাপগুলিকে জেমিনির সাথে একীভূত করবেন?

জেমিনির মতো জেনারেটিভ এআই মডেলগুলির সাধারণ ব্যবহারের ক্ষেত্রে নিম্নলিখিত বিভাগগুলি অন্তর্ভুক্ত রয়েছে:

  • কন্টেন্ট তৈরি এবং বর্ধন । মার্কেটিং কপি তৈরি করুন, সোশ্যাল মিডিয়া পোস্ট তৈরি করুন, বাস্তবসম্মত ছবি তৈরি করুন, সঙ্গীত রচনা করুন, অথবা ভিডিও কন্টেন্ট তৈরিতে সহায়তা করুন।
  • তথ্য অনুসন্ধান । একটি অসংগঠিত জ্ঞান ভিত্তি থেকে মূল অন্তর্দৃষ্টি বের করুন, দীর্ঘ লেখার সারসংক্ষেপ করুন, বিষয়বস্তু শ্রেণীবদ্ধ করুন, অথবা উন্নত নির্ভুলতা এবং গতির সাথে ভাষা অনুবাদ করুন।
  • কথোপকথন । স্বাভাবিক, তথ্যবহুল এবং সৃজনশীল কথোপকথনে অংশগ্রহণ করুন।

গুগল চ্যাটের পরিচিত ইন্টারফেসের মধ্যে এই ক্ষমতাগুলি সরাসরি একীভূত করার ক্ষমতা তাদের ব্যবহারকারীদের অভিজ্ঞতা এবং উৎপাদনশীলতা উন্নত করতে চান এমন যে কারও জন্য একটি বিশাল সুযোগ।

পূর্বশর্ত

তুমি যা বানাও

এই কোডল্যাবে, আপনি পূর্ববর্তী বিভাগে প্রবর্তিত তিনটি ব্যবহারের ক্ষেত্রে জেমিনি দিয়ে তিনটি গুগল চ্যাট অ্যাপ তৈরি করবেন।

সমস্যা ব্যবস্থাপনা অ্যাপ (বিষয়বস্তু তৈরি এবং বর্ধিতকরণ)

এই অ্যাপটি নিম্নলিখিত কাজ করে:

  • মৌলিক মিথস্ক্রিয়া, অ্যাপ হোম এবং অ্যাপ প্রমাণীকরণের মাধ্যমে তৈরি থেকে বন্ধ পর্যন্ত সমস্যাগুলি পরিচালনা করে।
  • বার্তাগুলি পর্যবেক্ষণ করে এবং ইভেন্ট এবং আনুষঙ্গিক উইজেটগুলির সাথে অন্তর্ভুক্তিমূলক সহায়তা প্রদান করে।

আপনি নিম্নলিখিত কাজগুলি করার জন্য মিথুন ব্যবহার করেন:

  • বার্তার ইতিহাস এবং সমস্যার বিবরণের উপর ভিত্তি করে সমস্যা প্রতিবেদন তৈরি করুন।
  • গেটেড প্রম্পট সহ বার্তাগুলিতে অ-সমেত শব্দগুলিকে শ্রেণীবদ্ধ করুন।

ব্যবহৃত প্রধান প্রযুক্তিগুলি হল Vertex AI, Gemini, Apps Script, এবং Google Workspace API (Admin, Chat, Docs, Events)।

22efdecff4601417.png সম্পর্কে

2d127c63518673b2.png সম্পর্কে

9aea694937f2f3ed.png সম্পর্কে

এই অ্যাপটি প্রাকৃতিক ভাষায় প্রশ্নগুলি বুঝতে এবং উত্তর দিতে এবং অসংগঠিত ডেটা থেকে উৎস রেফারেন্স ফেরত দিতে জেমিনির উপর নির্ভর করে।

ব্যবহৃত প্রধান প্রযুক্তিগুলি হল ডায়ালগফ্লো সিএক্স ডেটা স্টোর এজেন্ট, ডায়ালগফ্লো সিএক্স ওয়েবহুক, গুগল ক্লাউড ফাংশন এবং জেমিনি।

9468866bfe848bb8.png সম্পর্কে

প্রতিক্রিয়া অ্যাপ (কথোপকথন)

এই অ্যাপটি স্বাভাবিক ভাষায় কথোপকথনের সাথে পর্যালোচনা সংগ্রহ এবং সংরক্ষণের জন্য জেমিনির উপর নির্ভর করে।

ব্যবহৃত প্রধান প্রযুক্তিগুলি হল ডায়ালগফ্লো সিএক্স এজেন্ট, ডায়ালগফ্লো সিএক্স টুল, ওপেনএপিআই, গুগল ক্লাউড ফাংশন এবং জেমিনি।

99a7a0295f122f31.png সম্পর্কে

তুমি যা শিখো

  • ভার্টেক্স এআই-এর মাধ্যমে জেমিনির সাথে গুগল চ্যাট অ্যাপগুলিকে কীভাবে একীভূত করবেন।
  • কীভাবে গুগল চ্যাট অ্যাপগুলিকে ডায়ালগফ্লো সিএক্স এজেন্টের সাথে একীভূত করবেন।
  • গুগল চ্যাটের সর্বশেষ বৈশিষ্ট্যগুলি কীভাবে ব্যবহার করবেন: অ্যাপ হোম, গুগল চ্যাট ইভেন্ট এবং আনুষঙ্গিক উইজেট।

তোমার যা দরকার

2. সেট আপ করুন

রিসোর্স শুরু করুন

এই বিভাগে, আপনি আপনার পছন্দের ওয়েব ব্রাউজার থেকে নিম্নলিখিত সংস্থানগুলি অ্যাক্সেস এবং কনফিগার করতে পারবেন।

অ্যাপস স্ক্রিপ্ট প্রকল্প

অ্যাপস স্ক্রিপ্ট কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. সেটিংসে ক্লিক করুন এবং তারপর Google Apps Script API সক্ষম করুন।

অনুসরণ

  1. আপনার প্রকল্পটি নির্বাচন করুন।
  2. প্রজেক্ট সেটিংসে ক্লিক করুন।
  3. এডিটর চেকবক্সে " appsscript.json " ম্যানিফেস্ট ফাইল দেখান নির্বাচন করুন।
  4. প্রকল্পটির নাম পরিবর্তন করে Chat Apps Gemini রাখুন।

12c1485bd248b766.png সম্পর্কে

গুগল ক্লাউড প্রকল্প

গুগল ক্লাউড কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার প্রকল্পটি নির্বাচন করুন।
  2. মেনু ☰ > API এবং পরিষেবা > OAuth সম্মতি স্ক্রিন > অ্যাপ সম্পাদনা করুন এ ক্লিক করুন, এবং তারপর অ্যাপের নাম Chat Apps Gemini এ সেট করুন।

  1. গুগল চ্যাট এপিআই কনফিগারেশনে নেভিগেট করুন, এবং তারপর অ্যাপের নাম এবং বর্ণনাকে Chat Apps Gemini তে সেট করুন।

a71f040755da3b8b.png সম্পর্কে

গুগল চ্যাট

গুগল চ্যাটে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. প্রয়োজনে, আপনার গুগল চ্যাট অ্যাপ দিয়ে চ্যাট শুরু করুন।
  2. এটি কাজ করছে কিনা তা নিশ্চিত করার জন্য Hello এর মতো একটি বার্তা পাঠান।

9625418251528ae9.png সম্পর্কে

স্থানীয়ভাবে সোর্স কোড এবং রিসোর্স ডাউনলোড করুন

  1. এই GitHub সংগ্রহস্থলটি ডাউনলোড করুন।

  1. আপনার পছন্দের ডেভেলপমেন্ট পরিবেশে, apps-script ডিরেক্টরিটি খুলুন এবং তারপর আপনার টার্মিনালে একই ডিরেক্টরিতে নেভিগেট করুন।

da9478df97c99194.png সম্পর্কে

clasp ইনস্টল এবং কনফিগার করুন

আমরা স্থানীয় পরিবেশ থেকে অ্যাপস স্ক্রিপ্ট প্রকল্পে সোর্স কোডের সংস্করণগুলি সহজেই সম্পাদনা এবং পুশ করার জন্য clasp ব্যবহার করি।

  1. আপনার স্থানীয় পরিবেশে, node , npm , এবং clasp এর সর্বশেষ সংস্করণগুলি ইনস্টল করুন
npm install -g @google/clasp
  1. আপনার অ্যাকাউন্ট দিয়ে লগ ইন করুন :
clasp login

8bc2434e6dc6f22a.png সম্পর্কে

সফল হলে, আপনার ওয়েব ব্রাউজারে একটি মৌলিক নিশ্চিতকরণ স্ক্রিন দেখতে পাবেন এবং আপনার ক্লায়েন্ট শংসাপত্র সহ .clasprc.json ফাইলটি আপডেট করা হবে। আপনি আপনার টার্মিনালে এটি কোথায় অবস্থিত তা খুঁজে পেতে পারেন।

e1d833eb4d5b3a8f.png

৩. অ্যাপ ১: বিল্ড

ধারণাগুলি পর্যালোচনা করুন

ভার্টেক্স এআই

ভার্টেক্স এআই জেনারেটিভ এআই তৈরি এবং ব্যবহার করার জন্য আপনার যা কিছু প্রয়োজন তা অফার করে, যার মধ্যে রয়েছে এআই সলিউশন, এজেন্ট বিল্ডার, ১৩০ টিরও বেশি ফাউন্ডেশন মডেল এবং একটি ইউনিফাইড এআই প্ল্যাটফর্ম।

c9e9c7a1945b22ac.png সম্পর্কে

মিথুন রাশি

জেমিনি হল গুগলের একটি মাল্টিমডাল এলএলএম যা ভার্টেক্স এআই এর মাধ্যমে অ্যাক্সেসযোগ্য। এটি মানুষকে তাদের মানবিক সম্ভাবনা উন্মোচন করতে সাহায্য করে যাতে তারা তাদের কল্পনাশক্তি বৃদ্ধি করতে পারে, তাদের কৌতূহল প্রসারিত করতে পারে এবং তাদের উৎপাদনশীলতা বৃদ্ধি করতে পারে।

উন্নত চ্যাট পরিষেবা

অ্যাডভান্সড চ্যাট পরিষেবা আপনাকে অ্যাপস স্ক্রিপ্টে গুগল চ্যাট এপিআই ব্যবহার করতে দেয়। এটি স্ক্রিপ্টগুলিকে চ্যাট স্পেস খুঁজে পেতে, তৈরি করতে এবং পরিবর্তন করতে, স্পেসে সদস্যদের যোগ করতে বা সরাতে এবং টেক্সট, কার্ড, সংযুক্তি এবং প্রতিক্রিয়া সহ বার্তা পড়তে বা পোস্ট করতে দেয়।

স্থাপত্য পর্যালোচনা করুন

8c9c7b7328a69ea6.png সম্পর্কে

এই Google Chat অ্যাপটি Apps Script দিয়ে তৈরি। এটি নিম্নলিখিতভাবে কাজ করে:

  1. একজন ব্যবহারকারী অ্যাপে একটি বার্তা পাঠান, হয় সরাসরি বার্তায় অথবা একটি স্পেসে।
  2. অ্যাপস স্ক্রিপ্ট প্রকল্পে বাস্তবায়িত এবং গুগল ক্লাউড প্রকল্পের সাথে যুক্ত এই অ্যাপটি বার্তাটি প্রক্রিয়া করে।
  3. অ্যাপটি গুগল ডক্স এবং গুগল চ্যাট এপিআই-এর সাথে একীভূত হয়।
  4. অ্যাপটি স্ক্রিপ্ট বৈশিষ্ট্যে ডেটা ধরে রাখার জন্য প্রোপার্টি পরিষেবা ব্যবহার করে।
  5. অ্যাপটি সরাসরি বার্তায় অথবা মূল স্থানে একটি সমলয় প্রতিক্রিয়া পাঠায়।

পর্যালোচনা প্রবাহ

সমস্যা তৈরি করুন

অনুসরণ

নির্দিষ্ট স্থান থেকে সমস্যার সমাধান করুন

51b47714c378a24b.png সম্পর্কে

নির্দিষ্ট স্থান থেকে সমস্যাটি বন্ধ করুন

89e50228deeab0f9.png সম্পর্কে

সোর্স কোড পর্যালোচনা করুন

অ্যাপস স্ক্রিপ্ট প্রকল্পে নিম্নলিখিত স্ক্রিপ্টগুলি রয়েছে:

  • Configuration : পরিবেশের উপর ভিত্তি করে সম্পাদনা করার জন্য ধ্রুবক।
  • ChatApp : মেসেজ, কার্ড ক্লিক, স্ল্যাশ কমান্ড এবং ডায়ালগ সহ Google Chat ইন্টারঅ্যাকশন ইভেন্ট পরিচালনা করে।
  • Storage : প্রপার্টি পরিষেবার উপর নির্ভরশীল ইউটিলিটি ফাংশন।
  • ChatAppAuth : ইউটিলিটি ফাংশন যা গুগল চ্যাট অ্যাপ প্রমাণীকরণের উপর নির্ভর করে।
  • Docs : গুগল ডক্সের উপর নির্ভরশীল ইউটিলিটি ফাংশন।
  • VertexAi : ভার্টেক্স এআই-এর উপর নির্ভরশীল ইউটিলিটি ফাংশন।

এবং জেমিনি এবং চ্যাট স্পেস ইতিহাসের সাথে রিপোর্ট ডকুমেন্ট তৈরি করার সময় সক্রিয়ভাবে ব্যবহৃত অংশগুলি এখানে দেওয়া হল:

অ্যাপস্ক্রিপ্ট.জেসন

// Enables the Admin SDK Directory and Chat services, which you need to retrieve
// messages and usernames.

"enabledAdvancedServices": [
  ...
  {
    "userSymbol": "AdminDirectory",
    "version": "directory_v1",
    "serviceId": "admin"
  },
  {
    "userSymbol": "Chat",
    "version": "v1",
    "serviceId": "chat"
  }
  ...
]
// Includes the OAuth scopes to request the Admin SDK Directory, Google Chat,
// Google Docs, and Vertex AI APIs.

"oauthScopes": [
  ...
  "https://www.googleapis.com/auth/admin.directory.user.readonly",
  "https://www.googleapis.com/auth/chat.messages.readonly",
  "https://www.googleapis.com/auth/documents",
  "https://www.googleapis.com/auth/cloud-platform",
  ...
]

কনফিগারেশন.জেএস

// Relies on two constants: the first one is the Google Cloud project ID and the
// second one is the Vertex AI location to be used.

...
const PROJECT_ID = 'replace-with-gcp-project-id';
const VERTEX_AI_LOCATION_ID = 'us-central1';
...

ChatApp.js সম্পর্কে

// The slash command process function retrieves history, generates content, and passes
// it to the report generator.

function processSlashCommand(event) {
  ...
  if (event.message.slashCommand.commandId == CLOSE_COMMAND_ID
    && event.message.space.type !== "DM") {
    ...
    const history = exportSpaceHistory(spaceId);
    const summary = summarizeSpace(history);
    const docUrl = createReport(
      issue.title, issue.description, resolution, history, summary
    );
    ...
  }
  ...
}
/**
 * Fetches and concatenates the 100 first space messages by using the Google Chat API.
 *
 * Messages with slash commands are filtered (app command invocations).
 *
 * @return {string} concatenate space messages in the format "Sender's name: Message"
 */
function exportSpaceHistory(spaceName) {
  const messages = Chat.Spaces.Messages.list(spaceName, { 'pageSize': 100 }).messages;
  // Returns results after fetching message sender display names.
  let users = new Map();
  return messages
    .filter(message => message.slashCommand === undefined)
    .map(message =>
      `${getUserDisplayName(users, message.sender.name)}: ${message.text}`
    ).join('\n');
}
/**
 * Fetches a user's display name by using the Admin Directory API.
 *
 * A cache is used to only call the API once per user.
 *
 * @param {Map} cache the map containing users previously fetched
 * @param {string} userId the user ID to fetch
 * @return {string} the user's display name
 */
function getUserDisplayName(cache, userId) {
  if (cache.has(userId)) {
    return cache.get(userId);
  }
  let displayName = 'Unknown User';
  try {
    const user = AdminDirectory.Users.get(
      userId.replace("users/", ""),
      { projection: 'BASIC', viewType: 'domain_public' });
    displayName = user.name.displayName ? user.name.displayName : user.name.fullName;
  } catch (e) {
    // Ignores errors, uses 'Unknown User' by default.
  }
  cache.set(userId, displayName);
  return displayName;
}

VertexAi.js সম্পর্কে

/**
 * Summarizes a Google Chat space history with the Gemini Pro model using
 * Vertex AI API.
 *
 * @param {string} history the history
 * @return {string} the summary
 */
function summarizeSpace(history) {
  const url = `https://${VERTEX_AI_LOCATION_ID}-aiplatform.googleapis.com/v1`
    + `/projects/${PROJECT_ID}/locations/${VERTEX_AI_LOCATION_ID}`
    + "/publishers/google/models/gemini-1.0-pro:generateContent";
  const options = {
    method: "POST",
    headers: { Authorization: "Bearer " + ScriptApp.getOAuthToken() },
    contentType: "application/json",
    payload: JSON.stringify({
      contents: {
        role: "user",
        parts: {
          text: "Summarize the following conversation between engineers resolving"
              + " an issue in a few sentences.\n\n" + history
        }
      },
      safetySettings: {
        category: "HARM_CATEGORY_SEXUALLY_EXPLICIT",
        threshold: "BLOCK_LOW_AND_ABOVE"
      },
      generationConfig: {
        temperature: 0.2,
        topP: 0.8,
        topK: 40
      }
    })
  };

  return JSON.parse(UrlFetchApp.fetch(url, options).getContentText())
    .candidates[0].content.parts[0].text;
}

ডক্স.জেএস

// The report generator function adds two sections: the first one is for the summary and the second one is for history.
function createReport(..., history, summary) {
  ...
  body.appendParagraph("Summary").setHeading(DocumentApp.ParagraphHeading.HEADING1);
  body.appendParagraph(summary);
  body.appendParagraph("History").setHeading(DocumentApp.ParagraphHeading.HEADING1);
  body.appendParagraph(history);
  ...
}

গুগল ক্লাউড প্রোজেক্ট আপডেট করুন

API গুলি সক্ষম করুন

  1. গুগল ক্লাউড কনসোলে , গুগল ডক্স , গুগল অ্যাডমিন এসডিকে এবং ভার্টেক্স এআই এপিআই সক্ষম করুন:

  1. মেনু ☰ > API এবং পরিষেবা > সক্রিয় API এবং পরিষেবাগুলিতে ক্লিক করুন এবং তারপরে নিশ্চিত করুন যে API গুলি সক্ষম করা আছে।

পরিষেবা অ্যাকাউন্ট শুরু করুন

গুগল ক্লাউড কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. মেনু ☰ > IAM & Admin > পরিষেবা অ্যাকাউন্ট > + পরিষেবা অ্যাকাউন্ট তৈরি করুন এ ক্লিক করুন।

74cf57426419f39.png সম্পর্কে

  1. পরিষেবা অ্যাকাউন্টের নাম chat-app এ সেট করুন।
  2. পরিষেবা অ্যাকাউন্টের বিবরণ Chat app auth এ সেট করুন।
  3. তৈরি করুন এবং চালিয়ে যান ক্লিক করুন।
  4. সম্পন্ন ক্লিক করুন। আপনাকে পরিষেবা অ্যাকাউন্ট পৃষ্ঠায় পুনঃনির্দেশিত করা হবে এবং আপনি আপনার তৈরি করা পরিষেবা অ্যাকাউন্টটি দেখতে পাবেন।

ca0468f1f93990f9.png

  1. নতুন তৈরি করা পরিষেবা অ্যাকাউন্টটি নির্বাচন করুন।
  2. কী ট্যাবটি নির্বাচন করুন।
  3. কী যোগ করুন ক্লিক করুন।
  4. নতুন কী তৈরি করুন ক্লিক করুন।
  5. JSON নির্বাচন করুন।
  6. তৈরি করুন ক্লিক করুন।

9f7e6ea020978ab0.png সম্পর্কে

ডায়ালগটি বন্ধ হয়ে যায় এবং আপনার নতুন তৈরি পাবলিক/প্রাইভেট কী জোড়া স্বয়ংক্রিয়ভাবে আপনার স্থানীয় পরিবেশে JSON ফাইল হিসেবে ডাউনলোড হয়। আপনি যখন আপনার অ্যাপস স্ক্রিপ্ট প্রকল্পের সোর্স কোড সম্পাদনা করেন তখন আপনি এর সামগ্রীটি পরে ব্যবহার করেন।

Google Chat API কনফিগারেশন আপডেট করুন

গুগল ক্লাউড কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. একটি স্ল্যাশ কমান্ড যোগ করুন।
  2. নামটি /create এ সেট করুন।
  3. কমান্ড আইডি 1 তে সেট করুন।
  4. বর্ণনাকে Create a new issue হিসেবে সেট করুন।
  5. একটি ডায়ালগ খোলে চেকবক্সটি নির্বাচন করুন।
  6. আরেকটি স্ল্যাশ কমান্ড যোগ করুন।
  7. নাম /close এ সেট করুন।
  8. কমান্ড আইডি 2 তে সেট করুন।
  9. বর্ণনাকে " Close an issue এ সেট করুন।
  10. সংরক্ষণ করুন ক্লিক করুন।

bee2e7b63659ab33.png সম্পর্কে

অ্যাপস স্ক্রিপ্ট প্রজেক্ট আপডেট করুন

  • আপনার স্থানীয় টার্মিনালের বর্তমান ডিরেক্টরিটি issue-management/1-baseline এ পরিবর্তন করুন। এতে সোর্স কোড রয়েছে। আপনার অ্যাপস স্ক্রিপ্ট প্রকল্পে সোর্স কোডটি পুশ করার আগে, আপনাকে কয়েকটি জিনিস কনফিগার করতে হবে।

সোর্স কোড কনফিগার করুন

  1. Configuration.js ফাইলে CHAT_CREDENTIALS নামক JSON ধ্রুবকটিকে আপনার পূর্বে ডাউনলোড করা প্রাইভেট কী ফাইলের সামগ্রীতে সেট করুন।

d721f6bff73c5304.png সম্পর্কে

  1. গুগল ক্লাউড কনসোলে , মেনু ☰ > IAM এবং অ্যাডমিন > সেটিংস এ ক্লিক করুন।

  1. প্রকল্পের আইডি কপি করুন।

82592fa0bd113469.png সম্পর্কে

  1. Configuration.js ফাইলে PROJECT_ID নামের স্ট্রিং ধ্রুবকটিকে প্রজেক্ট আইডিতে সেট করুন।

383cee561130ceba.png দ্বারা পোস্ট করা 1 অনুবাদ, বিস্তারিত সব অনুবাদ

clasp সেটিংস কনফিগার করুন

সোর্স কোডটিকে সঠিক অ্যাপস স্ক্রিপ্ট প্রজেক্টে পুশ করার জন্য clasp সেটিংস শুরু করতে, এই পদক্ষেপগুলি অনুসরণ করুন:

  1. অ্যাপস স্ক্রিপ্ট কনসোলে , আপনার প্রকল্পটি নির্বাচন করুন।
  2. প্রকল্প সেটিংস নির্বাচন করুন।
  3. IDs এর অধীনে, Copy এ ক্লিক করুন।

20ea033b6de882c6.png সম্পর্কে

  1. বর্তমান ডিরেক্টরিতে, একটি .clasp.json ফাইল তৈরি করুন।
  2. <your-script-id> কপি করা আইডি দিয়ে প্রতিস্থাপন করুন।
  3. ফলাফলটি .clasp.json ফাইলে কপি করুন।
  4. .clasp.json ফাইলটি সংরক্ষণ করুন।
{
  "scriptId": "<your-script-id>"
}

সোর্স কোড পুশ করুন

  • নিম্নলিখিত কমান্ডটি চালান:
$clasp push
? Manifest file has been updated. Do you want to push and overwrite? Yes
└─ appsscript.json
└─ ChatApp.js
└─ ChatAppAuth.js
└─ Configuration.js
└─ Docs.js
└─ Storage.js
└─ VertexAi.js
Pushed 7 files.

চেষ্টা করে দেখুন

  1. গুগল চ্যাটে , অ্যাপে সরাসরি বার্তায় Hello! পাঠান। অ্যাপটি উত্তর দেয় না, কিন্তু একটি বার্তা আসে যা কনফিগারেশনের অনুরোধ করে।

অনুসরণ

  1. কনফিগার ক্লিক করুন।
  2. আপনার গুগল অ্যাকাউন্ট নির্বাচন করুন।
  3. প্রমাণীকরণ করুন।
  4. অ্যাপটি পর্যালোচনা করুন এবং অ্যাক্সেসের অনুমতি দিন।

4a2fd7ac5918bf1a.png সম্পর্কে

সফল হলে, আপনি ওয়েব পৃষ্ঠায় একটি মৌলিক নিশ্চিতকরণ স্ক্রিন দেখতে পাবেন এবং অ্যাপ থেকে আপনার মূল বার্তার একটি প্রকৃত প্রতিক্রিয়া দেখতে পাবেন।

acb9065568fe47d2.png সম্পর্কে

2d6ef9c62f47e082.png সম্পর্কে

  1. অ্যাপে আরেকটি সরাসরি বার্তা পাঠান, কিন্তু স্ল্যাশ কমান্ড /create দিয়ে।

be3f3c6eb0f929c1.png সম্পর্কে

  1. ডায়ালগে, Title কে Issue Title 1 এ সেট করুন।
  2. বর্ণনাকে ইস্যু Description 1 এ সেট করুন।
  3. তৈরি করুন ক্লিক করুন।

22efdecff4601417.png সম্পর্কে

অ্যাপটি নিম্নলিখিত কাজগুলি করে:

  1. ডায়ালগ বন্ধ করে।
  2. একই শিরোনামে নতুন তৈরি সংখ্যার জন্য নিবেদিত একটি স্থান তৈরি করে।
  3. নতুন তৈরি স্থানটিতে যোগদান করে।
  4. নতুন তৈরি হওয়া জায়গায় সমস্যার বর্ণনা সম্বলিত একটি বার্তা পাঠায়।
  5. নতুন তৈরি স্পেসের লিঙ্ক সহ আপনাকে সরাসরি একটি বার্তা পাঠায়।

3253cec2392e281f.png সম্পর্কে

  1. নতুন তৈরি করা জায়গায়, স্ল্যাশ কমান্ড /close এবং রেজোলিউশন সহ একটি বার্তা পাঠান যেমন Not reproducible

১৩২cc৪acfc১০b৯৮c.png

অ্যাপটি নিম্নলিখিত কাজগুলি করে:

  1. গুগল ডক্সে একটি রিপোর্ট ডকুমেন্ট তৈরি করে।
  2. নতুন তৈরি রিপোর্ট ডকুমেন্টের লিঙ্ক সহ সমস্যাটির জন্য নিবেদিত স্থানে একটি বার্তা পাঠায়।

2d127c63518673b2.png সম্পর্কে

  1. রিপোর্ট ডকুমেন্টটি খুলুন। এতে মৌলিক তথ্য, ইতিহাস এবং একটি সারাংশ রয়েছে।

9aea694937f2f3ed.png সম্পর্কে

৪. ঐচ্ছিক: অ্যাপ ১: অ্যাপ হোম যোগ করুন

ধারণাগুলি পর্যালোচনা করুন

অ্যাপ হোম হল একটি কাস্টমাইজেবল কার্ড মেসেজ যা একটি চ্যাট অ্যাপ ব্যবহারকারীকে পাঠায় যখন ব্যবহারকারী চ্যাট অ্যাপের মাধ্যমে সরাসরি মেসেজ থেকে হোম ট্যাব অ্যাক্সেস করে। এটি সাধারণত অ্যাপ ডকুমেন্টেশন বা একটি ওভারভিউ প্রদর্শনের জন্য ব্যবহৃত হয়। প্রযুক্তিগতভাবে, এটি পরিচালনা করার জন্য একটি ডেডিকেটেড ইভেন্ট রয়েছে এবং এটি কার্ড মেসেজের মতো একই মূল নীতির উপর ভিত্তি করে।

65f56f70f67a32e4.png সম্পর্কে

পর্যালোচনা প্রবাহ

সমস্যাগুলি পরিচালনা করুন

10663f5fc107fb3f.png সম্পর্কে

সোর্স কোড পর্যালোচনা করুন

অ্যাপস স্ক্রিপ্ট প্রজেক্টটি সম্পাদনা করা প্রয়োজন।

ChatApp.js সম্পর্কে

/**
 * Handles app home requests in Google Chat.
 * 
 * Displays the latest status of all issues.
 */
function onAppHome() {
  // Generates one card section per issue.
  var sections = [];
  for (var issueKey in appProperties.getProperties()) {
    const issue = JSON.parse(appProperties.getProperty(issueKey));
    if (issue.spaceId) {
      sections.push({
        header: `${issue.status} - ${issue.title}`,
        widgets: [{ textParagraph: {
            text: `Description: ${issue.description}`
          }}, { textParagraph: {
            text: `Resolution: ${issue.resolution}`
          }}, { buttonList: { buttons: [{
              text: "Open space",
              onClick: { openLink: {
                url: `https://mail.google.com/mail/u/0/#chat/space/${issue.spaceId}`
              }}
            }, {
              text: "Open report",
              onClick: { openLink: {
                url: issue.reportUrl !== "" ? issue.reportUrl : "docs.new"
              }},
              disabled: issue.reportUrl === ""
          }]}
        }]
      });
    }
  }

  return { action: { navigations: [{ push_card: {
    sections: sections
  }}]}};
}

গুগল ক্লাউড প্রোজেক্ট আপডেট করুন

গুগল ক্লাউড কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. ইন্টারেক্টিভ বৈশিষ্ট্য বিভাগের অধীনে, সাপোর্ট অ্যাপ হোম চেকবক্সটি নির্বাচন করুন।

97159c1c69ca8303.png সম্পর্কে

আপনার স্থানীয় পরিবেশে, এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার টার্মিনালের বর্তমান ডিরেক্টরিটি issue-management/2-app-home এ পরিবর্তন করুন। এতে আপনার ব্যবহার করার জন্য প্রয়োজনীয় সোর্স কোড রয়েছে।
  2. আপনার বর্তমান ডিরেক্টরিতে issue-management/1-baseline/.clasp.json ফাইলটি কপি করুন।
  3. আপনার বর্তমান ডিরেক্টরিতে issue-management/1-baseline/Configuration.js ফাইলটি অনুলিপি করুন যাতে এটি বিদ্যমান ডিরেক্টরিকে প্রতিস্থাপন করে।
  4. নিম্নলিখিত কমান্ডটি চালান:
clasp push

চেষ্টা করে দেখুন

গুগল চ্যাটে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. অ্যাপটিতে /create স্ল্যাশ কমান্ড দিয়ে সরাসরি একটি বার্তা পাঠান। অ্যাপটি একটি ডায়ালগ খুলবে।
  2. শিরোনামকে Issue Title 2 তে সেট করুন।
  3. বর্ণনাকে ইস্যু Description 2 তে সেট করুন।
  4. তৈরি করুন ক্লিক করুন।

3b2a8690e758f965.png সম্পর্কে

  1. Google Chat অ্যাপ ব্যবহার করে আপনার স্পেস থেকে হোম ট্যাবটি নির্বাচন করুন। আপনি যে সমস্যাগুলি তৈরি করেছেন তার বিবরণ দেখতে পাবেন।

ed8e32da0e6f2ac6.png সম্পর্কে

৫. ঐচ্ছিক: অ্যাপ ১: স্থান পর্যবেক্ষণ যোগ করুন

ধারণাগুলি পর্যালোচনা করুন

পাব/সাব

পাব/সাব হল একটি অ্যাসিঙ্ক্রোনাস এবং স্কেলেবল মেসেজিং পরিষেবা যা সেই বার্তাগুলি প্রক্রিয়াকরণকারী পরিষেবাগুলি থেকে বার্তা তৈরিকারী পরিষেবাগুলিকে আলাদা করে। পাব/সাব আপনাকে ইভেন্ট প্রযোজক এবং ভোক্তাদের একটি সিস্টেম তৈরি করতে দেয়, যাকে বলা হয় প্রকাশক এবং গ্রাহক । প্রকাশকরা সিঙ্ক্রোনাস রিমোট প্রসিডিউর কল (RPC) এর পরিবর্তে ইভেন্ট সম্প্রচারের মাধ্যমে অ্যাসিঙ্ক্রোনাসভাবে গ্রাহকদের সাথে যোগাযোগ করেন।

প্রকাশকরা কীভাবে বা কখন এই ইভেন্টগুলি প্রক্রিয়া করা হবে তা বিবেচনা না করেই Pub/Sub পরিষেবাতে ইভেন্টগুলি পাঠান। Pub/Sub তারপর তাদের প্রতিক্রিয়া জানাতে পারে এমন সমস্ত পরিষেবাগুলিতে ইভেন্টগুলি সরবরাহ করে। RPC-এর মাধ্যমে যোগাযোগকারী সিস্টেমগুলিতে, প্রকাশকদের গ্রাহকদের ডেটা পাওয়ার জন্য অপেক্ষা করতে হয়। তবে, Pub/Sub-তে অ্যাসিঙ্ক্রোনাস ইন্টিগ্রেশন সামগ্রিক সিস্টেমের নমনীয়তা এবং দৃঢ়তা বৃদ্ধি করে।

বিষয় : একটি নামযুক্ত সম্পদ যা বার্তাগুলির একটি ফিড উপস্থাপন করে। প্রকাশ বা সাবস্ক্রাইব করার আগে আপনাকে অবশ্যই একটি বিষয় তৈরি করতে হবে।

সাবস্ক্রিপশন : কোনও বিষয়ে প্রকাশিত বার্তাগুলি গ্রহণ করতে, আপনাকে অবশ্যই সেই বিষয়ে একটি সাবস্ক্রিপশন তৈরি করতে হবে। গ্রাহক ক্লায়েন্ট সেই বিষয়ে প্রকাশিত বার্তাগুলি গ্রহণ করে এবং প্রক্রিয়াজাত করে। একটি বিষয়ে একাধিক সাবস্ক্রিপশন থাকতে পারে, তবে একটি প্রদত্ত সাবস্ক্রিপশন একটি একক বিষয়ের অন্তর্গত।

Google Workspace ইভেন্ট

Google Workspace ইভেন্টগুলি Google Workspace রিসোর্সে পরিবর্তনগুলি উপস্থাপন করে, যেমন কখন রিসোর্স তৈরি, আপডেট বা মুছে ফেলা হয়। প্রাসঙ্গিক ইভেন্টগুলি অ্যাসিঙ্ক্রোনাসভাবে গ্রহণ এবং প্রক্রিয়া করার জন্য অ্যাপগুলি Google Workspace রিসোর্সে সাবস্ক্রাইব করতে পারে।

7816e477b112bfb6.png সম্পর্কে

Google Workspace Events API কীভাবে সাবস্ক্রিপশনের মাধ্যমে একটি অ্যাপে ইভেন্ট সরবরাহ করে তা এখানে দেওয়া হল:

  1. অ্যাপটি Google Workspace অ্যাপের একটি রিসোর্সে সাবস্ক্রাইব করে, যেমন একটি স্পেস।
  2. অ্যাপটি যে রিসোর্সে সাবস্ক্রাইব করেছে তা পরিবর্তিত হয়।
  3. Google Workspace অ্যাপটি Pub/Sub-এর একটি বিষয়ের উপর একটি ইভেন্ট সরবরাহ করে, যা অ্যাপের Google Workspace সাবস্ক্রিপশনের জন্য বিজ্ঞপ্তির শেষ বিন্দু হিসেবে কাজ করে। ইভেন্টটিতে রিসোর্সে কী পরিবর্তন হয়েছে তার ডেটা থাকে।
  4. অ্যাপটি ইভেন্টটি ধারণকারী পাব/সাব বার্তাটি প্রক্রিয়া করে এবং প্রয়োজনে পদক্ষেপ নেয়।

পর্যালোচনা প্রবাহ

সমস্যা তৈরি করুন (আপডেট)

6d7a9d7a68666a80.png সম্পর্কে

নির্দিষ্ট স্থান থেকে সমস্যা সমাধান করুন (আপডেট)

17e60f052f222456.png সম্পর্কে

নির্দিষ্ট স্থান থেকে সমস্যাটি বন্ধ করুন (আপডেট)

742d490ea0b6fe3a.png সম্পর্কে

সাবস্ক্রিপশন প্রক্রিয়া করুন

de3017100dec6401.png সম্পর্কে

সোর্স কোড পর্যালোচনা করুন

অ্যাপস স্ক্রিপ্ট প্রজেক্টটি সম্পাদনা করা প্রয়োজন।

অ্যাপস্ক্রিপ্ট.জেসন

// Enables the Workspace Events service.

"enabledAdvancedServices": [
  ...
  {
    "userSymbol": "WorkspaceEvents",
    "version": "v1",
    "serviceId": "workspaceevents"
  }
  ...
]

কনফিগারেশন.জেএস

// Adds two constants: the first one is the Pub/Sub topic ID and the second one
// is the Pub/Sub subscription ID to be used to retrieve Google Workspace events.

...
const GWS_PUBSUB_TOPIC_ID = `projects/${PROJECT_ID}/topics/workspace-events`;
const GWS_PUBSUB_SUBSCRIPTION_ID =
  `projects/${PROJECT_ID}/subscriptions/workspace-events-sub`;
...

ChatApp.js সম্পর্কে

// Edits the function to delete the subscription at issue closure.

function processSlashCommand(event) {
  ...
  if (event.message.slashCommand.commandId == CLOSE_COMMAND_ID
    && event.message.space.type !== "DM") {
    ...
    deleteSubscription(issue.subscriptionId);
    ...
  }
  ...
}
// Edits the function to create the subscription.

function createIssue(event) {
  ...
  const subscriptionId = createSpaceSubscription(spaceUrl);
  const createdIssue = saveCreatedIssue(..., subscriptionId);
  ...
}
// Edits the function to delete the subscription.

function onRemoveFromSpace(event) {
  ...
  deleteSubscription(issue.subscriptionId);
  ...
}

স্টোরেজ.জেএস

// Edits the function to keep track of the subscription ID.

function saveCreatedIssue(..., spaceId, subscriptionId) {
  ...
  appProperties.setProperty(spaceId, JSON.stringify({
    ...
    subscriptionId: subscriptionId,
    ...
  }));
  ...
}

ওয়ার্কস্পেসইভেন্ট.জেএস

/**
 * Creates a new subscription to Google Workspace Events associated to a
 * Google Chat space.
 * 
 * The subscription scope includes message creation events and resources.
 * 
 * @param {string} spaceId the space ID to create a subscription for
 * @return the ID of the newly created subscription
 */
function createSpaceSubscription(spaceId) {
  const operation = WorkspaceEvents.Subscriptions.create({
    targetResource: `//chat.googleapis.com/${spaceId}`,
    eventTypes: ["google.workspace.chat.message.v1.created"],
    notificationEndpoint: { pubsubTopic: GWS_PUBSUB_TOPIC_ID },
    payloadOptions: { includeResource: true },
  });

  return operation.response.name;
}
/**
 * Processes events from subscription by using the Google Cloud PubSub API.
 * 
 * It pulls and acknowledges each event.
 */
function processSubscription() {
  const response = UrlFetchApp.fetch(
    `https://pubsub.googleapis.com/v1/${GWS_PUBSUB_SUBSCRIPTION_ID}:pull`,
    {
      method: "POST",
      contentType: "application/json",
      headers: { "Authorization": "Bearer " + ScriptApp.getOAuthToken() },
      payload: JSON.stringify({ maxMessages: 10 })
    }
  );

  const messages = JSON.parse(response.getContentText()).receivedMessages;
  for (var messageIndex in messages) {
    const message = messages[messageIndex];
    const ceType = message.message.attributes["ce-type"];
    const dataStr = Utilities.newBlob(Utilities.base64Decode(message.message.data))
      .getDataAsString();
    if (ceType === "google.workspace.events.subscription.v1.expirationReminder") {
      // Renews subscription.
      renewSubscription(JSON.parse(dataStr).subscription.name);
    } else if (ceType === "google.workspace.chat.message.v1.created") {
      // Processes the message text when it's sent in a space.
      const chatMessage = JSON.parse(dataStr).message;
      if (chatMessage.sender.type !== "BOT") {
        console.log("Message was processed.");
      }
    }
    // Acknowledges successful processing to avoid getting it again next time.
    ackSubscription(message.ackId);
  }
}
/**
 * Acknowledges a subscription event by using the Google Cloud PubSub API.
 * 
 * @param {string} ackId the ID of the event acknowledgment to send
 */
function ackSubscription(ackId) {
  UrlFetchApp.fetch(
    `https://pubsub.googleapis.com/v1/${GWS_PUBSUB_SUBSCRIPTION_ID}:acknowledge`,
    {
      method: "POST",
      contentType: "application/json",
      headers: { "Authorization": "Bearer " + ScriptApp.getOAuthToken() },
      payload: JSON.stringify({
        ackIds: [ackId]
      })
    }
  );
}
/**
 * Renews a subscription to Google Workspace Events.
 * 
 * The default time to live option is used.
 * 
 * @param {string} subscriptionId the ID of the subscription to renew
 */
function renewSubscription(subscriptionId) {
  WorkspaceEvents.Subscriptions.patch({ttl: '0s'}, subscriptionId);
}
/**
 * Deletes a subscription to Google Workspace Events.
 * 
 * @param {string} subscriptionId the ID of the subscription to delete
 */
function deleteSubscription(subscriptionId) {
  WorkspaceEvents.Subscriptions.remove(subscriptionId);
}

গুগল ক্লাউড প্রোজেক্ট আপডেট করুন

API গুলি সক্ষম করুন

  1. গুগল ক্লাউড কনসোলে, গুগল ওয়ার্কস্পেস ইভেন্টস এবং পাবসব সক্ষম করুন।

  1. মেনু ☰ > API এবং পরিষেবা > সক্রিয় API এবং পরিষেবাগুলিতে ক্লিক করুন এবং তারপরে নিশ্চিত করুন যে উভয়ই সক্ষম।

সাবস্ক্রিপশন শুরু করুন

সমস্ত কর্মক্ষেত্রের ইভেন্ট পোস্ট করার জন্য আপনাকে একটি পাব/সাব বিষয় তৈরি করতে হবে এবং সাবস্ক্রাইব করতে হবে।

গুগল ক্লাউড কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. মেনু ☰ > পাব/সাব > বিষয়গুলিতে যান।

  1. বিষয় তৈরি করুন ক্লিক করুন।
  2. টপিক আইডি workspace-events এ সেট করুন।
  3. একটি ডিফল্ট সাবস্ক্রিপশন যোগ করুন চেকবক্সটি নির্বাচন করুন।
  4. তৈরি করুন ক্লিক করুন।

b39f9a0aec7c9939.png সম্পর্কে

গুগল চ্যাট থেকে আপনার নতুন তৈরি করা বিষয়ে পাব/সাব বার্তা প্রকাশের অ্যাক্সেস দিতে, এই পদক্ষেপগুলি অনুসরণ করুন:

  1. তালিকা থেকে বিষয় নির্বাচন করুন।
  2. অনুমতি ট্যাবটি নির্বাচন করুন।
  3. নতুন প্রিন্সিপালে chat-api-push@system.gserviceaccount.com যোগ করুন।
  4. ভূমিকার জন্য পাব/সাব প্রকাশক নির্বাচন করুন।
  5. সংরক্ষণ করুন ক্লিক করুন।

8d4016c37532503.png সম্পর্কে

অ্যাপস স্ক্রিপ্ট প্রজেক্ট আপডেট করুন

গুগল ক্লাউড কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. মেনু ☰ > IAM & Admin > সেটিংস এ যান।

  1. প্রকল্পের আইডি কপি করুন।

82592fa0bd113469.png সম্পর্কে

আপনার স্থানীয় পরিবেশে, এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার টার্মিনালের বর্তমান ডিরেক্টরিটি issue-management/3-message-monitoring এ পরিবর্তন করুন। এতে আপনার প্রয়োজনীয় সোর্স কোড রয়েছে।
  2. Configuration.js ফাইলে PROJECT_ID নামের স্ট্রিং ধ্রুবকটি কপি করা প্রজেক্ট আইডিতে সেট করুন।
  3. Configuration.js ফাইলে CHAT_CREDENTIALS নামক JSON ধ্রুবকটিকে আপনার আগে ডাউনলোড করা প্রাইভেট কী ফাইলের সামগ্রীতে সেট করুন।
  4. আপনার বর্তমান ডিরেক্টরিতে issue-management/2-app-home/.clasp.json ফাইলটি কপি করুন।
  5. নিম্নলিখিত কমান্ডটি চালান:
clasp push

চেষ্টা করে দেখুন

গুগল চ্যাটে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. অ্যাপটিতে /create স্ল্যাশ কমান্ড দিয়ে সরাসরি একটি বার্তা পাঠান। অ্যাপটি একটি ডায়ালগ খুলবে।
  2. শিরোনামকে Issue Title 3 এ সেট করুন।
  3. বর্ণনাকে ইস্যু Description 3 তে সেট করুন।
  4. তৈরি করুন ক্লিক করুন।
  5. নতুন তৈরি স্থানে, সমস্যাটি নিয়ে আলোচনা করে কয়েকটি বার্তা পাঠান।
  6. স্ল্যাশ কমান্ড /close এবং রেজোলিউশন যেমন Fixed সহ একটি বার্তা পাঠান।

গুগল ক্লাউড কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. মেনু ☰ > পাব/সাব > সাবস্ক্রিপশন এ যান।

  1. সাবস্ক্রিপশন workspace-events-sub নির্বাচন করুন।
  2. বার্তা ট্যাবটি নির্বাচন করুন।
  3. টানুন ক্লিক করুন। টেবিলটি নতুন তৈরি স্পেসে আপনি যা পাঠিয়েছেন তার সাথে সম্পর্কিত বার্তাগুলি প্রদর্শন করে।

82631c9792d83889.png সম্পর্কে

অ্যাপস স্ক্রিপ্ট কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার প্রকল্পটি নির্বাচন করুন।
  2. সম্পাদক নির্বাচন করুন।
  3. WorkspaceEvent.gs ফাইলটি নির্বাচন করুন।
  4. রান বিভাগে processSubscription নির্বাচন করুন।
  5. Run ক্লিক করুন। এক্সিকিউশন লগ থেকে আপনি দেখতে পাবেন যে বার্তাগুলি প্রক্রিয়া করা হয়েছে।

c612e8fa2bd0a163.png সম্পর্কে

গুগল ক্লাউড কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. মেনু ☰ > পাব/সাব > সাবস্ক্রিপশন এ যান।

  1. সাবস্ক্রিপশন workspace-events-sub নির্বাচন করুন।
  2. বার্তা ট্যাবটি নির্বাচন করুন।
  3. টানুন ক্লিক করুন। টেবিলটি আর নতুন তৈরি স্পেসে আপনার পাঠানো বার্তাগুলির সাথে সম্পর্কিত বার্তাগুলি প্রদর্শন করে না।

e185454cac862a7b.png

  • গুগল চ্যাটে , /create কমান্ড ব্যবহার করে তৈরি করা তৃতীয় ইস্যুর জন্য নিবেদিত স্থানে, সমস্যাটি নিয়ে আলোচনা করে আরও কয়েকটি বার্তা পাঠান।

গুগল ক্লাউড কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. মেনু ☰ > পাব/সাব > সাবস্ক্রিপশন এ যান।

  1. সাবস্ক্রিপশন workspace-events-sub নির্বাচন করুন।
  2. বার্তা ট্যাবটি নির্বাচন করুন।
  3. টানুন ক্লিক করুন। টেবিলটি নতুন তৈরি স্পেসে আপনি যা পাঠিয়েছেন তার সাথে সম্পর্কিত বার্তাগুলি প্রদর্শন করে না।

৬. ঐচ্ছিক: অ্যাপ ১: অন্তর্ভুক্তিমূলক সহায়তা যোগ করুন

ধারণাগুলি পর্যালোচনা করুন

জেনারেটিভ এআই প্রম্পটিং হলো একটি জেনারেটিভ এআই মডেলকে নির্দিষ্ট ধরণের কাঙ্ক্ষিত আউটপুটের দিকে পরিচালিত করার জন্য নির্দেশাবলী বা প্রশ্ন তৈরি করার শিল্প। একটি সাধারণ অভ্যাস হল প্রম্পটে নিয়ম এবং শর্তাবলী যোগ করে উত্তরগুলিকে গেট করা । এটি আউটপুটকে নিরাপদ, প্রাসঙ্গিক, সামঞ্জস্যপূর্ণ এবং প্রত্যাশার সাথে সামঞ্জস্যপূর্ণ করতে সাহায্য করতে পারে।

পর্যালোচনা প্রবাহ

সাবস্ক্রিপশন প্রক্রিয়া করুন (আপডেট)

780d0802f77dd180.png সম্পর্কে

সোর্স কোড পর্যালোচনা করুন

অ্যাপস স্ক্রিপ্ট প্রজেক্টটি সম্পাদনা করা প্রয়োজন।

ওয়ার্কস্পেসইভেন্ট.জেএস

// Edits the function to replace logging by an actual card message.

function processSubscription() {
  ...
  for (var messageIndex in messages) {
    ...
    } else if (ceType === "google.workspace.chat.message.v1.created") {
      ...
      const inclusivityCheck = getInclusivityFeedback(chatMessage.text);
      if (inclusivityCheck !== "It's inclusive!") {
        createAppMessageUsingChatService({
          cardsV2: [{ cardId: "1", card: { header: {
              title: "Inclusivity",
              subtitle: `The following words are not inclusive: ${inclusivityCheck}`
          }}}]
        },
        chatMessage.space.name);
      }
      ...
    }
    ...
  }
  ...
}

VertexAi.js সম্পর্কে

/**
 * Gets feedback on inclusivity for a text with the Gemini Pro model using
 * Vertex AI API.
 * 
 * Returns "It's inclusive!" when it is otherwise a list of word(s) that might not
 * be optimal.
 *
 * @param {string} text the text
 * @return {string} the feedback
 */
function getInclusivityFeedback(text) {
  const url = `https://${VERTEX_AI_LOCATION_ID}-aiplatform.googleapis.com/v1`
    + `/projects/${PROJECT_ID}/locations/${VERTEX_AI_LOCATION_ID}`
    + "/publishers/google/models/gemini-1.0-pro:generateContent";
  const options =  {
    method: "POST",
    headers: { Authorization: "Bearer " + ScriptApp.getOAuthToken() },
    contentType: "application/json",
    payload: JSON.stringify({
      contents: {
        role: "user",
        parts: {
          text: "Are there any words that obviously go against inclusivity "
            + "in this text:"
            + `\n\n----------\n${text}\n----------\n\n`
            + "If there are not, answer \"It's inclusive!\" "
            + "otherwise answer by listing them separated by commas. "
            + "Do not answer with any explanation."
        }
      },
      safetySettings: {
        category: "HARM_CATEGORY_SEXUALLY_EXPLICIT",
        threshold: "BLOCK_LOW_AND_ABOVE"
      },
      generationConfig: {
        temperature: 0.2,
        topP: 0.8,
        topK: 40
      }
    })
  };

  return JSON.parse(UrlFetchApp.fetch(url, options).getContentText())
    .candidates[0].content.parts[0].text;
}

অ্যাপস স্ক্রিপ্ট প্রজেক্ট আপডেট করুন

আপনার স্থানীয় পরিবেশে, এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার টার্মিনালের বর্তমান ডিরেক্টরিটি issue-management/4-inclusivity-help এ পরিবর্তন করুন। এতে আপনার প্রয়োজনীয় সোর্স কোড রয়েছে।
  2. আপনার বর্তমান ডিরেক্টরিতে issue-management/3-message-monitoring/.clasp.json ফাইলটি কপি করুন।
  3. আপনার বর্তমান ডিরেক্টরিতে issue-management/3-message-monitoring/Configuration.js ফাইলটি অনুলিপি করুন যাতে এটি বিদ্যমান ডিরেক্টরিকে প্রতিস্থাপন করে।
  4. নিম্নলিখিত কমান্ডটি চালান:
clasp push

চেষ্টা করে দেখুন

গুগল চ্যাটে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. অ্যাপটিতে /create স্ল্যাশ কমান্ড দিয়ে সরাসরি একটি বার্তা পাঠান। অ্যাপটি একটি ডায়ালগ খুলবে।
  2. শিরোনামকে Issue Title 4 এ সেট করুন।
  3. বর্ণনাকে ইস্যু Description 4 তে সেট করুন।
  4. তৈরি করুন ক্লিক করুন।
  5. নতুন তৈরি করা জায়গায়, It happened to me last week as well

অ্যাপস স্ক্রিপ্ট কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার প্রকল্পটি নির্বাচন করুন।
  2. সম্পাদক নির্বাচন করুন।
  3. WorkspaceEvent.gs ফাইলটি নির্বাচন করুন।
  4. রান বিভাগে processSubscription নির্বাচন করুন।
  5. Run এ ক্লিক করুন। এক্সিকিউশন লগ থেকে আপনি দেখতে পাবেন যে বার্তাগুলি প্রক্রিয়া করা হয়েছে।

গুগল চ্যাটে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. লক্ষ্য করুন যে অ্যাপটি নতুন তৈরি করা স্থানে কোনও অন্তর্ভুক্তিমূলক সহায়তা পাঠায়নি।
  2. নতুন তৈরি করা জায়গায়, I had to add myself from the master to fix it

অ্যাপস স্ক্রিপ্ট কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার প্রকল্পটি নির্বাচন করুন।
  2. সম্পাদক নির্বাচন করুন।
  3. WorkspaceEvent.gs ফাইলটি নির্বাচন করুন।
  4. রান বিভাগে processSubscription নির্বাচন করুন।
  5. Run এ ক্লিক করুন। এক্সিকিউশন লগ থেকে আপনি দেখতে পাবেন যে বার্তাগুলি প্রক্রিয়া করা হয়েছে। Google Chat- এ, অ্যাপটি নতুন তৈরি স্পেসে একটি অন্তর্ভুক্তিমূলক সহায়তা বার্তা পাঠিয়েছে।

7936342847acbe2d.png সম্পর্কে

৭. ঐচ্ছিক: অ্যাপ ১: পছন্দ যোগ করুন

.

ধারণাগুলি পর্যালোচনা করুন

একটি অ্যাক্সেসরি উইজেট হল একটি বর্ডারলেস উইজেট যা একটি অ্যাপ দ্বারা প্রেরিত বার্তার নীচে সংযুক্ত থাকে। এটি সাধারণত বার্তার নির্দিষ্ট প্রেক্ষাপটে ব্যবহারকারীর দ্রুত প্রতিক্রিয়া সক্ষম করার জন্য ব্যবহৃত হয়। প্রযুক্তিগতভাবে, এটি কার্ড বোতামগুলির মতো একই মূল নীতির উপর ভিত্তি করে।

অনুসরণ

পর্যালোচনা প্রবাহ

অন্তর্ভুক্তিমূলক সহায়তা অক্ষম করুন

1bb7a8592ee6221e.png সম্পর্কে

সোর্স কোড পর্যালোচনা করুন

অ্যাপস স্ক্রিপ্ট প্রজেক্টটি সম্পাদনা করা প্রয়োজন।

ChatApp.js সম্পর্কে

// Edits the function to handle the inclusivity help disablement action for a
// given space.

function onCardClick(event) {
  ...
  if (event.action.actionMethodName === "disableInclusivityHelp") {
    disableInclusivityHelp(event.common.parameters.spaceId);
  }
}

স্টোরেজ.জেএস

// Edits the function to keep track of the inclusivity help setting.

function saveCreatedIssue(title, description, spaceId, subscriptionId) {
  appProperties.setProperty(spaceId, JSON.stringify({
    ...
    inclusivityHelp: true,
    ...
  }));
  ...
}
/**
 * Disables inclusivity help in a space.
 * 
 * @param {string} spaceId the ID of dedicated space of the issue
 */
function disableInclusivityHelp(spaceId) {
  var issue = JSON.parse(appProperties.getProperty(spaceId));
  issue.inclusivityHelp = false;
  appProperties.setProperty(spaceId, JSON.stringify(issue));
}
/**
 * Checks whether the app should help with inclusivity in a given space.
 * 
 * @param {string} spaceId the ID of dedicated space of the issue
 * @return whether the app should help with inclusivity
 */
function shouldHelpWithInclusivity(spaceId) {
  return JSON.parse(appProperties.getProperty(spaceId)).inclusivityHelp;
}

ওয়ার্কস্পেসইভেন্ট.জেএস

// Edits the function to display the accessory widget to the existing card message.

function processSubscription() {
  ...
  for (var messageIndex in messages) {
    ...
    } else if (ceType === "google.workspace.chat.message.v1.created") {
      ...
      if (... && shouldHelpWithInclusivity(chatMessage.space.name)) {
        createAppMessageUsingChatService({
          ...
          accessoryWidgets: [{ buttonList: { buttons: [{
            altText: "Disable inclusivity help",
            icon: {
              iconUrl: "https://upload.wikimedia.org/.../Stop_hand_rugen.png"
            },
            onClick: { action: {
              function: "disableInclusivityHelp",
              parameters: [{
                key: "spaceId",
                value: chatMessage.space.name
              }]
            }}
          }]}}]
        }, ...);
        ...
      }
      ...
    }
    ...
  }
  ...
}

অ্যাপস স্ক্রিপ্ট প্রজেক্ট আপডেট করুন

আপনার স্থানীয় পরিবেশে, এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার টার্মিনালের বর্তমান ডিরেক্টরিটি issue-management/5-disable-help এ পরিবর্তন করুন। এতে আপনার প্রয়োজনীয় সোর্স কোড রয়েছে।
  2. আপনার বর্তমান ডিরেক্টরিতে issue-management/4-inclusivity-help/.clasp.json ফাইলটি কপি করুন।
  3. আপনার বর্তমান ডিরেক্টরিতে issue-management/4-inclusivity-help/Configuration.js ফাইলটি অনুলিপি করুন যাতে এটি বিদ্যমান ডিরেক্টরিকে প্রতিস্থাপন করে।
  4. নিম্নলিখিত কমান্ডটি চালান:
clasp push

চেষ্টা করে দেখুন

সাহায্য বন্ধ করুন

  • গুগল চ্যাটে , চতুর্থ সংখ্যার জন্য নিবেদিত স্থান যা আপনি স্ল্যাশ কমান্ড /create দিয়ে তৈরি করেছেন, সেই বার্তাটি পাঠান I had to add myself from the master to fix

অ্যাপস স্ক্রিপ্ট কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার প্রকল্পটি নির্বাচন করুন।
  2. সম্পাদক নির্বাচন করুন।
  3. WorkspaceEvent.gs ফাইলটি নির্বাচন করুন।
  4. রান বিভাগে processSubscription নির্বাচন করুন।
  5. Run এ ক্লিক করুন। এক্সিকিউশন লগ থেকে আপনি দেখতে পাবেন যে বার্তাগুলি প্রক্রিয়া করা হয়েছে।

গুগল চ্যাটে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. লক্ষ্য করুন যে অ্যাপটি একটি আনুষঙ্গিক উইজেট সহ সমস্যাটির জন্য নিবেদিত স্থানে অন্তর্ভুক্তিমূলক সহায়তা সহ একটি বার্তা পাঠিয়েছে।
  2. অন্তর্ভুক্তিমূলক সহায়তা নিষ্ক্রিয় করতে আনুষঙ্গিক উইজেটে ক্লিক করুন।

de722cff1928dec9.png সম্পর্কে

অক্ষমতা পরীক্ষা করুন

  • গুগল চ্যাটে , চতুর্থ সংখ্যার জন্য নিবেদিত স্থান যা আপনি স্ল্যাশ কমান্ড /create দিয়ে তৈরি করেছেন, সেই বার্তাটি পাঠান I had to add myself from the master to fix

অ্যাপস স্ক্রিপ্ট কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার প্রকল্পটি নির্বাচন করুন।
  2. সম্পাদক নির্বাচন করুন।
  3. WorkspaceEvent.gs ফাইলটি নির্বাচন করুন।
  4. রান বিভাগে processSubscription নির্বাচন করুন।
  5. Run এ ক্লিক করুন। এক্সিকিউশন লগ থেকে আপনি দেখতে পাবেন যে বার্তাগুলি প্রক্রিয়া করা হয়েছে। Google Chat- এ, অ্যাপটি সমস্যাটির জন্য নিবেদিত স্থানটিতে অন্তর্ভুক্তিমূলক সহায়তা সহ কোনও বার্তা পাঠায়নি কারণ এটি অক্ষম ছিল।

347d659db53b73e9.png সম্পর্কে

৮. অ্যাপ ২: বিল্ড

ধারণাগুলি পর্যালোচনা করুন

জেনারেশন এআই গ্রাউন্ডিং

এটি AI মডেলগুলিকে জ্ঞানের যাচাইযোগ্য উৎসের সাথে সংযুক্ত করে আরও বাস্তবসম্মত এবং নির্ভরযোগ্য করে তোলার বিষয়ে। এই কৌশলটি AI কে তথ্য উদ্ভাবন থেকে বিরত রাখতে সাহায্য করে এবং প্রতিক্রিয়াগুলিকে প্রাসঙ্গিকভাবে প্রাসঙ্গিক এবং কম পক্ষপাতদুষ্ট করতে সাহায্য করতে পারে।

স্বাভাবিক ভাষা

কৃত্রিম বা কম্পিউটার-ভিত্তিক ভাষার বিপরীতে, দৈনন্দিন যোগাযোগের জন্য মানুষের দ্বারা কথিত বা লিখিত যেকোনো ভাষা।

ক্লাউড স্টোরেজ

ক্লাউড স্টোরেজ বিশ্বব্যাপী যেকোনো সময় যেকোনো পরিমাণ ডেটা সংরক্ষণ এবং পুনরুদ্ধারের অনুমতি দেয়। এটি বিভিন্ন পরিস্থিতিতে ব্যবহার করা যেতে পারে, যার মধ্যে রয়েছে ওয়েবসাইটের বিষয়বস্তু পরিবেশন করা, আর্কাইভাল এবং দুর্যোগ পুনরুদ্ধারের জন্য ডেটা সংরক্ষণ করা, অথবা সরাসরি ডাউনলোডের মাধ্যমে ব্যবহারকারীদের কাছে বৃহৎ ডেটা অবজেক্ট বিতরণ করা।

ডায়ালগফ্লো সিএক্স ডেটা স্টোর

ডায়ালগফ্লো সিএক্স ডেটা স্টোরের সাথে একীভূত হয় যা ওয়েবসাইট এবং ডকুমেন্টের সংগ্রহ যা ডেটা স্টোর এজেন্টরা নির্দিষ্ট ডেটা থেকে ব্যবহারকারীর প্রশ্নের উত্তর খুঁজে পেতে ব্যবহার করে। একটি নির্দিষ্ট প্রশ্নের জন্য, ডেটা স্টোর এজেন্ট প্রদত্ত উৎস সামগ্রী থেকে একটি উত্তর অনুসন্ধান করে এবং ফলাফলগুলিকে একটি সুসংগত প্রতিক্রিয়ায় সারসংক্ষেপ করে। এটি শেষ ব্যবহারকারীকে আরও জানতে প্রতিক্রিয়ার উৎসগুলির সহায়ক লিঙ্কও প্রদান করে।

স্থাপত্য পর্যালোচনা করুন

9d3342d12f3b4dda.png সম্পর্কে

এই গুগল চ্যাট অ্যাপটি ডায়ালগফ্লো সিএক্স দিয়ে তৈরি এবং নিম্নলিখিতভাবে কাজ করে:

  1. একজন ব্যবহারকারী অ্যাপে একটি বার্তা পাঠান, হয় সরাসরি বার্তায় অথবা একটি স্পেসে।
  2. অ্যাপটি, যা একটি ডায়ালগফ্লো সিএক্স এজেন্ট এবং একটি গুগল ক্লাউড প্রকল্পের সাথে যুক্ত, বার্তাটি প্রক্রিয়া করে।
  3. অ্যাপটি ক্লাউড স্টোরেজে অবস্থিত একটি ডেটা স্টোরের সাথে একীভূত হয়।
  4. অ্যাপটি সরাসরি বার্তায় অথবা মূল স্থানে একটি সমলয় প্রতিক্রিয়া পাঠায়।

পর্যালোচনা প্রবাহ

প্রশ্নের উত্তর দিন

aad9fb5a7ca48956.png সম্পর্কে

সোর্স কোড পর্যালোচনা করুন

আপনার কেবলমাত্র কোডের প্রয়োজন নেই, বরং গ্রাউন্ডিংয়ের জন্য ব্যবহৃত ডেটা।

গুগল-চ্যাট-ওভারভিউ.পিডিএফ

এতে Google Workspace ডেভেলপার ওয়েবসাইটের একটি পৃষ্ঠার মুদ্রিত সংস্করণ, Google Chat অ্যাপের অসংগঠিত তথ্য রয়েছে।

e9b91c4587b1a3a0.png সম্পর্কে

গুগল ক্লাউড প্রোজেক্ট আপডেট করুন

গুগল ক্লাউড কনসোলে, এই পদক্ষেপগুলি অনুসরণ করুন:

  1. Dialogflow এবং Cloud Storage API গুলি সক্ষম করুন।

  1. Vertex AI Agent Builder API সক্রিয় করুন।

  1. মেনু ☰ > API এবং পরিষেবা > সক্রিয় API এবং পরিষেবাগুলিতে ক্লিক করুন এবং তারপরে নিশ্চিত করুন যে সমস্ত API সক্রিয় আছে।

.

Dialogflow CX ডেটা স্টোর এজেন্ট তৈরি করুন

জ্ঞানের তথ্য শুরু করুন

গুগল ক্লাউড কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. মেনু ☰ > ক্লাউড স্টোরেজ > বাকেটস এ ক্লিক করুন।

4f15978ae9f1b687.png সম্পর্কে

  1. তৈরি করুন ক্লিক করুন।
  2. নামটি gchat-knowledge এ সেট করুন।
  3. তৈরি করুন ক্লিক করুন।

6b38c6d4d2c41bba.png - [অনলাইন].

  1. gchat-knowledge বাকেটটি নির্বাচন করুন।
  2. ফাইল আপলোড করুন এ ক্লিক করুন।
  3. আপনার স্থানীয় পরিবেশ থেকে google-chat-overview.pdf ফাইলটি ডাউনলোড করুন এবং নির্বাচন করুন।

df89acb22e1762af.png সম্পর্কে

অ্যাপ তৈরি করুন

গুগল ক্লাউড কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. মেনু ☰ > এজেন্ট বিল্ডার > অ্যাপস এ ক্লিক করুন।

  1. নতুন অ্যাপে ক্লিক করুন।
  2. চ্যাটের ধরণটি নির্বাচন করুন।

44276003074bcf14.png সম্পর্কে

  1. আপনার কোম্পানির নামের সাথে Company name সেট করুন।
  2. Agent name knowledge এ সেট করুন।
  3. চালিয়ে যান ক্লিক করুন।

c4fedfd7556f723b.png সম্পর্কে

  1. নতুন ডেটা স্টোর তৈরি করুন ক্লিক করুন।
  2. ডেটা উৎস হিসেবে ক্লাউড স্টোরেজ নির্বাচন করুন।

6e2440ecf0f8f9bd.png সম্পর্কে

  1. ফাইল নির্বাচন করুন।
  2. ব্রাউজ করুন এ ক্লিক করুন।
  3. google-chat-overview.pdf ফাইলটি নির্বাচন করুন।
  4. চালিয়ে যান ক্লিক করুন।
  5. ডেটা স্টোরের নাম gchat-knowledge-ds এ সেট করুন।
  6. তৈরি করুন ক্লিক করুন।

a675df7490b83900.png সম্পর্কে

  1. টেবিলে gchat-knowledge-ds ডেটা স্টোর নির্বাচন করুন।
  2. তৈরি করুন ক্লিক করুন।

f121d580771ed96.png সম্পর্কে

  1. কয়েক মিনিট পর, মেনু ☰ > এজেন্ট বিল্ডার > অ্যাপস-এ ক্লিক করুন এবং লক্ষ্য করুন যে আপনি অ্যাপটি দেখতে পাচ্ছেন।

d929a7431dd84968.png সম্পর্কে

  1. মেনু ☰ > এজেন্ট বিল্ডার > ডেটা স্টোরে ক্লিক করুন।

  1. gchat-knowledge-ds ডেটা স্টোরে ক্লিক করুন। ডকুমেন্টের সংখ্যা 1 , যা নির্দেশ করে যে এটি প্রস্তুত।

558319790a0accf2.png সম্পর্কে

অ্যাপটি সম্পূর্ণ করুন এবং পরীক্ষা করুন

Dialogflow CX কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার গুগল ক্লাউড প্রজেক্ট নির্বাচন করুন।
  2. নলেজ এজেন্ট নির্বাচন করুন।

অনুসরণ

  1. এজেন্ট সেটিংস > জেনারেটিভ এআই > জেনারেটিভ এজেন্ট নির্বাচন করুন।
  2. মডেলটি টেক্সট বাইসন থেকে জেমিনি প্রো তে স্যুইচ করুন।
  3. সংরক্ষণ করুন ক্লিক করুন।

68cc4713ec9b25a0.png সম্পর্কে

  1. টেস্ট এজেন্ট ক্লিক করুন।
  2. পাঠান What is Google Chat? । এজেন্ট অর্থপূর্ণ কিছু দিয়ে উত্তর দেয়।

8e3a2cb02469041a.png সম্পর্কে

গুগল চ্যাট অ্যাপ ইন্টিগ্রেট করুন

Dialogflow CX কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার গুগল ক্লাউড প্রজেক্ট নির্বাচন করুন।
  2. নলেজ এজেন্টের সারিতে, ক্লিক করুন 1e7ede7abae4aa3c.png সম্পর্কে > নাম কপি করুন

e19f61185158110d.png

গুগল ক্লাউড কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. Google Chat API কনফিগারেশনে যান।

  1. সংযোগ সেটিংসের অধীনে, ডায়ালগফ্লো নির্বাচন করুন।
  2. Dialogflow সেটিংস এর অধীনে, Dialogflow CX নির্বাচন করুন।
  3. আপনার কপি করা এজেন্টের নামের সাথে এজেন্ট বা পরিবেশ রিসোর্সের নাম সেট করুন।
  4. দুটি স্ল্যাশ কমান্ড মুছে ফেলুন।

505ff39a50880904.png সম্পর্কে

  1. গুগল চ্যাটে , গুগল চ্যাট অ্যাপে সরাসরি বার্তায় What is Google Chat? পাঠান। এজেন্ট অর্থপূর্ণ কিছু দিয়ে সাড়া দেয়।

অনুসরণ

৯. ঐচ্ছিক: অ্যাপ ২: উৎস যোগ করুন

ধারণাগুলি পর্যালোচনা করুন

ডায়ালগফ্লো সিএক্স ওয়েবহুক

একটি পরিষেবা যা ব্যবসায়িক লজিক হোস্ট করে অথবা অন্যান্য পরিষেবা কল করে। একটি Dialogflow CX সেশনের সময়, ওয়েবহুকগুলি প্রাকৃতিক ভাষা প্রক্রিয়াকরণের মাধ্যমে নিষ্কাশিত ডেটার উপর নির্ভর করে গতিশীল প্রতিক্রিয়া তৈরি করতে, সংগৃহীত ডেটা যাচাই করতে বা ব্যাকএন্ডে অ্যাকশন ট্রিগার করতে পারে।

ক্লাউড ফাংশন

ক্লাউড ফাংশনগুলি সার্ভারলেস ব্যাকএন্ড তৈরি, রিয়েল-টাইম ডেটা প্রসেসিং এবং বুদ্ধিমান অ্যাপ তৈরির জন্য দুর্দান্ত। প্রোভিশন, ম্যানেজমেন্ট, প্যাচ বা আপডেট করার জন্য কোনও সার্ভার নেই। এগুলি স্বয়ংক্রিয়ভাবে স্কেল হয় এবং অত্যন্ত উপলব্ধ এবং ত্রুটি-সহনশীল।

পর্যালোচনা প্রবাহ

প্রশ্নের উত্তর দিন (আপডেট)

92767c07c7b252aa.png সম্পর্কে

সোর্স কোড পর্যালোচনা করুন

আপনার একমাত্র সোর্স কোডটি প্রয়োজন যা হল গুগল চ্যাট বার্তাগুলিতে এজেন্ট প্রতিক্রিয়াগুলিকে অভিযোজিত করার ফাংশন। এটি একটি ওয়েবহুক হিসাবে ব্যবহৃত হয়।

প্যাকেজ.জেসন

// The function relies on the Cloud Functions framework to run.

{
  "name": "agent-response-adapter",
  "version": "0.0.1",
  "dependencies": {
    "@google-cloud/functions-framework": "^3.0.0"
  },
  ...
}

ইনডেক্স.জেএস

/** 
 * Handles all incoming requests.
 *
 * It takes a Dialogflow CX agent response as input and returns a
 * valid Google Chat card message with both the text and source links
 */
functions.http('agent-response-adapter', (request, response) => {
  // Creates Google Chat buttons based on the data store agent response
  // grounding details.
  var linkTitles = [];
  var linkButtons = [];
  const grounding = request.body.messages[1].payload.richContent[0][0];
  if (grounding.type === "match_citations") {
    // Supports citation match type.
    grounding.citations.forEach((citation) => {
      // Avoid duplications.
      if (linkTitles.indexOf(citation.title) < 0) {
        linkButtons.push({
          text: citation.title,
          onClick: { openLink: {
            url: citation.actionLink
          }}
        });
        linkTitles.push(citation.title);
      }
    });
  } else if (grounding.type === "info") {
    // Supports info type.
    if (linkTitles.indexOf(grounding.title) < 0) {
      linkButtons.push({
        text: grounding.title,
        onClick: { openLink: {
          url: grounding.actionLink
        }}
      });
      linkTitles.push(grounding.title);
    }
  }

  // Sends the Dialogflow CX fulfillment response to replace the agent response
  // with the Chat message with text and source buttons.
  response.send({ fulfillment_response: {
    merge_behavior: "REPLACE",
    messages: [{ payload: {
      // Reuses the original data store agent response text.
      text: request.body.messages[0].text.text[0],
      cardsV2: [{
        cardId: "sourcesCard",
        card: { sections: [{
          header: "Sources",
          widgets: [{ buttonList: {
            buttons: linkButtons
          }}]
        }]}
      }]
    }}]
  }});
});

গুগল ক্লাউড প্রোজেক্ট আপডেট করুন

গুগল ক্লাউড কনসোলে, এই পদক্ষেপগুলি অনুসরণ করুন:

  1. ক্লাউড বিল্ড, ক্লাউড ফাংশন, ক্লাউড লগিং, আর্টিফ্যাক্ট রেজিস্ট্রি এবং ক্লাউড রান API সক্ষম করুন।

  1. মেনু ☰ > API এবং পরিষেবা > সক্রিয় API এবং পরিষেবাগুলিতে ক্লিক করুন এবং তারপরে নিশ্চিত করুন যে API গুলি সক্রিয় আছে।

Dialogflow CX ডেটা স্টোর এজেন্ট আপডেট করুন

সম্ভব হলে একাধিক উৎস ব্যবহার করে এটি চালু করার জন্য আপনাকে একটি ক্লাউড ফাংশন স্থাপন করতে হবে এবং Dialogflow CX ওয়েবহুক আপডেট করতে হবে।

একাধিক উৎস ফেরত দিন

ডিফল্টরূপে, একটি নতুন ডেটা স্টোর এজেন্ট সর্বাধিক একটি উৎস প্রদান করে, তবে আপনি আরও বেশি উৎস পরিবর্তন করতে পারেন।

Dialogflow CX কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার গুগল ক্লাউড প্রজেক্ট নির্বাচন করুন।
  2. নলেজ এজেন্ট নির্বাচন করুন।
  3. শুরু পৃষ্ঠা নির্বাচন করুন।
  4. ডেটা স্টোর সম্পাদনা করুন নির্বাচন করুন।
  5. এজেন্ট রেসপন্স বিভাগের অধীনে, ডেটা স্টোর রেসপন্স অপশনগুলিকে 5 এ সেট করুন।
  6. সংরক্ষণ করুন ক্লিক করুন।

f5932d03057df645.png সম্পর্কে

ক্লাউড ফাংশন শুরু করুন

গুগল ক্লাউড কনসোলে , এই পদক্ষেপগুলি অনুসরণ করুন:

  1. মেনু ☰ > ক্লাউড ফাংশন ক্লিক করুন।

  1. Create function এ ক্লিক করুন।
  2. Basics এর অধীনে, নামটি function-1 এ সেট করুন।
  3. প্রমাণীকরণের অধীনে, অপ্রমাণিত আহ্বানগুলিকে অনুমতি দিন রেডিও বোতামটি নির্বাচন করুন।
  4. রানটাইম, বিল্ড, সংযোগ এবং সুরক্ষা সেটিংস এর অধীনে, সর্বাধিক উদাহরণের সংখ্যা 3 এ সেট করুন।
  5. পরবর্তী ক্লিক করুন।

bd3790a9285f9c07.png সম্পর্কে

  1. এন্ট্রি পয়েন্টকে agent-response-adapter এ সেট করুন।
  2. Replace the default content with the files package.json and index.js .
  3. Click Deploy .

b379bb8ca0fc1079.png

  1. Copy the URL while you wait a couple minutes for the function to deploy.

eaae08cf048b9b1c.png

Initiate webhook

You need to configure the Dialogflow CX agent to use a webhook that triggers the newly deployed function.

In the Dialogflow CX console , follow these steps:

  1. Select your Google Cloud project.
  2. Select the knowledge agent.
  3. Select Manage > Webhooks > Create .
  4. Set Display name to Google Chat Response Adapter .
  5. Set Webhook URL to the URL that you copied previously.
  6. সংরক্ষণ করুন ক্লিক করুন।

5f3c6804d52b87c1.png

  1. Click Build .
  2. Select Start page .
  3. Select Edit data stores .
  4. Under Webhook settings , click the Enable webhook toggle.
  5. Select Google Chat Response Adapter for Webhook .
  6. Set tag to arbitrary_tag .
  7. সংরক্ষণ করুন ক্লিক করুন।

442fcaaec9b8f2e3.png

Test app

  • In Google Chat , send What is Google Chat? in a direct message to the Google Chat app. The agent responds with something meaningful and a card with sources, if any.

9468866bfe848bb8.png

10. App 3: Build

Review concepts

Conversational interactions

They are the back-and-forth exchanges of information or ideas between two or more people through natural language. This contrasts to technical interfaces that often rely on stateless, highly structured, and intolerant exchanges.

OpenAPI Specification

It provides a consistent means to carry information through each stage of the API lifecycle. It is a specification language for HTTP APIs that defines structure and syntax in a way that is not wedded to the programming language the API is created in. API specifications are typically written in YAML or JSON, allowing for easy sharing and consumption of the specification.

Dialogflow CX agent

The basic building block of agent apps . An agent app typically has many agents , where each agent is defined to handle specific tasks. The agent data is provided to the LLM, so it has the information it needs to answer questions and execute tasks. Each agent can provide information, send queries to external services, or defer conversation handling to a Dialogflow CX flow or another agent to handle sub-tasks.

Dialogflow CX tool

Tools are used to connect agent apps to external systems. These systems can augment the knowledge of agent apps and empower them to execute complex tasks efficiently.

Review architecture

9d3342d12f3b4dda.png

This Google Chat app is built with Dialogflow CX and works as follows:

  1. A user sends a message to the app, either in a direct message or in a space.
  2. The app, which is a Dialogflow CX agent and is associated with a Google Cloud project, processes the message.
  3. The app integrates with an agent.
  4. The app sends a synchronous response, either in a direct message or in the original space.

Review flows

Collect review

a67a5b8b513bfc2c.png

Review source code

The only source code that you need is the function to mock the backend service that the agent uses as a tool.

package.json

// The function relies on the Cloud Functions framework to run.

{
  "name": "feedback-app-backend",
  "version": "0.0.1",
  "dependencies": {
    "@google-cloud/functions-framework": "^3.0.0"
  },
  ...
}

index.js

/** 
 * Handles all incoming requests.
 * 
 * It always returns OK in plain text.
 */
functions.http('feedback-app-backend', (request, response) => {
    response.send('OK');
});

service-openapi.yaml

// Defines the backend service structure and how to request it.

openapi: 3.1.0
info:
  title: Review Store
  license:
    name: Apache 2.0
    identifier: Apache-2.0
  version: 0.0.1
servers:
  - url: https://us-central1-project-0.cloudfunctions.net
paths:
  /store-review:
    post:
      operationId: storeReview
      summary: Store a new review
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties:
                stars:
                  type: integer
                  format: int64
      responses:
        '200':
          description: success
          content:
            application/json:
              schema:
                type: string

Initiate backend service mock

You deploy a Cloud Function to simulate a backend service that the Dialogflow CX agent app needs to integrate and call as a tool.

In the Google Cloud console , follow these steps:

  1. Click Menu ☰ > Cloud Functions .

  1. Click Create function .
  2. Under Basics , set name to function-2 .
  3. Under Authentication , select the Allow unauthenticated invocations radio button.
  4. Under Runtime, build, connections and security settings , set Maximum number of instances to 3 .
  5. Click Next .

e8cf0ee7441bf634.png

  1. Set Entry point to feedback-app-backend .
  2. Replace the default content with the files package.json and index.js .
  3. Click Deploy .

bdb5cf9f503aa7f6.png

  1. Copy the URL while you wait a couple minutes for the function to deploy.

Create Dialogflow CX agent app

Create app

In the Google Cloud console , follow these steps:

  1. Click Menu ☰ > Agent builder > Apps .

  1. Click New app .
  2. Select Agent .
  3. Set Display name to Feedback App .
  4. Click Create .

7ef3dbacee96c5aa.png

Initiate tool

In the Google Cloud console , follow these steps:

  1. Click Menu ☰ > Agent builder > Apps .

  1. Select the Feedback App agent.
  2. Click Tools > + Create .
  3. Set Name to review .
  4. Select OpenAPI .
  5. Set description to the following value:
The tool takes the number of stars as a parameter of the store review method and saves it in a database for later use.
  1. Download and replace $URL in the file service-openapi.yaml with the URL that you copied previously.
  2. Set YAML Schema to the edited content of the service-openapi.yaml file.
  3. সংরক্ষণ করুন ক্লিক করুন।

58085d6d56b603f7.png

Initiate agent

In the Google Cloud console , follow these steps:

  1. Click Menu ☰ > Agent builder > Apps .

  1. Select the Feedback App agent.
  2. Select Agents > Default Generative Agent .
  3. Set Agent name to Feedback collector .
  4. Set goal to the following value:
You are an agent that collects reviews from Google Chat app developers.
A review may be between 0 and 5 stars. The more stars, the more positive the review.
  1. Set instructions to the following value:
If the developer didn't provide the number of stars, ask for the number of stars.
After the developer provides the number of stars of the review, confirm the number with the developer and use ${TOOL: review} to store the review with the number of stars.
If ${TOOL: review} fails, apologize and ask to try again later. Otherwise, thank the developer for the review.
  1. সংরক্ষণ করুন ক্লিক করুন।

ebee7fdfa826b487.png

Test app

In the Google Cloud console , follow these steps:

  1. Click Menu ☰ > Agent builder > Apps .

  1. Select the Feedback App agent.
  2. Go to Preview agent .
  3. Under Agent , select Feedback collector .
  4. Under Select generative model , select gemini-pro .
  5. Send the message Hello! to start.

90ca8cb7b2c1cb4b.png

In the Google Cloud console , follow these steps:

  1. Click Menu ☰ > Cloud Functions .

  1. Select function-2 > Logs . Some logs show Google-Dialogflow as caller.

48bfdf1788004d18.png

Integrate Google Chat app

In the Dialogflow CX console , follow these steps:

  1. Select your Google Cloud project.
  2. Click the action menu of the Feedback App agent.
  3. Click Copy name .

In the Google Cloud console , follow these steps:

  1. Go to the Google Chat API configuration.

  1. Set Agent or Environment resource name to the agent name that you copied previously.

df16619a1cb85cf8.png

  • In Google Chat , send Hello! in a direct message to the Google Chat app to start. The agent responds similarly to your test from the Dialogflow CX console.

99a7a0295f122f31.png

11. Clean up

Delete Google Cloud project

To avoid incurring charges to your Google Cloud Account for the resources used in this codelab, we recommend that you delete the Google Cloud project.

In the Google Cloud console , follow these steps:

  1. Click Menu ☰ > IAM & Admin > Settings .

  1. Click Shut down .
  2. Enter the project ID.
  3. Click Shut down anyway .

407699a4e03afea6.png

Delete Apps Script project

We recommend that you delete your Apps Script project, too.

In the Apps Script console , follow these steps:

  1. Select your project.
  2. Click the action menu.
  3. Click Remove .

fa3a42d7d2201eb9.png

১২. অভিনন্দন

Congratulations! You built Google Chat apps with Gemini!

এরপর কী?

We only showcased simple use cases in this codelab, but there are plenty of expansion areas that you might want to consider in your Google Chat apps, such as the following:

  • Integrate with other Generative AI models, including customs.
  • Support other types of media, such as audio, image, and video.
  • Use multimodality.
  • Rely on longer context windows and feedback loops.
  • Publish production-ready Google Chat apps on the marketplace. There are plenty of resources available for developers such as YouTube videos, documentation websites, code samples, and tutorials.
  • Enable Google Chat for your organization. The import mode feature makes it easier to get started.

আরও জানুন