|
| 1 | +--- |
| 2 | +title: "الانتقال من inputs.id إلى restore_from_state_id" |
| 3 | +description: "نقل تدفقات @persist من ترطيب inputs.id المهجور إلى حقل restore_from_state_id المدعوم" |
| 4 | +icon: "arrow-right-arrow-left" |
| 5 | +--- |
| 6 | + |
| 7 | +<Warning> |
| 8 | + تمرير `id` داخل `inputs` لترطيب تدفق `@persist` هو **مهجور** ومقرر إزالته في إصدار مستقبلي. البديل، `restore_from_state_id`، متاح في CrewAI **v1.14.5 وما بعده** — الخطوات أدناه تنطبق بمجرد أن تقوم بالتحديث. |
| 9 | +</Warning> |
| 10 | + |
| 11 | +## نظرة عامة |
| 12 | + |
| 13 | +الطريقة الموثقة لترطيب تدفق `@persist` من تنفيذ سابق هي تمرير UUID لذلك التنفيذ كـ `inputs.id`. الآن، تكشف CrewAI عن حقل مخصص، `restore_from_state_id`، الذي يقوم بنفس الترطيب دون تحميل حمولة `inputs` — ودون ربط مفتاح الترطيب بهوية التنفيذ الجديد. |
| 14 | + |
| 15 | +## الانتقال |
| 16 | + |
| 17 | +إذا كنت حالياً تبدأ تدفق `@persist` باستخدام `inputs={"id": ...}`: |
| 18 | + |
| 19 | +```python |
| 20 | +# مهجور |
| 21 | +flow = CounterFlow() |
| 22 | +flow.kickoff(inputs={"id": "abcd1234-5678-90ef-ghij-klmnopqrstuv"}) |
| 23 | +``` |
| 24 | + |
| 25 | +انتقل إلى `restore_from_state_id`: |
| 26 | + |
| 27 | +```python |
| 28 | +# مدعوم |
| 29 | +flow = CounterFlow() |
| 30 | +flow.kickoff(restore_from_state_id="abcd1234-5678-90ef-ghij-klmnopqrstuv") |
| 31 | +``` |
| 32 | + |
| 33 | +تتمتع الوضعيتان بمعاني سلالة مختلفة: |
| 34 | + |
| 35 | +- `inputs={"id": <uuid>}` (مهجور) — **استئناف**: تكتب الكتابات تحت المعرف المقدم، مما يمدد نفس تاريخ `flow_uuid`. |
| 36 | +- `restore_from_state_id=<uuid>` — **تفرع**: يترطب الحالة من اللقطة، ثم يكتب تحت `state.id` جديدة. يتم الحفاظ على تاريخ التدفق المصدر. |
| 37 | + |
| 38 | +لأغلب سيناريوهات الإنتاج — إعادة تشغيل تدفق تم تهيئته من حالة سابقة — فإن التفرع هو ما تريده. راجع [إتقان حالة التدفق](/ar/guides/flows/mastering-flow-state) للحصول على النموذج الذهني الكامل. |
| 39 | + |
| 40 | +إذا كنت تبدأ تدفقك عبر واجهة برمجة تطبيقات CrewAI AMP REST، راجع [AMP](#amp) أدناه لهجرة الحمولة المعادلة. |
| 41 | + |
| 42 | +## لماذا نقوم بإهمال `inputs.id` لـ `@persist` |
| 43 | + |
| 44 | +`inputs.id` هو حالياً الطريقة الموثقة لاستئناف تدفق `@persist` من تنفيذ سابق. المشكلة هي أن نفس UUID يقوم بوظيفتين في وقت واحد: |
| 45 | + |
| 46 | +1. **يحدد أي لقطة يترطب منها `@persist`** — تحميل الحالة المحفوظة تحت ذلك UUID. |
| 47 | +2. **يصبح معرف تنفيذ التدفق الجديد** (`state.id` في SDK؛ يظهر كـ `flow_id` في بعض السياقات) — كل كتابة `@persist` من هذه البداية أيضاً تقع تحت نفس UUID. |
| 48 | + |
| 49 | +هذه الوظيفة المزدوجة هي السبب الجذري للمشاكل التي يصفها هذا الدليل. لأن UUID المقدم هو أيضاً معرف التنفيذ الجديد، فإن بدايتين تمرران نفس `inputs.id` ليست تنفيذين متميزين — إنهما تشتركان في معرف، وتشاركان في سجل الاستمرارية، و(على AMP) تشتركان في صف في قائمة التنفيذات. لا توجد طريقة للقول "ترطب من هذه اللقطة، ولكن سجل هذا التشغيل بشكل منفصل" دون تقسيم المسؤوليتين. |
| 50 | + |
| 51 | +`restore_from_state_id` هو هذا الانقسام. إنه يخبر `@persist` من أي لقطة يترطب، بينما يترك التنفيذ الجديد حراً لاستلام `state.id` جديدة. لم يعد مصدر الترطيب والتشغيل المسجل نفس UUID — وهو ما تريده معظم سيناريوهات الإنتاج فعلياً. |
| 52 | + |
| 53 | +## جدول إزالة |
| 54 | + |
| 55 | +من المقرر إزالة `inputs.id` لترطيب `@persist` في إصدار مستقبلي من CrewAI. لا يوجد قطع صارم فوري — تظل التدفقات الحالية تعمل — ولكن بمجرد أن تقوم بالتحديث إلى v1.14.5 أو ما بعده، يجب أن يستخدم الكود الجديد `restore_from_state_id`، ويجب أن تهاجر التدفقات الحالية في الفرصة المناسبة التالية. |
| 56 | + |
| 57 | +## AMP |
| 58 | + |
| 59 | +إذا كنت تنشر تدفقك إلى CrewAI AMP، فإن الهجرة تمتد إلى الحمولة التي تبدأ بها المرسلة إلى طاقمك المنشور، وتظهر الأعراض المرئية لإعادة استخدام `inputs.id` على لوحة معلومات النشر. تغطي القسمان الفرعيان أدناه كلاهما. |
| 60 | + |
| 61 | +### هجرة حمولة البداية |
| 62 | + |
| 63 | +إذا كنت حالياً تبدأ تدفقاً منشوراً عن طريق تضمين `id` في `inputs`: |
| 64 | + |
| 65 | +```bash |
| 66 | +# مهجور |
| 67 | +curl -X POST \ |
| 68 | + -H "Content-Type: application/json" \ |
| 69 | + -H "Authorization: Bearer YOUR_CREW_TOKEN" \ |
| 70 | + -d '{"inputs": {"id": "abcd1234-5678-90ef-ghij-klmnopqrstuv", "topic": "AI Agent Frameworks"}}' \ |
| 71 | + https://your-crew-url.crewai.com/kickoff |
| 72 | +``` |
| 73 | + |
| 74 | +نقل UUID إلى حقل `restoreFromStateId` في المستوى الأعلى: |
| 75 | + |
| 76 | +```bash |
| 77 | +# مدعوم |
| 78 | +curl -X POST \ |
| 79 | + -H "Content-Type: application/json" \ |
| 80 | + -H "Authorization: Bearer YOUR_CREW_TOKEN" \ |
| 81 | + -d '{ |
| 82 | + "inputs": {"topic": "AI Agent Frameworks"}, |
| 83 | + "restoreFromStateId": "abcd1234-5678-90ef-ghij-klmnopqrstuv" |
| 84 | + }' \ |
| 85 | + https://your-crew-url.crewai.com/kickoff |
| 86 | +``` |
| 87 | + |
| 88 | +يجلس `restoreFromStateId` بجانب `inputs` في حمولة البداية، وليس داخلها. الآن، يحمل كائن `inputs` فقط القيم التي تستهلكها تدفقك فعلياً. |
| 89 | + |
| 90 | +### ماذا يحدث عند إعادة استخدام `inputs.id` |
| 91 | + |
| 92 | +عندما تتلقى AMP بداية لتدفق يتطابق `inputs.id` الخاص به مع تنفيذ موجود، فإنه يحل إلى السجل الموجود بدلاً من إنشاء سجل جديد. من لوحة معلومات النشر سترى: |
| 93 | + |
| 94 | +- **حالة التنفيذ** — حالة التشغيل الجديد تحل محل حالة التشغيل السابق. يمكن أن تعود تنفيذات مكتملة إلى `جارية`، أو يمكن أن تتحول تشغيلات `مكتملة` إلى `خطأ` إذا فشلت البداية الجديدة — في كلتا الحالتين، لم تعد لوحة المعلومات تعكس التشغيل الأصلي. |
| 95 | +- **التتبع** — تتراكم تتبعات OTel عبر البدايات لأنها تشترك في نفس معرف التنفيذ؛ تتبعات التشغيل السابق إما تُستبدل بـ، أو تُخلط مع، تشغيل الجديد. لم يعد إعادة التشغيل خطوة بخطوة يتوافق مع تنفيذ واحد. |
| 96 | +- **قائمة التنفيذات** — البدايات التي يجب أن تظهر كصفوف منفصلة تتقلص إلى إدخال واحد، مما يخفي التاريخ. |
| 97 | + |
| 98 | +تساعد الهجرة إلى `restoreFromStateId` في الحفاظ على كل بداية كتنفيذ خاص بها — مع حالتها الخاصة، وتتبعها، وصفها في القائمة — بينما لا تزال ترطب الحالة من تشغيل سابق. |
| 99 | + |
| 100 | +<Card title="هل تحتاج مساعدة؟" icon="headset" href="mailto:support@crewai.com"> |
| 101 | + اتصل بفريق الدعم لدينا إذا لم تكن متأكداً من أي وضع يحتاجه تدفقك أو واجهت مشاكل أثناء الهجرة. |
| 102 | +</Card> |
0 commit comments