۱. مقدمه
در این آزمایشگاه کد، یک ویجت چت پشتیبانی مشتری هوشمند به یک فروشگاه تجارت الکترونیک تجهیزات فضای باز به نام Rugged Terrain Guide اضافه خواهید کرد. از Firebase AI Logic برای ساخت این عامل استفاده خواهید کرد و یاد خواهید گرفت که چگونه یک الگوی اعلان سمت سرور ( product-agent ) را پیکربندی کنید که شخصیت هوش مصنوعی، قوانین سختگیرانه بودجه را مدیریت کند و به صورت پویا از کاتالوگ محصول به عنوان زمینه استفاده کند.
کاری که انجام خواهید داد:
- کد آغازین برنامه وب این codelab را دریافت کنید.
- یک پروژه Firebase راهاندازی کنید.
- سرویسهای Firebase (مانند Firebase AI Logic) را در یک برنامه وب راهاندازی و مقداردهی اولیه کنید.
- یک الگوی اعلان سمت سرور را در کنسول Firebase پیکربندی کنید.
- از طریق فراخوانی سرویس هوش مصنوعی مولد از طریق یک رابط TypeScript شبیه React، به قالب دسترسی پیدا کنید.
آنچه نیاز دارید:
- یک مرورگر وب مانند کروم .
- آشنایی اولیه با TypeScript و Node.js.
- یک IDE یا ویرایشگر متن به دلخواه شما. Antigravity انتخاب خوبی است.
۲. کد شروع را دریافت کنید
- در ترمینال خود، مخزن اولیه را کلون کنید:
git clone https://github.com/GoogleCloudPlatform/devrel-demos.git - به دایرکتوری کد بروید و وابستگیها را نصب کنید:
cd devrel-demos/codelabs/firebase-server-prompt-templates-codelab npm install
۳. یک پروژه Firebase راهاندازی کنید
ایجاد یک پروژه فایربیس
- با استفاده از حساب گوگل خود وارد کنسول فایربیس شوید.
- برای ایجاد یک پروژه جدید، روی دکمه کلیک کنید و سپس نام پروژه را وارد کنید (برای مثال،
rugged-terrain-ai). - روی ادامه کلیک کنید.
- در صورت درخواست، شرایط Firebase را مرور و قبول کنید و سپس روی ادامه کلیک کنید.
- (اختیاری) دستیار هوش مصنوعی را در کنسول Firebase (با نام "Gemini در Firebase") فعال کنید.
- برای این codelab، به گوگل آنالیتیکس نیاز ندارید ، بنابراین گزینه گوگل آنالیتیکس را غیرفعال کنید .
- روی ایجاد پروژه کلیک کنید، منتظر بمانید تا پروژه شما آماده شود و سپس روی ادامه کلیک کنید.
طرح قیمتگذاری فایربیس خود را ارتقا دهید
برای استفاده از سرویسهای فایربیس در این آزمایشگاه کد، پروژه فایربیس شما باید در طرح قیمتگذاری پرداخت در محل (Blaze) باشد، به این معنی که به یک حساب پرداخت ابری (Cloud Billing ) متصل باشد.
- یک حساب Cloud Billing به یک روش پرداخت، مانند کارت اعتباری، نیاز دارد.
- اگر در استفاده از فایربیس و گوگل کلود تازهکار هستید، بررسی کنید که آیا واجد شرایط دریافت اعتبار ۳۰۰ دلاری و یک حساب کاربری رایگان ابری هستید یا خیر.
- اگر این codelab را به عنوان بخشی از یک رویداد انجام میدهید، از برگزارکننده خود بپرسید که آیا امکان استفاده از فضای ابری (Cloud credits) وجود دارد یا خیر.
برای ارتقاء پروژه خود به طرح Blaze، مراحل زیر را دنبال کنید:
- در کنسول Firebase، گزینه ارتقاء پلن خود را انتخاب کنید.
- طرح Blaze را انتخاب کنید. دستورالعملهای روی صفحه را دنبال کنید تا یک حساب Cloud Billing به پروژه شما متصل شود.
اگر به عنوان بخشی از این ارتقا نیاز به ایجاد یک حساب Cloud Billing داشتید، ممکن است لازم باشد برای تکمیل ارتقا، به روند ارتقا در کنسول Firebase برگردید.
۴. سرویسهای فایربیس را راهاندازی کنید و برنامه خود را متصل کنید
برای این آزمایشگاه کد، باید فضای ذخیرهسازی ابری برای فایربیس و منطق هوش مصنوعی فایربیس را در پروژه فایربیس خود راهاندازی کنید. همچنین باید کد منبع برنامه خود را به پروژه فایربیس خود متصل کنید.
راهاندازی فضای ذخیرهسازی ابری برای فایربیس
این آزمایشگاه کد از فضای ذخیرهسازی ابری برای فایربیس برای ذخیره توضیحات محصول استفاده میکند.
- در کنسول فایربیس، به مسیر Databases & Storage > Storage بروید.
- روی شروع به کار کلیک کنید.
- مکانی را برای سطل ذخیرهسازی پیشفرض خود انتخاب کنید.
کاربران درUS-WEST1،US-CENTRAL1وUS-EAST1میتوانند از ردیف «همیشه رایگان» برای Google Cloud Storage بهرهمند شوند. کاربران در سایر مناطق ، از قیمتها و میزان استفاده از Google Cloud Storage پیروی میکنند. - روی حالت تولید (Production mode) کلیک کنید. در مراحل زیر، این قوانین امنیتی را بهروزرسانی خواهید کرد تا مختص این آزمایشگاه کد باشند.
- روی ایجاد کلیک کنید.
- قوانین امنیتی خود را بهروزرسانی کنید:
- پس از آمادهسازی سطل، به برگه قوانین بروید.
- قوانین زیر را کپی و سپس در آن جایگذاری کنید:
rules_version = '2'; service firebase.storage { match /b/{bucket}/o { match /products.txt { allow read; } } } - روی انتشار کلیک کنید.
- توضیحات محصول را از کد آغازین آپلود کنید:
- روی تب Files مربوط به Storage Bucket خود کلیک کنید.
- روی آپلود فایل کلیک کنید و سپس فایل
products.txtرا از کد آغازین آپلود کنید. این فایل را میتوانید در آدرسsrc/data/products.txtپیدا کنید.
پیکربندی منطق هوش مصنوعی فایربیس
منطق هوش مصنوعی فایربیس (Firebase AI Logic) سرویس اصلی فایربیس است که در این آزمایشگاه کد از آن استفاده خواهید کرد.
- در کنسول فایربیس، به بخش سرویسهای هوش مصنوعی > منطق هوش مصنوعی بروید.
- روی شروع به کار کلیک کنید.
- در کارت API مربوط به Vertex AI Gemini ، روی گزینهی «شروع با این API» کلیک کنید و دستورالعملهای روی صفحه را دنبال کنید. این روند، APIهای مورد نیاز برای استفاده از Firebase AI Logic با API مربوط به Vertex AI Gemini را برای شما فعال میکند.
- (اختیاری) گزینه فعال کردن نظارت بر هوش مصنوعی را انتخاب کنید تا بتوانید معیارها و میزان استفاده در سطح برنامه را مشاهده کنید تا از طریق Firebase AI Logic، دید جامعی نسبت به درخواستهای خود داشته باشید.
کد خود را به پروژه Firebase خود وصل کنید
به عنوان بخشی از راهاندازی Firebase AI Logic، از شما خواسته میشود که یک برنامه وب Firebase ایجاد کنید و پیکربندی خود را به کد منبع خود اضافه کنید.
- وقتی در جریان تنظیم Firebase AI Logic از شما خواسته شد، روی وب (
>) آیکون برای ثبت یک برنامه وب جدید. - نام برنامه را بنویسید (مثلاً
Rugged Web). - شیء
firebaseConfigرا از دستورالعملهای راهاندازی کپی کنید.
در مرحله بعد، کد شروع را بهروزرسانی کنید:
- در ویرایشگر کد خود،
src/firebase.tsرا باز کنید. -
firebaseConfigموجود را با موردی که از کنسول Firebase کپی کردهاید، جایگزین کنید.
فایل شما باید به این شکل باشد:
import { getAI, getTemplateGenerativeModel, VertexAIBackend } from "firebase/ai";
import { initializeApp } from "firebase/app";
// Your web app's Firebase configuration
const firebaseConfig = {
apiKey: "YOUR_API_KEY",
authDomain: "YOUR_PROJECT_ID.firebaseapp.com",
projectId: "YOUR_PROJECT_ID",
storageBucket: "YOUR_PROJECT_ID.firebasestorage.app",
messagingSenderId: "YOUR_MESSAGING_SENDER_ID",
appId: "YOUR_APP_ID"
};
// Initialize Firebase
export const app = initializeApp(firebaseConfig);
const ai = getAI(app, { backend: new VertexAIBackend() });
۵. الگوی اعلان سمت سرور را ایجاد کنید
به جای کدنویسی دستورات پیچیده هوش مصنوعی در برنامه کلاینت، از سینتکس Dotprompt برای مدیریت ایمن دستورالعملها روی سرور استفاده خواهید کرد.
این امر مانع از آن میشود که کاربران نهایی قوانین مخفی «بودجه مماشات» را ببینند.
- در کنسول Firebase، به بخش Vertex AI یا Prompt Management بروید.
- یک الگوی اعلان جدید ایجاد کنید و نام آن را
product-agentبگذارید. - مدل را روی
gemini-2.5-flashتنظیم کنید. - طرح ورودی را دقیقاً به صورت زیر تعریف کنید:
input: schema: query: type: string description: the customers ask of the robot productId?: type: string description: the product the customer is looking at right now history?: type: array description: list of previous history between the user and system items: type: object required: [role, contents] properties: role: type: string contents: type: string - محتویات
agent-product.promptرا از دایرکتوری ریشه به فیلد Prompt و اختیاری system instructions کپی کنید. این کار به طور ایمن به مدل دستور میدهد که چگونه به عنوان "Rugged Operator" رفتار کند و کاتالوگ محصول را تزریق کند. - در کنسول Firebase، الگوی
product-agentرا ذخیره و منتشر کنید.
۶. مدل هوش مصنوعی را فراخوانی کنید
حالا که قالب به طور امن روی سرور تعریف شده است، فقط کافی است آن را از قسمت frontend برنامه خود فراخوانی کنید.
- در ویرایشگر کد خود، به
src/firebase.tsبرگردید. - در زیر مقداردهی اولیه، از
getTemplateGenerativeModelبرای اتصال به قالب استفاده کنید:const model = getTemplateGenerativeModel(ai); export const callCustomerSupportModel = async (query: string, productId?: string, history?: { role: string, contents: string }[]) => { // Generate content using the published 'product-agent' template const result = await model.generateContent('product-agent', { query, productId, history, }); return result.response.text(); }
۷. با استفاده از Firebase App Check، عامل را ایمن کنید
مدلهای هوش مصنوعی قدرتمند هستند، اما اگر نقاط پایانی عمومی محافظت نشوند، میتوانند مورد سوءاستفاده قرار گیرند. شما همیشه باید از Firebase App Check استفاده کنید تا مطمئن شوید که فقط برنامه وب واقعی شما میتواند مدل مولد هوش مصنوعی Vertex را فراخوانی کند و رباتها و کلاینتهای غیرمجاز را مسدود کند.
- در کنسول Firebase، به Build > App Check بروید.
- روی برگه برنامهها کلیک کنید، برنامه وب خود (
Rugged Web) را باز کنید و روی ارائهدهنده reCAPTCHA Enterprise کلیک کنید. - گزینه «ایجاد کلید جدید reCAPTCHA Enterprise» را انتخاب کنید و فرم را پر کنید:
- نام :
Codelab Key - دامنهها :
localhostو127.0.0.1را اضافه کنید تا سرور محلی Vite شما مجاز به ارسال درخواست باشد.
- نام :
- برای ثبت برنامه، روی ذخیره کلیک کنید.
- پس از ثبت نام، کنسول Firebase کلید سایت شما را نمایش میدهد. این رشته را کپی کنید.
- در ویرایشگر کد خود، دوباره
src/firebase.tsرا باز کنید. - ایمپورتهای زیر را در بالا اضافه کنید:
import { initializeAppCheck, ReCaptchaEnterpriseProvider } from "firebase/app-check"; - مقداردهی اولیه App Check را درست پس از فراخوانی
initializeApp(firebaseConfig)اضافه کنید و کلید سایتی که کپی کردهاید را جایگذاری کنید:// Initialize App Check const appCheck = initializeAppCheck(app, { provider: new ReCaptchaEnterpriseProvider('YOUR_RECAPTCHA_ENTERPRISE_SITE_KEY'), useLimitedUseAppCheckTokens: true }); - برای استفاده از این توکنها، فراخوانی تابع
getAI()خود را بهروزرسانی کنید. تغییر زیر را اعمال کنید: با تنظیم مقدارconst ai = getAI(app, { backend: new VertexAIBackend(), useLimitedUseAppCheckTokens: true });useLimitedUseAppCheckTokensبه true، شما مطمئن میشوید که توکنهای کوتاهمدت برای کمک به محدود کردن سوءاستفادهای که ممکن است backend شما دریافت کند، اعمال میشوند.
۸. برنامه را اجرا کنید
با پیکربندی Firebase و اتصال ویجت چت پشتیبانی، زمان اجرای برنامه فرا رسیده است.
- در ترمینال خود، سرور توسعه Vite را اجرا کنید:
npm run dev - آدرس اینترنتی محلی ارائه شده (معمولاً
http://localhost:5173/) را باز کنید. - روی دکمهی شناور پشتیبانی تاکتیکی (FAB) در گوشهی پایین سمت راست کلیک کنید.
- سعی کنید در مورد محصولات سوال بپرسید، برای مثال:
- «من دنبال یک پوسته مقاوم در برابر آب و هوا هستم»
- کلاه بافتنی زیر صفر من خراب است، چه کاری از دستم برمیآید؟
- به عقب راندن ادامه بده تا منطق «بودجهی مماشات» هوش مصنوعی رو فعال کنی!
۹. (اختیاری) پاکسازی منابع از codelab
برای جلوگیری از هزینههای احتمالی برای حساب Google Cloud Billing خود، میتوانید منابع ایجاد شده در طول این codelab را حذف کنید.
- به کنسول فایربیس بروید.
- پروژه
rugged-terrain-aiرا انتخاب کنید. - به تنظیمات پروژه (آیکون چرخ دنده) بروید.
- به پایین بروید و روی «حذف پروژه» کلیک کنید.
- برای تأیید حذف، دستورالعملهای روی صفحه را دنبال کنید.
۱۰. تبریک میگویم!
🎊 ماموریت تکمیل شد! شما با موفقیت یک عامل پشتیبانی مشتری هوش مصنوعی قوی و مبتنی بر الگو را ادغام کردهاید.
کاری که شما انجام دادید:
- مقداردهی اولیه Firebase و Vertex AI backend در یک برنامه کلاینت.
- یک الگوی اعلان امن سمت سرور با استفاده از Handlebars و طرحهای ورودی دقیق پیکربندی شد تا رفتار پیچیده عامل را تعریف کند.
- به صورت پویا یک LLM فراخوانی میشود که تاریخچه چت و شناسههای متنی محصول را بدون افشای منطق داخلی اعلان به کلاینت، به صورت ایمن منتقل میکند.
بعدش چی؟
- بررسی برنامه Firebase : نقاط پایانی هوش مصنوعی خود را در برابر سوءاستفاده ایمن کنید.