config.mdx 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684
  1. ---
  2. title: الإعدادات
  3. description: استخدام ملف إعدادات OpenCode بصيغة JSON.
  4. ---
  5. يمكنك ضبط OpenCode باستخدام ملف إعدادات بصيغة JSON.
  6. ---
  7. ## التنسيق
  8. يدعم OpenCode تنسيقي **JSON** و**JSONC** (JSON مع تعليقات).
  9. ```jsonc title="opencode.jsonc"
  10. {
  11. "$schema": "https://opencode.ai/config.json",
  12. // Theme configuration
  13. "theme": "opencode",
  14. "model": "anthropic/claude-sonnet-4-5",
  15. "autoupdate": true,
  16. }
  17. ```
  18. ---
  19. ## المواقع
  20. يمكنك وضع ملف الإعدادات في عدة مواقع مختلفة، ولكل موقع
  21. ترتيب أولوية مختلف.
  22. :::note
  23. تُدمَج ملفات الإعدادات **معًا** ولا تُستبدَل.
  24. :::
  25. تُدمَج ملفات الإعدادات معًا ولا تُستبدَل. يتم جمع الإعدادات من مواقع الإعدادات التالية. تتجاوز الإعدادات اللاحقة الإعدادات السابقة فقط عند تعارض المفاتيح. أما الإعدادات غير المتعارضة فتبقى محفوظة من جميع الملفات.
  26. على سبيل المثال، إذا كان الإعداد العام يضبط `theme: "opencode"` و`autoupdate: true`، وكان إعداد المشروع يضبط `model: "anthropic/claude-sonnet-4-5"`، فستتضمن الإعدادات النهائية الخيارات الثلاثة جميعها.
  27. ---
  28. ### ترتيب الأولوية
  29. تُحمَّل مصادر الإعدادات بهذا الترتيب (المصادر اللاحقة تتجاوز السابقة):
  30. 1. **الإعدادات البعيدة** (من `.well-known/opencode`) - الإعدادات الافتراضية على مستوى المؤسسة
  31. 2. **الإعدادات العامة** (`~/.config/opencode/opencode.json`) - تفضيلات المستخدم
  32. 3. **إعدادات مخصصة** (`OPENCODE_CONFIG` env var) - تجاوزات مخصصة
  33. 4. **إعدادات المشروع** (`opencode.json` داخل المشروع) - إعدادات خاصة بالمشروع
  34. 5. **أدلة `.opencode`** - الوكلاء، الأوامر، الإضافات
  35. 6. **إعدادات ضمنية** (`OPENCODE_CONFIG_CONTENT` env var) - تجاوزات وقت التشغيل
  36. هذا يعني أن إعدادات المشروع يمكنها تجاوز الإعدادات العامة، وأن الإعدادات العامة يمكنها تجاوز الإعدادات الافتراضية البعيدة على مستوى المؤسسة.
  37. :::note
  38. يستخدم الدليلان `.opencode` و`~/.config/opencode` **أسماء جمع** للأدلة الفرعية: `agents/` و`commands/` و`modes/` و`plugins/` و`skills/` و`tools/` و`themes/`. كما تُدعَم أسماء المفرد (مثل `agent/`) للتوافق مع الإصدارات السابقة.
  39. :::
  40. ---
  41. ### عن بُعد
  42. يمكن للمؤسسات توفير إعدادات افتراضية عبر نقطة النهاية `.well-known/opencode`. يتم جلب ذلك تلقائيًا عندما تقوم بالمصادقة مع مزوّد يدعم هذه الميزة.
  43. تُحمَّل الإعدادات البعيدة أولًا لتكون طبقة الأساس. ويمكن لجميع مصادر الإعدادات الأخرى (العامة، وإعدادات المشروع) تجاوز هذه القيم الافتراضية.
  44. على سبيل المثال، إذا كانت مؤسستك توفر خوادم MCP معطّلة افتراضيًا:
  45. ```json title="Remote config from .well-known/opencode"
  46. {
  47. "mcp": {
  48. "jira": {
  49. "type": "remote",
  50. "url": "https://jira.example.com/mcp",
  51. "enabled": false
  52. }
  53. }
  54. }
  55. ```
  56. يمكنك تفعيل خوادم محددة في إعداداتك المحلية:
  57. ```json title="opencode.json"
  58. {
  59. "mcp": {
  60. "jira": {
  61. "type": "remote",
  62. "url": "https://jira.example.com/mcp",
  63. "enabled": true
  64. }
  65. }
  66. }
  67. ```
  68. ---
  69. ### عام
  70. ضع إعدادات OpenCode العامة في `~/.config/opencode/opencode.json`. استخدم الإعدادات العامة للتفضيلات على مستوى المستخدم مثل السمات، والمزوّدين، أو اختصارات المفاتيح.
  71. تتجاوز الإعدادات العامة القيم الافتراضية البعيدة الخاصة بالمؤسسة.
  72. ---
  73. ### لكل مشروع
  74. أضف `opencode.json` في جذر مشروعك. تمتلك إعدادات المشروع أعلى أولوية بين ملفات الإعدادات القياسية، إذ تتجاوز الإعدادات العامة والبعيدة معًا.
  75. :::tip
  76. ضع إعدادات المشروع الخاصة في جذر مشروعك.
  77. :::
  78. عند تشغيل OpenCode، يبحث عن ملف إعدادات في الدليل الحالي أو يصعد حتى أقرب دليل Git.
  79. ومن الآمن أيضًا تضمينه في Git، كما يستخدم نفس المخطط الخاص بالإعدادات العامة.
  80. ---
  81. ### مسار مخصص
  82. حدّد مسار ملف إعدادات مخصصًا باستخدام متغير البيئة `OPENCODE_CONFIG`.
  83. ```bash
  84. export OPENCODE_CONFIG=/path/to/my/custom-config.json
  85. opencode run "Hello world"
  86. ```
  87. تُحمَّل الإعدادات المخصصة بين الإعدادات العامة وإعدادات المشروع ضمن ترتيب الأولوية.
  88. ---
  89. ### دليل مخصص
  90. حدّد دليل إعدادات مخصصًا باستخدام متغير البيئة `OPENCODE_CONFIG_DIR`.
  91. سيتم البحث داخل هذا الدليل عن الوكلاء والأوامر والأوضاع والإضافات تمامًا مثل
  92. الدليل القياسي `.opencode`، ويجب أن يتبع نفس البنية.
  93. ```bash
  94. export OPENCODE_CONFIG_DIR=/path/to/my/config-directory
  95. opencode run "Hello world"
  96. ```
  97. يُحمَّل الدليل المخصص بعد الإعدادات العامة وأدلة `.opencode`، لذلك **يمكنه تجاوز** إعداداتها.
  98. ---
  99. ## المخطط
  100. يحتوي ملف الإعدادات على مخطط مُعرَّف في [**`opencode.ai/config.json`**](https://opencode.ai/config.json).
  101. يفترض أن يتمكن محررك من التحقق والإكمال التلقائي اعتمادًا على هذا المخطط.
  102. ---
  103. ### TUI
  104. يمكنك ضبط الإعدادات الخاصة بـ TUI عبر الخيار `tui`.
  105. ```json title="opencode.json"
  106. {
  107. "$schema": "https://opencode.ai/config.json",
  108. "tui": {
  109. "scroll_speed": 3,
  110. "scroll_acceleration": {
  111. "enabled": true
  112. },
  113. "diff_style": "auto"
  114. }
  115. }
  116. ```
  117. الخيارات المتاحة:
  118. - `scroll_acceleration.enabled` - تفعيل تسارع التمرير بأسلوب macOS. **له أولوية على `scroll_speed`.**
  119. - `scroll_speed` - مُضاعِف سرعة تمرير مخصص (الافتراضي: `3`، الحد الأدنى: `1`). يتم تجاهله إذا كان `scroll_acceleration.enabled` مساويًا لـ `true`.
  120. - `diff_style` - التحكم في عرض `diff`. القيمة `"auto"` تتكيف مع عرض terminal، و`"stacked"` تعرض عمودًا واحدًا دائمًا.
  121. [تعرف على المزيد حول استخدام TUI هنا](/docs/tui).
  122. ---
  123. ### الخادم
  124. يمكنك ضبط إعدادات الخادم لأوامر `opencode serve` و`opencode web` عبر الخيار `server`.
  125. ```json title="opencode.json"
  126. {
  127. "$schema": "https://opencode.ai/config.json",
  128. "server": {
  129. "port": 4096,
  130. "hostname": "0.0.0.0",
  131. "mdns": true,
  132. "mdnsDomain": "myproject.local",
  133. "cors": ["http://localhost:5173"]
  134. }
  135. }
  136. ```
  137. الخيارات المتاحة:
  138. - `port` - المنفذ الذي سيتم الاستماع عليه.
  139. - `hostname` - اسم المضيف الذي سيتم الاستماع عليه. عند تفعيل `mdns` وعدم ضبط اسم مضيف، تكون القيمة الافتراضية `0.0.0.0`.
  140. - `mdns` - تفعيل اكتشاف الخدمة عبر mDNS. يتيح ذلك للأجهزة الأخرى على الشبكة اكتشاف خادم OpenCode.
  141. - `mdnsDomain` - اسم نطاق مخصص لخدمة mDNS. القيمة الافتراضية هي `opencode.local`. مفيد لتشغيل عدة نُسخ على نفس الشبكة.
  142. - `cors` - أصول إضافية مسموح بها لـ CORS عند استخدام خادم HTTP من عميل يعتمد على المتصفح. يجب أن تكون القيم أصولًا كاملة (البروتوكول + المضيف + منفذ اختياري)، مثل `https://app.example.com`.
  143. [تعرف على المزيد حول الخادم هنا](/docs/server).
  144. ---
  145. ### الأدوات
  146. يمكنك إدارة الأدوات التي يمكن لـ LLM استخدامها عبر الخيار `tools`.
  147. ```json title="opencode.json"
  148. {
  149. "$schema": "https://opencode.ai/config.json",
  150. "tools": {
  151. "write": false,
  152. "bash": false
  153. }
  154. }
  155. ```
  156. [تعرف على المزيد حول الأدوات هنا](/docs/tools).
  157. ---
  158. ### النماذج
  159. يمكنك ضبط المزوّدين والنماذج التي تريد استخدامها في إعدادات OpenCode عبر الخيارات `provider` و`model` و`small_model`.
  160. ```json title="opencode.json"
  161. {
  162. "$schema": "https://opencode.ai/config.json",
  163. "provider": {},
  164. "model": "anthropic/claude-sonnet-4-5",
  165. "small_model": "anthropic/claude-haiku-4-5"
  166. }
  167. ```
  168. يضبط الخيار `small_model` نموذجًا منفصلًا للمهام الخفيفة مثل توليد العناوين. افتراضيًا يحاول OpenCode استخدام نموذج أقل تكلفة إذا كان متاحًا لدى مزوّدك، وإلا فسيعود إلى النموذج الرئيسي.
  169. قد تتضمن خيارات المزوّد `timeout` و`setCacheKey`:
  170. ```json title="opencode.json"
  171. {
  172. "$schema": "https://opencode.ai/config.json",
  173. "provider": {
  174. "anthropic": {
  175. "options": {
  176. "timeout": 600000,
  177. "setCacheKey": true
  178. }
  179. }
  180. }
  181. }
  182. ```
  183. - `timeout` - مهلة الطلب بالميلي ثانية (الافتراضي: 300000). اضبطه إلى `false` لتعطيله.
  184. - `setCacheKey` - يضمن تعيين مفتاح التخزين المؤقت دائمًا للمزوّد المحدد.
  185. يمكنك أيضًا ضبط [النماذج المحلية](/docs/models#local). [تعرف على المزيد](/docs/models).
  186. ---
  187. #### خيارات خاصة بالمزوّد
  188. يدعم بعض المزوّدين خيارات إعداد إضافية تتجاوز الإعدادات العامة مثل `timeout` و`apiKey`.
  189. ##### Amazon Bedrock
  190. يدعم Amazon Bedrock إعدادات خاصة بـ AWS:
  191. ```json title="opencode.json"
  192. {
  193. "$schema": "https://opencode.ai/config.json",
  194. "provider": {
  195. "amazon-bedrock": {
  196. "options": {
  197. "region": "us-east-1",
  198. "profile": "my-aws-profile",
  199. "endpoint": "https://bedrock-runtime.us-east-1.vpce-xxxxx.amazonaws.com"
  200. }
  201. }
  202. }
  203. }
  204. ```
  205. - `region` - منطقة AWS لـ Bedrock (الافتراضي: متغير البيئة `AWS_REGION` أو `us-east-1`)
  206. - `profile` - ملف تعريف AWS المُسمّى من `~/.aws/credentials` (الافتراضي: متغير البيئة `AWS_PROFILE`)
  207. - `endpoint` - عنوان URL لنقطة نهاية مخصصة لنقاط نهاية VPC. هذا اسم بديل للخيار العام `baseURL` باستخدام مصطلحات AWS. إذا تم تحديدهما معًا، تكون أولوية `endpoint` أعلى.
  208. :::note
  209. لرموز Bearer (`AWS_BEARER_TOKEN_BEDROCK` أو `/connect`) أولوية أعلى من المصادقة القائمة على ملف التعريف. راجع [أولوية المصادقة](/docs/providers#authentication-precedence) للتفاصيل.
  210. :::
  211. [تعرف على المزيد حول إعداد Amazon Bedrock](/docs/providers#amazon-bedrock).
  212. ---
  213. ### السمات
  214. يمكنك ضبط السمة التي تريد استخدامها في إعدادات OpenCode عبر الخيار `theme`.
  215. ```json title="opencode.json"
  216. {
  217. "$schema": "https://opencode.ai/config.json",
  218. "theme": ""
  219. }
  220. ```
  221. [تعرف على المزيد هنا](/docs/themes).
  222. ---
  223. ### الوكلاء
  224. يمكنك ضبط وكلاء متخصصين لمهام محددة عبر الخيار `agent`.
  225. ```jsonc title="opencode.jsonc"
  226. {
  227. "$schema": "https://opencode.ai/config.json",
  228. "agent": {
  229. "code-reviewer": {
  230. "description": "Reviews code for best practices and potential issues",
  231. "model": "anthropic/claude-sonnet-4-5",
  232. "prompt": "You are a code reviewer. Focus on security, performance, and maintainability.",
  233. "tools": {
  234. // Disable file modification tools for review-only agent
  235. "write": false,
  236. "edit": false,
  237. },
  238. },
  239. },
  240. }
  241. ```
  242. يمكنك أيضًا تعريف الوكلاء باستخدام ملفات markdown في `~/.config/opencode/agents/` أو `.opencode/agents/`. [تعرف على المزيد هنا](/docs/agents).
  243. ---
  244. ### الوكيل الافتراضي
  245. يمكنك تعيين الوكيل الافتراضي باستخدام الخيار `default_agent`. يحدد ذلك أي وكيل سيتم استخدامه عندما لا يتم تحديد وكيل صراحةً.
  246. ```json title="opencode.json"
  247. {
  248. "$schema": "https://opencode.ai/config.json",
  249. "default_agent": "plan"
  250. }
  251. ```
  252. يجب أن يكون الوكيل الافتراضي وكيلًا أساسيًا (وليس وكيلًا فرعيًا). يمكن أن يكون وكيلًا مدمجًا مثل `"build"` أو `"plan"`، أو [وكيلًا مخصصًا](/docs/agents) قمت بتعريفه. إذا لم يكن الوكيل المحدد موجودًا أو كان وكيلًا فرعيًا، فسيعود OpenCode إلى `"build"` مع تحذير.
  253. ينطبق هذا الإعداد على جميع الواجهات: TUI وCLI (`opencode run`) وتطبيق سطح المكتب وGitHub Action.
  254. ---
  255. ### المشاركة
  256. يمكنك ضبط ميزة [share](/docs/share) عبر الخيار `share`.
  257. ```json title="opencode.json"
  258. {
  259. "$schema": "https://opencode.ai/config.json",
  260. "share": "manual"
  261. }
  262. ```
  263. يقبل هذا الإعداد القيم التالية:
  264. - `"manual"` - السماح بالمشاركة اليدوية عبر الأوامر (الافتراضي)
  265. - `"auto"` - مشاركة المحادثات الجديدة تلقائيًا
  266. - `"disabled"` - تعطيل المشاركة بالكامل
  267. افتراضيًا تكون المشاركة في الوضع اليدوي، حيث تحتاج إلى مشاركة المحادثات صراحةً باستخدام الأمر `/share`.
  268. ---
  269. ### الأوامر
  270. يمكنك ضبط أوامر مخصصة للمهام المتكررة عبر الخيار `command`.
  271. ```jsonc title="opencode.jsonc"
  272. {
  273. "$schema": "https://opencode.ai/config.json",
  274. "command": {
  275. "test": {
  276. "template": "Run the full test suite with coverage report and show any failures.\nFocus on the failing tests and suggest fixes.",
  277. "description": "Run tests with coverage",
  278. "agent": "build",
  279. "model": "anthropic/claude-haiku-4-5",
  280. },
  281. "component": {
  282. "template": "Create a new React component named $ARGUMENTS with TypeScript support.\nInclude proper typing and basic structure.",
  283. "description": "Create a new component",
  284. },
  285. },
  286. }
  287. ```
  288. يمكنك أيضًا تعريف الأوامر باستخدام ملفات markdown في `~/.config/opencode/commands/` أو `.opencode/commands/`. [تعرف على المزيد هنا](/docs/commands).
  289. ---
  290. ### اختصارات المفاتيح
  291. يمكنك تخصيص اختصارات المفاتيح عبر الخيار `keybinds`.
  292. ```json title="opencode.json"
  293. {
  294. "$schema": "https://opencode.ai/config.json",
  295. "keybinds": {}
  296. }
  297. ```
  298. [تعرف على المزيد هنا](/docs/keybinds).
  299. ---
  300. ### التحديث التلقائي
  301. سيقوم OpenCode بتنزيل أي تحديثات جديدة تلقائيًا عند بدء التشغيل. يمكنك تعطيل ذلك عبر الخيار `autoupdate`.
  302. ```json title="opencode.json"
  303. {
  304. "$schema": "https://opencode.ai/config.json",
  305. "autoupdate": false
  306. }
  307. ```
  308. إذا لم تكن تريد التحديثات لكنك تريد الإشعار عند توفر نسخة جديدة، فاضبط `autoupdate` على `"notify"`.
  309. لاحظ أن هذا يعمل فقط إذا لم يتم تثبيته عبر مدير حزم مثل Homebrew.
  310. ---
  311. ### المنسّقات
  312. يمكنك ضبط منسّقات الشفرة عبر الخيار `formatter`.
  313. ```json title="opencode.json"
  314. {
  315. "$schema": "https://opencode.ai/config.json",
  316. "formatter": {
  317. "prettier": {
  318. "disabled": true
  319. },
  320. "custom-prettier": {
  321. "command": ["npx", "prettier", "--write", "$FILE"],
  322. "environment": {
  323. "NODE_ENV": "development"
  324. },
  325. "extensions": [".js", ".ts", ".jsx", ".tsx"]
  326. }
  327. }
  328. }
  329. ```
  330. [تعرف على المزيد حول المنسّقات هنا](/docs/formatters).
  331. ---
  332. ### الأذونات
  333. افتراضيًا يسمح opencode **بجميع العمليات** دون الحاجة إلى موافقة صريحة. يمكنك تغيير ذلك عبر الخيار `permission`.
  334. على سبيل المثال، لضمان أن أداتي `edit` و`bash` تتطلبان موافقة المستخدم:
  335. ```json title="opencode.json"
  336. {
  337. "$schema": "https://opencode.ai/config.json",
  338. "permission": {
  339. "edit": "ask",
  340. "bash": "ask"
  341. }
  342. }
  343. ```
  344. [تعرف على المزيد حول الأذونات هنا](/docs/permissions).
  345. ---
  346. ### ضغط السياق
  347. يمكنك التحكم في سلوك ضغط السياق عبر الخيار `compaction`.
  348. ```json title="opencode.json"
  349. {
  350. "$schema": "https://opencode.ai/config.json",
  351. "compaction": {
  352. "auto": true,
  353. "prune": true
  354. }
  355. }
  356. ```
  357. - `auto` - ضغط الجلسة تلقائيًا عند امتلاء السياق (الافتراضي: `true`).
  358. - `prune` - إزالة مخرجات الأدوات القديمة لتوفير الرموز (tokens) (الافتراضي: `true`).
  359. ---
  360. ### المراقِب
  361. يمكنك ضبط أنماط التجاهل لمراقِب الملفات عبر الخيار `watcher`.
  362. ```json title="opencode.json"
  363. {
  364. "$schema": "https://opencode.ai/config.json",
  365. "watcher": {
  366. "ignore": ["node_modules/**", "dist/**", ".git/**"]
  367. }
  368. }
  369. ```
  370. تتبع الأنماط صياغة `glob`. استخدم ذلك لاستبعاد الأدلة المزدحمة من مراقبة الملفات.
  371. ---
  372. ### خوادم MCP
  373. يمكنك ضبط خوادم MCP التي تريد استخدامها عبر الخيار `mcp`.
  374. ```json title="opencode.json"
  375. {
  376. "$schema": "https://opencode.ai/config.json",
  377. "mcp": {}
  378. }
  379. ```
  380. [تعرف على المزيد هنا](/docs/mcp-servers).
  381. ---
  382. ### الإضافات
  383. [الإضافات](/docs/plugins) توسّع OpenCode بأدوات وخُطافات وتكاملات مخصصة.
  384. ضع ملفات الإضافات في `.opencode/plugins/` أو `~/.config/opencode/plugins/`. يمكنك أيضًا تحميل إضافات من npm عبر الخيار `plugin`.
  385. ```json title="opencode.json"
  386. {
  387. "$schema": "https://opencode.ai/config.json",
  388. "plugin": ["opencode-helicone-session", "@my-org/custom-plugin"]
  389. }
  390. ```
  391. [تعرف على المزيد هنا](/docs/plugins).
  392. ---
  393. ### التعليمات
  394. يمكنك ضبط التعليمات الخاصة بالنموذج الذي تستخدمه عبر الخيار `instructions`.
  395. ```json title="opencode.json"
  396. {
  397. "$schema": "https://opencode.ai/config.json",
  398. "instructions": ["CONTRIBUTING.md", "docs/guidelines.md", ".cursor/rules/*.md"]
  399. }
  400. ```
  401. يقبل هذا مصفوفة من المسارات وأنماط `glob` لملفات التعليمات. [تعرف على المزيد
  402. حول القواعد هنا](/docs/rules).
  403. ---
  404. ### المزوّدون المعطّلون
  405. يمكنك تعطيل المزوّدين الذين يتم تحميلهم تلقائيًا عبر الخيار `disabled_providers`. هذا مفيد عندما تريد منع تحميل مزوّدين معينين حتى لو كانت بيانات الاعتماد الخاصة بهم متاحة.
  406. ```json title="opencode.json"
  407. {
  408. "$schema": "https://opencode.ai/config.json",
  409. "disabled_providers": ["openai", "gemini"]
  410. }
  411. ```
  412. :::note
  413. الخيار `disabled_providers` له أولوية على `enabled_providers`.
  414. :::
  415. يقبل الخيار `disabled_providers` مصفوفة من معرفات المزوّدين. عند تعطيل مزوّد:
  416. - لن يتم تحميله حتى لو كانت متغيرات البيئة مضبوطة.
  417. - لن يتم تحميله حتى لو كانت مفاتيح API مضبوطة عبر الأمر `/connect`.
  418. - لن تظهر نماذج هذا المزوّد في قائمة اختيار النموذج.
  419. ---
  420. ### المزوّدون المفعّلون
  421. يمكنك تحديد قائمة سماح للمزوّدين عبر الخيار `enabled_providers`. عند ضبطه، سيتم تفعيل المزوّدين المحددين فقط وسيتم تجاهل البقية.
  422. ```json title="opencode.json"
  423. {
  424. "$schema": "https://opencode.ai/config.json",
  425. "enabled_providers": ["anthropic", "openai"]
  426. }
  427. ```
  428. هذا مفيد عندما تريد تقييد OpenCode لاستخدام مزوّدين محددين بدلًا من تعطيلهم واحدًا تلو الآخر.
  429. :::note
  430. الخيار `disabled_providers` له أولوية على `enabled_providers`.
  431. :::
  432. إذا ظهر مزوّد ضمن كل من `enabled_providers` و`disabled_providers`، تكون أولوية `disabled_providers` أعلى للتوافق مع الإصدارات السابقة.
  433. ---
  434. ### تجريبي
  435. يحتوي المفتاح `experimental` على خيارات قيد التطوير النشط.
  436. ```json title="opencode.json"
  437. {
  438. "$schema": "https://opencode.ai/config.json",
  439. "experimental": {}
  440. }
  441. ```
  442. :::caution
  443. الخيارات التجريبية غير مستقرة. قد تتغير أو تُزال دون إشعار.
  444. :::
  445. ---
  446. ## المتغيرات
  447. يمكنك استخدام استبدال المتغيرات في ملفات الإعدادات للإشارة إلى متغيرات البيئة ومحتويات الملفات.
  448. ---
  449. ### متغيرات البيئة
  450. استخدم `{env:VARIABLE_NAME}` لاستبدال متغيرات البيئة:
  451. ```json title="opencode.json"
  452. {
  453. "$schema": "https://opencode.ai/config.json",
  454. "model": "{env:OPENCODE_MODEL}",
  455. "provider": {
  456. "anthropic": {
  457. "models": {},
  458. "options": {
  459. "apiKey": "{env:ANTHROPIC_API_KEY}"
  460. }
  461. }
  462. }
  463. }
  464. ```
  465. إذا لم يكن متغير البيئة مضبوطًا، فسيتم استبداله بسلسلة فارغة.
  466. ---
  467. ### الملفات
  468. استخدم `{file:path/to/file}` لاستبدال محتويات ملف:
  469. ```json title="opencode.json"
  470. {
  471. "$schema": "https://opencode.ai/config.json",
  472. "instructions": ["./custom-instructions.md"],
  473. "provider": {
  474. "openai": {
  475. "options": {
  476. "apiKey": "{file:~/.secrets/openai-key}"
  477. }
  478. }
  479. }
  480. }
  481. ```
  482. يمكن أن تكون مسارات الملفات:
  483. - نسبية إلى دليل ملف الإعدادات
  484. - أو مسارات مطلقة تبدأ بـ `/` أو `~`
  485. يُفيد ذلك في:
  486. - الاحتفاظ بالبيانات الحساسة مثل مفاتيح API في ملفات منفصلة.
  487. - تضمين ملفات تعليمات كبيرة دون تشويش ملف الإعدادات.
  488. - مشاركة مقتطفات إعدادات مشتركة عبر عدة ملفات إعدادات.