تولید آبجکت با AI در NextJS
توابعی مانند generateText و streamText امکان تولید متن بدون ساختار را فراهم میکنند. اما اگر بخواهید دادههای ساختاریافته مانند JSON تولید کنید، میتوانید با استفاده از تابع generateObject و ارائهی یک طرحواره (schema)، ساختار object مورد نظر را مشخص نمایید.
این تابع نیاز دارد که اسکیما را با استفاده از کتابخانهی Zod تعریف کنید؛ Zod کتابخانهای برای تعریف و اعتبارسنجی ساختار objectها در جاوااسکریپت است. با استفاده از Zod نهتنها میتوانید ساختار مورد انتظار را مشخص کنید، بلکه امکان validation آبجکت تولیدشده نیز وجود دارد تا مطمئن شوید که با ساختار تعریفشده مطابقت دارد.
کلاینت
بیایید یک کامپوننت سادهی React ایجاد کنیم که هنگام کلیک روی یک دکمه، یک درخواست POST به endpoint به نام api/completion/ ارسال میکند. این endpoint، یک object ساختاریافته را بر اساس پرامپت ورودی تولید کرده و آن را بازمیگرداند. ما نیز پس از دریافت پاسخ، object تولیدشده را در رابط کاربری نمایش خواهیم داد. در فایل app/page.tsx قطعه کد زیر را قرار دهید:
سرور
بیایید یک route handler برای api/completion/ ایجاد کنیم که بر اساس پرامپت ورودی، یک object ساختاریافته تولید کند. این route، تابع generateObject از ماژول ai را فراخوانی میکند. این تابع با استفاده از پرامپت ورودی، یک آبجکت تولید کرده و آن را بهعنوان پاسخ بازمیگرداند. در مسیر app/api/completion/route.ts، قطعه کد زیر را قرار دهید:
متغیرهای محیطی BASE_URL و LIARA_API_KEY همان baseUrl سرویس هوش مصنوعی لیارا و کلید API لیارا هستند که باید در بخش متغیرهای محیطی برنامه خود، آنها را تنظیم کنید.
پروژه فوق را میتوانید بهصورت کامل در گیتهاب لیارا، مشاهده کنید.