এই নির্দেশিকাটি ব্যাখ্যা করে যে কীভাবে এমন একটি ধাপ তৈরি করবেন যা ব্যবহারকারীরা Google Workspace Studio-তে এজেন্টে যোগ করতে পারবেন।
একজন এজেন্টের কাজের ক্রমানুসারে একটি ধাপ হলো একটি একক ধাপ। ধাপগুলো একজন এজেন্টকে শুরু করতে পারে না।
উদাহরণস্বরূপ, এমন একটি ধাপ বিবেচনা করুন যা পাটিগণিত করে। এটি ব্যবহারকারীকে দুটি মান এবং একটি গাণিতিক ক্রিয়াকলাপ জিজ্ঞাসা করে। তারপর এটি মানগুলির উপর গাণিতিক ক্রিয়াকলাপ সম্পাদন করে এবং ফলাফল আউটপুট দেয়।

একটি ধাপ তৈরি করতে, অ্যাড-অনের ম্যানিফেস্ট ফাইলে এটি কনফিগার করুন, Google Workspace অ্যাড-অনের কোডে অ্যাপ্লিকেশন লজিক লিখুন এবং ধাপটি স্থাপন এবং পরীক্ষা করুন।
ধাপটি সংজ্ঞায়িত করুন
একটি ধাপ কনফিগার করতে, ম্যানিফেস্ট ফাইলে এটি সংজ্ঞায়িত করুন এবং কোডে এর অ্যাপ্লিকেশন লজিক লিখুন।
ম্যানিফেস্ট ফাইলের ধাপটি সংজ্ঞায়িত করুন
ম্যানিফেস্ট ফাইলে, appsscript.json :
- অ্যাড-অনের কোডে সংশ্লিষ্ট ফাংশনের নামের সাথে
onConfigFunctionএবংonExecuteFunctionসেট করুন। এই উদাহরণে, ফাংশনগুলিকেonConfigCalculate()এবংonExecuteCalculate()বলা হয়।-
onConfigFunctionধাপটি সেট আপ এবং কনফিগার করে। প্রয়োজনে, ধাপটি কার্যকর করার জন্য প্রয়োজনীয় ব্যবহারকারীদের কাছ থেকে তথ্য সংগ্রহ করে, যেমন ইমেল পাঠানোর ঠিকানা। এই নির্দেশিকার উদাহরণে, আমরা দুটি মান এবং একটি গণিত অপারেশনের জন্য জিজ্ঞাসা করি। -
onExecuteFunctionধাপটি কার্যকর করে। যদি ব্যবহারকারীদের কাছ থেকে তথ্য সংগ্রহ করা হয়, তাহলে সেই তথ্য এই ফাংশনে চলে যায়। প্রযোজ্য হলে, একটি আউটপুট প্রদান করে। এই নির্দেশিকার উদাহরণে, একটি গণিত গণনার ফলাফল আউটপুট করে।
-
প্রয়োজনীয় ইনপুট এবং আউটপুট সেট করুন, যা ধাপটি ডেটা সংগ্রহ করে পরবর্তী ধাপগুলিতে পাঠাতে সাহায্য করবে। এই উদাহরণে, ব্যবহারকারীকে
inputs[]এ সংজ্ঞায়িত দুটি মান এবং একটি গণিত অপারেশন জিজ্ঞাসা করুন।outputs[]এ সংজ্ঞায়িত হিসাবে গণনা করা ফলাফলটি আউটপুট করুন।ইনপুট এবং আউটপুট সম্পর্কে আরও জানতে, ইনপুট ভেরিয়েবল এবং আউটপুট ভেরিয়েবল দেখুন। এজেন্টগুলি ত্রুটি ছাড়াই চলছে তা নিশ্চিত করতে, ইনপুট ভেরিয়েবলগুলি যাচাই করুন ।
ক্যালকুলেটর ধাপের জন্য ম্যানিফেস্ট ফাইলটি এখানে:
JSON সম্পর্কে
{
"timeZone": "America/Los_Angeles",
"exceptionLogging": "STACKDRIVER",
"runtimeVersion": "V8",
"addOns": {
"common": {
"name": "Calculator",
"logoUrl": "https://www.gstatic.com/images/branding/productlogos/calculator_search/v1/web-24dp/logo_calculator_search_color_1x_web_24dp.png",
"useLocaleFromApp": true
},
"flows": {
"workflowElements": [
{
"id": "actionElement",
"state": "ACTIVE",
"name": "Calculate",
"description": "Asks the user for two values and a math operation, then performs the math operation on the values and outputs the result.",
"workflowAction": {
"inputs": [
{
"id": "value1",
"description": "value1",
"cardinality": "SINGLE",
"dataType": {
"basicType": "INTEGER"
}
},
{
"id": "value2",
"description": "value2",
"cardinality": "SINGLE",
"dataType": {
"basicType": "INTEGER"
}
},
{
"id": "operation",
"description": "operation",
"cardinality": "SINGLE",
"dataType": {
"basicType": "STRING"
}
}
],
"outputs": [
{
"id": "result",
"description": "Calculated result",
"cardinality": "SINGLE",
"dataType": {
"basicType": "INTEGER"
}
}
],
"onConfigFunction": "onConfigCalculate",
"onExecuteFunction": "onExecuteCalculate"
}
}
]
}
}
}
এরপর, কোডের ধাপটি সংজ্ঞায়িত করে সহায়ক কোডটি লিখুন।
কোডের ধাপটি সংজ্ঞায়িত করুন
অ্যাপ্লিকেশন কোডে, নিম্নলিখিতগুলি করুন:
এই উদাহরণে
onConfigFunctionলিখুন, যাonConfigCalculate()নামে পরিচিত। ব্যবহারকারীরা যখন কোনও এজেন্টে ধাপটি যোগ করেন, তখন তারা এজেন্ট বিল্ডারে ধাপের দিকগুলি কনফিগার করতে পারেন। ব্যবহারকারীর কাছ থেকে প্রয়োজনীয় তথ্য সংগ্রহ করার জন্য,onConfigFunctionএকটি কনফিগারেশন কার্ড সংজ্ঞায়িত করে।অ্যাড-অনগুলিতে ইউজার ইন্টারফেসের জন্য কার্ডগুলি হল মূল উপাদান। কার্ডগুলি একটি নির্দিষ্ট লেআউট, বোতামের মতো ইন্টারেক্টিভ UI উপাদান এবং চিত্রের মতো সমৃদ্ধ মিডিয়া সমর্থন করে। কার্ডগুলি হল এমন একটি উপায় যা আপনি একজন ব্যবহারকারীর কাছ থেকে ডেটা পেতে পারেন যা ধাপটি চালানোর জন্য প্রয়োজন, যেমন একটি ইমেল ঠিকানা যা একটি ইমেল পাঠানোর জন্য।
OnConfigFunctionএকটি কার্ড ফেরত দেয়। এই কার্ডটি UI সংজ্ঞায়িত করে যেখানে ব্যবহারকারীরা ধাপের ডেটা সেট করে। এই উদাহরণে,onConfigFunctionএকটি কার্ড তৈরি করে যা ব্যবহারকারীকে দুটি মান এবং একটি গণিত অপারেশন জিজ্ঞাসা করে।এই উদাহরণে
onExecuteCalculate()নামকonExecuteFunctionলিখুন। যখন আপনার স্টেপটি একটি এজেন্টে চলে, তখনOnExecuteFunctionচলে।onConfigurationFunctionএ সংজ্ঞায়িত কনফিগারেশনের সময় ব্যবহারকারী যে কোনও ইনপুট মান সেট করে তাOnExecuteFunctionএ পাস করা হয়।OnExecuteFunction()লিখুন যাতে এটি প্রদত্ত ইনপুট ব্যবহার করে সিঙ্ক্রোনাসভাবে তার কাজ সম্পাদন করে। মনে রাখবেন,OnExecuteFunction()কে অবশ্যই আপনার এজেন্টের ম্যানিফেস্টে সংজ্ঞায়িত সমস্ত আউটপুট ফেরত দিতে হবে, অন্যথায় একটি ত্রুটি ঘটে।
এই কোড নমুনায় একটি সাপোর্টিং ফাংশন, outputVariables() অন্তর্ভুক্ত, যা ধাপ থেকে প্রদত্ত ভেরিয়েবল তৈরি করে এবং আউটপুট হিসেবে পাঠায়।
তোমার ধাপ পরীক্ষার জন্য প্রস্তুত।
ক্যালকুলেটর ধাপের কোডটি এখানে:
অ্যাপস স্ক্রিপ্ট
/**
* Generates and displays a configuration card for the sample calculation step.
*
* This function creates a card with input fields for two values and a drop-down
* for selecting an arithmetic operation.
*
* The input fields are configured to let the user select outputs from previous
* steps as input values using the `hostAppDataSource` property.
*/
function onConfigCalculate() {
const firstInput = CardService.newTextInput()
.setFieldName("value1")
.setTitle("First Value")
.setHostAppDataSource(
CardService.newHostAppDataSource()
.setWorkflowDataSource(
CardService.newWorkflowDataSource()
.setIncludeVariables(true)
)
);
const secondInput = CardService.newTextInput()
.setFieldName("value2")
.setTitle("Second Value").setHostAppDataSource(
CardService.newHostAppDataSource()
.setWorkflowDataSource(
CardService.newWorkflowDataSource()
.setIncludeVariables(true)
)
);
const selectionInput = CardService.newSelectionInput()
.setTitle("operation")
.setFieldName("operation")
.setType(CardService.SelectionInputType.DROPDOWN)
.addItem("+", "+", false)
.addItem("-", "-", true)
.addItem("x", "x", false)
.addItem("/", "/", false);
const sections = CardService.newCardSection()
.setHeader("Action_sample: Calculate")
.setId("section_1")
.addWidget(firstInput)
.addWidget(selectionInput)
.addWidget(secondInput)
var card = CardService.newCardBuilder()
.addSection(sections)
.build();
return card;
}
/**
* Returns output variables from a step.
*
* This function constructs an object that, when returned, sends the
* provided variable values as output from the current step.
* The variable values are logged to the console for debugging purposes.
*/
function outputVariables(variableDataMap) {
const workflowAction = AddOnsResponseService.newReturnOutputVariablesAction()
.setVariableDataMap(variableDataMap);
const hostAppAction = AddOnsResponseService.newHostAppAction()
.setWorkflowAction(workflowAction);
const renderAction = AddOnsResponseService.newRenderActionBuilder()
.setHostAppAction(hostAppAction)
.build();
return renderAction;
}
/**
* Executes the calculation step based on the inputs from a flow event.
*
* This function retrieves input values and the operation from the flow event,
* performs the calculation, and returns the result as an output variable.
* The function logs the event for debugging purposes.
*/
function onExecuteCalculate(event) {
console.log("output: " + JSON.stringify(event));
var calculatedValue = 0;
var value1 = event.workflow.actionInvocation.inputs["value1"].integerValues[0];
var value2 = event.workflow.actionInvocation.inputs["value2"].integerValues[0];
var operation = event.workflow.actionInvocation.inputs["operation"].stringValues[0];
if (operation == "+") {
calculatedValue = value1 + value2;
} else if (operation == "-") {
calculatedValue = value1 - value2;
} else if (operation == "x") {
calculatedValue = value1 * value2;
} else if (operation == "/") {
calculatedValue = value1 / value2;
}
const variableDataMap = { "result": AddOnsResponseService.newVariableData().addIntegerValue(calculatedValue) };
return outputVariables(variableDataMap);
}
তোমার ধাপ পরীক্ষা করো
আপনার স্টেপ পরীক্ষা করার জন্য, আপনার অ্যাড-অনের জন্য একটি পরীক্ষামূলক স্থাপনা সেট আপ করুন, একটি এজেন্টে স্টেপটি যোগ করুন এবং তারপর এজেন্টটি চালান।
আপনার অ্যাড-অনের জন্য একটি পরীক্ষামূলক স্থাপনা সেট আপ করুন:
- অ্যাপস স্ক্রিপ্ট এডিটরে স্ক্রিপ্ট প্রজেক্টটি খুলুন।
- স্থাপন > পরীক্ষা স্থাপন ক্লিক করুন।
- ইনস্টল করুন এ ক্লিক করুন।
- নিচে, সম্পন্ন ক্লিক করুন।
আপনি অন্যান্য ব্যবহারকারীদের তাদের অ্যাকাউন্টের সাথে অ্যাপস স্ক্রিপ্ট প্রকল্পটি ভাগ করে অ্যাড-অনটি পরীক্ষা করার সুযোগ দিতে পারেন (সম্পাদনার অ্যাক্সেস প্রয়োজন)। তারপর ব্যবহারকারীদের পূর্ববর্তী পদক্ষেপগুলি অনুসরণ করতে অনুরোধ করুন।
একবার ইনস্টল হয়ে গেলে, অ্যাড-অনটি এজেন্টস-এ তাৎক্ষণিকভাবে উপলব্ধ হয়ে যাবে। অ্যাড-অনটি প্রদর্শিত হওয়ার আগে আপনাকে এজেন্টস রিফ্রেশ করতে হতে পারে। এটি ব্যবহার করার আগে আপনাকে অ্যাড-অনটি অনুমোদন করতে হবে।
পরীক্ষামূলক স্থাপনা সম্পর্কে আরও জানতে, একটি অপ্রকাশিত অ্যাড-অন ইনস্টল করুন দেখুন।
ওপেন এজেন্ট।
আপনার পদক্ষেপ অন্তর্ভুক্ত করে এমন একটি এজেন্ট তৈরি করুন:
- নতুন এজেন্ট এ ক্লিক করুন।
- এজেন্ট কীভাবে শুরু করবে তা নির্বাচন করুন। কোনও ধাপ পরীক্ষা করার সময়, এমন একটি স্টার্টার বেছে নেওয়া ভালো যা আপনি নিজেই শুরু করতে পারেন, যেমন নিজেকে একটি ইমেল পাঠানো। যদি আপনার ধাপে একটি ইনপুট ভেরিয়েবলের প্রয়োজন হয়, তাহলে স্টার্টারের আউটপুটের অংশ হিসাবে ইনপুট ভেরিয়েবলটি কনফিগার করুন।
- ধাপ যোগ ক্লিক করুন। আপনার তৈরি বা আপডেট করা ধাপটি নির্বাচন করুন, যাকে বলা হয় Calculate ।
- আপনার ধাপটি কনফিগার করুন। গণনা ধাপের জন্য, দুটি মান এবং একটি গাণিতিক ক্রিয়া নির্বাচন করুন। ধাপটি স্বয়ংক্রিয়ভাবে সংরক্ষণ করা হবে।
- আপনার ধাপের আউটপুট পরীক্ষা করতে, আরেকটি ধাপ যোগ করুন। উদাহরণস্বরূপ, একটি ইমেল বার্তায় আউটপুট যোগ করতে, আপনি Gmail এর "একটি বার্তা পাঠান" ধাপ যোগ করতে পারেন। Message এ, Variables এ ক্লিক করুন এবং আপনার ধাপের আউটপুট নির্বাচন করুন। calculate ধাপের জন্য, Variables > Step 2: Calculated result > Calculated result নির্বাচন করুন। Message ক্ষেত্রে একটি চিপ হিসাবে ভেরিয়েবলটি প্রদর্শিত হবে।
- চালু করুন ক্লিক করুন। আপনার এজেন্ট চালানোর জন্য প্রস্তুত।
আপনার এজেন্টের স্টার্টার সেট অফ করে এজেন্ট চালান। উদাহরণস্বরূপ, যদি আপনার এজেন্ট কোনও ইমেল পাওয়ার পরেই শুরু হয়, তাহলে নিজেকে একটি ইমেল পাঠান।
এজেন্টটি প্রত্যাশা অনুযায়ী কাজ করছে কিনা তা যাচাই করুন। এজেন্ট বিল্ডারের অ্যাক্টিভিটি ট্যাবে গিয়ে লগগুলি পরীক্ষা করুন। অ্যাক্টিভিটি ট্যাবে কাস্টম লগ তৈরি করতে শিখতে, অ্যাক্টিভিটি লগগুলি দেখুন।
সম্পর্কিত বিষয়
- ইনপুট ভেরিয়েবল
- একটি ইনপুট ভেরিয়েবল যাচাই করুন
- আউটপুট ভেরিয়েবল
- একটি কাস্টম রিসোর্স সংজ্ঞায়িত করুন
- গতিশীল ভেরিয়েবল
- কার্যকলাপ এবং ত্রুটি লগ করুন
- ওয়ার্কস্পেস স্টুডিও ইভেন্ট অবজেক্ট