Files
tf_code/packages/web/src/content/docs/ar/sdk.mdx
2026-02-28 15:27:11 -06:00

464 lines
22 KiB
Plaintext
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
---
title: مجموعة تطوير البرمجيات (SDK)
description: عميل JavaScript آمن الأنواع لخادم opencode.
---
import config from "../../../../config.mjs"
export const typesUrl = `${config.github}/blob/dev/packages/sdk/js/src/gen/types.gen.ts`
توفر SDK الخاصة بـ opencode لـ JS/TS عميلا آمنا للأنواع للتفاعل مع الخادم.
استخدمها لبناء التكاملات والتحكم في opencode برمجيا.
[اعرف المزيد](/docs/server) حول كيفية عمل الخادم. للاطلاع على أمثلة، تفقد [المشاريع](/docs/ecosystem#projects) التي أنشأها المجتمع.
---
## التثبيت
ثبّت SDK من npm:
```bash
npm install @opencode-ai/sdk
```
---
## إنشاء عميل
أنشئ مثيلا من opencode:
```javascript
import { createOpencode } from "@opencode-ai/sdk"
const { client } = await createOpencode()
```
هذا يشغّل خادما وعميلا معا.
#### الخيارات
| الخيار | النوع | الوصف | الافتراضي |
| ---------- | ------------- | ----------------------------- | ----------- |
| `hostname` | `string` | اسم مضيف الخادم | `127.0.0.1` |
| `port` | `number` | منفذ الخادم | `4096` |
| `signal` | `AbortSignal` | إشارة إلغاء للإيقاف | `undefined` |
| `timeout` | `number` | مهلة بدء الخادم بالمللي ثانية | `5000` |
| `config` | `Config` | كائن الإعدادات | `{}` |
---
## الإعدادات
يمكنك تمرير كائن إعدادات لتخصيص السلوك. سيستمر المثيل في التقاط `opencode.json` لديك، لكن يمكنك تجاوز الإعدادات أو إضافة إعدادات مباشرة:
```javascript
import { createOpencode } from "@opencode-ai/sdk"
const opencode = await createOpencode({
hostname: "127.0.0.1",
port: 4096,
config: {
model: "anthropic/claude-3-5-sonnet-20241022",
},
})
console.log(`Server running at ${opencode.server.url}`)
opencode.server.close()
```
## العميل فقط
إذا كان لديك مثيل opencode يعمل بالفعل، يمكنك إنشاء مثيل عميل للاتصال به:
```javascript
import { createOpencodeClient } from "@opencode-ai/sdk"
const client = createOpencodeClient({
baseUrl: "http://localhost:4096",
})
```
#### الخيارات
| الخيار | النوع | الوصف | الافتراضي |
| --------------- | ---------- | --------------------------------- | ----------------------- |
| `baseUrl` | `string` | عنوان URL للخادم | `http://localhost:4096` |
| `fetch` | `function` | تنفيذ fetch مخصص | `globalThis.fetch` |
| `parseAs` | `string` | طريقة تحليل الاستجابة | `auto` |
| `responseStyle` | `string` | أسلوب الإرجاع: `data` أو `fields` | `fields` |
| `throwOnError` | `boolean` | رمي الأخطاء بدلا من إرجاعها | `false` |
---
## الأنواع
تتضمن SDK تعريفات TypeScript لجميع أنواع API. استوردها مباشرة:
```typescript
import type { Session, Message, Part } from "@opencode-ai/sdk"
```
جميع الأنواع مولّدة من مواصفات OpenAPI الخاصة بالخادم ومتاحة في <a href={typesUrl}>ملف الأنواع</a>.
---
## الأخطاء
يمكن أن ترمي SDK أخطاء يمكنك التقاطها ومعالجتها:
```typescript
try {
await client.session.get({ path: { id: "invalid-id" } })
} catch (error) {
console.error("Failed to get session:", (error as Error).message)
}
```
---
## المخرجات المنظمة
يمكنك طلب مخرجات JSON منظمة من النموذج عن طريق تحديد `format` مع مخطط JSON. سيستخدم النموذج أداة `StructuredOutput` لإرجاع JSON تم التحقق من صحته ومطابق للمخطط الخاص بك.
### الاستخدام الأساسي
```typescript
const result = await client.session.prompt({
path: { id: sessionId },
body: {
parts: [{ type: "text", text: "Research Anthropic and provide company info" }],
format: {
type: "json_schema",
schema: {
type: "object",
properties: {
company: { type: "string", description: "Company name" },
founded: { type: "number", description: "Year founded" },
products: {
type: "array",
items: { type: "string" },
description: "Main products",
},
},
required: ["company", "founded"],
},
},
},
})
// Access the structured output
console.log(result.data.info.structured_output)
// { company: "Anthropic", founded: 2021, products: ["Claude", "Claude API"] }
```
### أنواع صيغ الإخراج
| النوع | الوصف |
| ------------- | -------------------------------------------------- |
| `text` | الافتراضي. استجابة نصية قياسية (بدون مخرجات منظمة) |
| `json_schema` | يرجع JSON تم التحقق من صحته ومطابق للمخطط المقدم |
### صيغة مخطط JSON
عند استخدام `type: 'json_schema'`، يجب تقديم:
| الحقل | النوع | الوصف |
| ------------ | --------------- | ------------------------------------------------ |
| `type` | `'json_schema'` | مطلوب. يحدد وضع مخطط JSON |
| `schema` | `object` | مطلوب. كائن مخطط JSON الذي يحدد بنية الإخراج |
| `retryCount` | `number` | اختياري. عدد محاولات إعادة التحقق (الافتراضي: 2) |
### معالجة الأخطاء
إذا فشل النموذج في إنتاج مخرجات منظمة صالحة بعد جميع المحاولات، ستتضمن الاستجابة `StructuredOutputError`:
```typescript
if (result.data.info.error?.name === "StructuredOutputError") {
console.error("Failed to produce structured output:", result.data.info.error.message)
console.error("Attempts:", result.data.info.error.retries)
}
```
### أفضل الممارسات
1. **قدّم أوصافا واضحة** في خصائص المخطط لمساعدة النموذج على فهم البيانات التي يجب استخراجها
2. **استخدم `required`** لتحديد الحقول التي يجب أن تكون موجودة
3. **حافظ على تركيز المخططات** - المخططات المتداخلة المعقدة قد تكون أصعب على النموذج لملئها بشكل صحيح
4. **عيّن `retryCount` مناسبا** - قم بزيادته للمخططات المعقدة، وتقليله للمخططات البسيطة
---
## APIs
توفر SDK جميع واجهات الخادم عبر عميل آمن للأنواع.
---
### عام (`global`)
| الطريقة | الوصف | الاستجابة |
| ----------------- | ---------------------------- | ------------------------------------ |
| `global.health()` | التحقق من صحة الخادم وإصداره | `{ healthy: true, version: string }` |
---
#### أمثلة
```javascript
const health = await client.global.health()
console.log(health.data.version)
```
---
### التطبيق (`app`)
| الطريقة | الوصف | الاستجابة |
| -------------- | ------------------------- | ------------------------------------------- |
| `app.log()` | كتابة إدخال في السجل | `boolean` |
| `app.agents()` | سرد جميع الوكلاء المتاحين | <a href={typesUrl}><code>Agent[]</code></a> |
---
#### أمثلة
```javascript
// Write a log entry
await client.app.log({
body: {
service: "my-app",
level: "info",
message: "Operation completed",
},
})
// List available agents
const agents = await client.app.agents()
```
---
### المشروع (`project`)
| الطريقة | الوصف | الاستجابة |
| ------------------- | ------------------ | --------------------------------------------- |
| `project.list()` | سرد جميع المشاريع | <a href={typesUrl}><code>Project[]</code></a> |
| `project.current()` | جلب المشروع الحالي | <a href={typesUrl}><code>Project</code></a> |
---
#### أمثلة
```javascript
// List all projects
const projects = await client.project.list()
// Get current project
const currentProject = await client.project.current()
```
---
### المسار (`path`)
| الطريقة | الوصف | الاستجابة |
| ------------ | ----------------- | ---------------------------------------- |
| `path.get()` | جلب المسار الحالي | <a href={typesUrl}><code>Path</code></a> |
---
#### أمثلة
```javascript
// Get current path information
const pathInfo = await client.path.get()
```
---
### الإعدادات (`config`)
| الطريقة | الوصف | الاستجابة |
| -------------------- | --------------------------------- | ----------------------------------------------------------------------------------------------------- |
| `config.get()` | جلب معلومات الإعدادات | <a href={typesUrl}><code>Config</code></a> |
| `config.providers()` | سرد المزوّدين والنماذج الافتراضية | `{ providers: `<a href={typesUrl}><code>Provider[]</code></a>`, default: { [key: string]: string } }` |
---
#### أمثلة
```javascript
const config = await client.config.get()
const { providers, default: defaults } = await client.config.providers()
```
---
### الجلسات (`session`)
| الطريقة | الوصف | ملاحظات |
| ---------------------------------------------------------- | -------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| `session.list()` | سرد الجلسات | يعيد <a href={typesUrl}><code>Session[]</code></a> |
| `session.get({ path })` | جلب جلسة | يعيد <a href={typesUrl}><code>Session</code></a> |
| `session.children({ path })` | سرد الجلسات الفرعية | يعيد <a href={typesUrl}><code>Session[]</code></a> |
| `session.create({ body })` | إنشاء جلسة | يعيد <a href={typesUrl}><code>Session</code></a> |
| `session.delete({ path })` | حذف جلسة | يعيد `boolean` |
| `session.update({ path, body })` | تحديث خصائص الجلسة | يعيد <a href={typesUrl}><code>Session</code></a> |
| `session.init({ path, body })` | تحليل التطبيق وإنشاء `AGENTS.md` | يعيد `boolean` |
| `session.abort({ path })` | إيقاف جلسة قيد التشغيل | يعيد `boolean` |
| `session.share({ path })` | مشاركة جلسة | يعيد <a href={typesUrl}><code>Session</code></a> |
| `session.unshare({ path })` | إلغاء مشاركة جلسة | يعيد <a href={typesUrl}><code>Session</code></a> |
| `session.summarize({ path, body })` | تلخيص جلسة | يعيد `boolean` |
| `session.messages({ path })` | سرد الرسائل في جلسة | يعيد `{ info: `<a href={typesUrl}><code>Message</code></a>`, parts: `<a href={typesUrl}><code>Part[]</code></a>`}[]` |
| `session.message({ path })` | جلب تفاصيل الرسالة | يعيد `{ info: `<a href={typesUrl}><code>Message</code></a>`, parts: `<a href={typesUrl}><code>Part[]</code></a>`}` |
| `session.prompt({ path, body })` | إرسال رسالة مطالبة | `body.noReply: true` يعيد UserMessage (للسياق فقط). الافتراضي يعيد <a href={typesUrl}><code>AssistantMessage</code></a> مع استجابة AI. يدعم `body.outputFormat` من أجل [المخرجات المنظمة](#المخرجات-المنظمة) |
| `session.command({ path, body })` | إرسال أمر إلى الجلسة | يعيد `{ info: `<a href={typesUrl}><code>AssistantMessage</code></a>`, parts: `<a href={typesUrl}><code>Part[]</code></a>`}` |
| `session.shell({ path, body })` | تشغيل أمر shell | يعيد <a href={typesUrl}><code>AssistantMessage</code></a> |
| `session.revert({ path, body })` | التراجع عن رسالة | يعيد <a href={typesUrl}><code>Session</code></a> |
| `session.unrevert({ path })` | استعادة الرسائل المتراجع عنها | يعيد <a href={typesUrl}><code>Session</code></a> |
| `postSessionByIdPermissionsByPermissionId({ path, body })` | الاستجابة لطلب إذن | يعيد `boolean` |
---
#### أمثلة
```javascript
// Create and manage sessions
const session = await client.session.create({
body: { title: "My session" },
})
const sessions = await client.session.list()
// Send a prompt message
const result = await client.session.prompt({
path: { id: session.id },
body: {
model: { providerID: "anthropic", modelID: "claude-3-5-sonnet-20241022" },
parts: [{ type: "text", text: "Hello!" }],
},
})
// Inject context without triggering AI response (useful for plugins)
await client.session.prompt({
path: { id: session.id },
body: {
noReply: true,
parts: [{ type: "text", text: "You are a helpful assistant." }],
},
})
```
---
### الملفات
| الطريقة | الوصف | الاستجابة |
| ------------------------- | ----------------------------------- | -------------------------------------------------------------------------------------------- |
| `find.text({ query })` | البحث عن نص داخل الملفات | مصفوفة من كائنات المطابقة مع `path` و`lines` و`line_number` و`absolute_offset` و`submatches` |
| `find.files({ query })` | العثور على الملفات والمجلدات بالاسم | `string[]` (مسارات) |
| `find.symbols({ query })` | العثور على رموز مساحة العمل | <a href={typesUrl}><code>Symbol[]</code></a> |
| `file.read({ query })` | قراءة ملف | `{ type: "raw" \| "patch", content: string }` |
| `file.status({ query? })` | جلب حالة الملفات المتتبَّعة | <a href={typesUrl}><code>File[]</code></a> |
يدعم `find.files` بعض حقول الاستعلام الاختيارية:
- `type`: `"file"` أو `"directory"`
- `directory`: تجاوز جذر المشروع لعملية البحث
- `limit`: الحد الأقصى للنتائج (1200)
---
#### أمثلة
```javascript
// Search and read files
const textResults = await client.find.text({
query: { pattern: "function.*opencode" },
})
const files = await client.find.files({
query: { query: "*.ts", type: "file" },
})
const directories = await client.find.files({
query: { query: "packages", type: "directory", limit: 20 },
})
const content = await client.file.read({
query: { path: "src/index.ts" },
})
```
---
### واجهة TUI (`tui`)
| الطريقة | الوصف | الاستجابة |
| ------------------------------ | ---------------------- | --------- |
| `tui.appendPrompt({ body })` | إلحاق نص بالمطالبة | `boolean` |
| `tui.openHelp()` | فتح مربع حوار المساعدة | `boolean` |
| `tui.openSessions()` | فتح محدد الجلسات | `boolean` |
| `tui.openThemes()` | فتح محدد السمات | `boolean` |
| `tui.openModels()` | فتح محدد النماذج | `boolean` |
| `tui.submitPrompt()` | إرسال المطالبة الحالية | `boolean` |
| `tui.clearPrompt()` | مسح المطالبة | `boolean` |
| `tui.executeCommand({ body })` | تنفيذ أمر | `boolean` |
| `tui.showToast({ body })` | عرض إشعار toast | `boolean` |
---
#### أمثلة
```javascript
// Control TUI interface
await client.tui.appendPrompt({
body: { text: "Add this to prompt" },
})
await client.tui.showToast({
body: { message: "Task completed", variant: "success" },
})
```
---
### المصادقة (`auth`)
| الطريقة | الوصف | الاستجابة |
| ------------------- | ---------------------------- | --------- |
| `auth.set({ ... })` | تعيين بيانات اعتماد المصادقة | `boolean` |
---
#### أمثلة
```javascript
await client.auth.set({
path: { id: "anthropic" },
body: { type: "api", key: "your-api-key" },
})
```
---
### الأحداث (`event`)
| الطريقة | الوصف | الاستجابة |
| ------------------- | -------------------------- | -------------------------- |
| `event.subscribe()` | تدفق أحداث مرسلة من الخادم | تدفق أحداث مرسلة من الخادم |
---
#### أمثلة
```javascript
// Listen to real-time events
const events = await client.event.subscribe()
for await (const event of events.stream) {
console.log("Event:", event.type, event.properties)
}
```