الخلفية
تتيح لك ميزة "البطاقات المرتبطة تلقائيًا" إرسال بطاقات إضافية إلى مستخدم لديه بطاقتك الحالية في "محفظة Google". يمكنك أيضًا ربط البطاقات مسبقًا ببطاقة أساسية عندما يحفظ المستخدم البطاقة الأساسية (الرئيسية). يتم تجميع البطاقة المرتبطة تلقائيًا مع البطاقة الأساسية مع إشارة توضيحية فوق البطاقة الأساسية لإعلام المستخدم بأنّه تمت ربط بطاقة جديدة. يمكن استخدام أنواع البطاقات التالية كبطاقات أساسية أو مرتبطة:
- بطاقة الحدث
- جواز مرور على متن طائرة
- بطاقة النقل العام
- عرض
- بطاقة هدايا
- بطاقة الولاء
- بطاقة عامة
البطاقة الأساسية مع الإشارة إلى أنّه تمت إضافة بطاقة جديدة | بطاقة جديدة مرتبطة بالبطاقة الأساسية |
حالات الاستخدام
قد تكون لديك حالات استخدام مختلفة لربط البطاقات ببطاقة حالية. تشمل بعض الأمثلة ما يلي:
- ربط عرض بطاقة ولاء حالية
- ربط قسيمة طعام ببطاقة صعود طائرة أو تذكرة حضور فعالية
- ربط بطاقة وقوف السيارات بتذكرة حضور حدث
بعض الاعتبارات عند استخدام البطاقات المرتبطة تلقائيًا
- يجب أن يستخدم كلّ من العنصر الأساسي والعنصر المرتبط معًا معرّف المُصدر نفسه.
- هناك حدّ أقصى يبلغ 50 عنصرًا مرتبطًا لكلّ عنصر أساسي.
- لا يمكن ضمان إرسال البطاقات المرتبطة تلقائيًا، وننطبق عليها سياسة "بذل قصارى الإمكان". يمكن للمستخدمين إيقاف تلقّي البطاقات المرتبطة تلقائيًا. إذا كانت حالة الاستخدام حرجة ويجب أن يتلقّى المستخدم البطاقة المرتبطة، ننصحك بالتواصل من خلال قناة أخرى لضمان إضافة المستخدم للبطاقة.
- تتضمّن التعديلات على بنود الخدمة في "محفظة Google" إرشادات حول استخدام البطاقات المرتبطة تلقائيًا والتي يجب الالتزام بها.
خطوات الدمج
إذا سبق لك إنشاء عنصر أساسي، يمكنك تخطّي الخطوة 1.
- أنشئ عنصرًا من أي نوع بطاقة مُدرَج مع المَعلمات المطلوبة. هذا هو الكائن الأساسي.
- أنشئ عنصرًا آخر من أي نوع من أنواع البطاقات المدرَجة. سيكون هذا هو العنصر المرتبط.
- قبل حفظ الكائن الأساسي أو بعده، عدِّل الكائن الأساسي باستخدام رقم تعريف الكائن المرتبط في المَعلمة linkedObjectIds.
هناك حدّ أدنى للحمولة المطلوبة لضبط linkedObjectIds في ملف primary pass. تشمل المَعلمات الثلاث المطلوبة ما يلي:
- ISSUERID.PRIMARY_OBJECT_ID
- ISSUERID.PRIMARY_CLASS_ID
- ISSUERID.LINKED_OBJECT_ID
مثال على طلب JSON لإضافة عنصر مرتبط إلى عنصر بطاقة
… { "id": "ISSUERID.PASS_OBJECTID", "classId": "ISSUERID.PASS_CLASSID", "barcode": { "type": "qrCode", "value": "QR code" }, "linkedObjectIds": {"ISSUERID.LINKED_PASS_OBJECTID"} } …
مثال على استجابة JSON بعد ربط عنصر بعنصر بطاقة
… "state": "active", "linkedObjectIds": { "ISSUERID.LINKED_PASS_OBJECTID" } …
السلوك المتوقع
بعد تلقّي استجابة ناجحة، من المفترض أن تتلقّى الأجهزة التي تتضمّن البطاقة التي عدّلتها البطاقة المرتبطة. سيتم تجميع البطاقة المرتبطة هذه مع البطاقة الأساسية. يمكن للمستخدمين الاطّلاع على البطاقة المرتبطة من خلال التمرير سريعًا لليسار.
التعامل مع الاستثناءات
قد تحدث أخطاء محتملة عند استخدام واجهة برمجة التطبيقات بشكل غير صحيح، وقد تشمل:
رسالة | السبب |
---|---|
لا يتشارك الجسم الأساسي والجسم المرتبط معًا رقم تعريف ملف تعريف العميل المُصدِر نفسه. | لا يمكنك إرفاق عنصر مرتبط بعنصر تابع لمُصدِر آخر. |
يشير العنصر الأساسي والعنصر المرتبط إلى العنصر نفسه. | لا يمكنك إرفاق العنصر نفسه كعنصر linkedObject. |
الكائن المرتبط غير موجود. | يجب أن يكون العنصر المرتبط قد تم إدراجه في واجهة برمجة التطبيقات Wallet API. |
يتضمّن العنصر المرتبط عنصرًا مرتبطًا آخر. لا يمكن إضافة عناصر متداخلة مرتبطة. | لا يمكن أن يتضمّن العنصر المرتبط عنصرًا مرتبطًا آخر. |
سبق أن تم ربط العنصر بعنصر آخر. لا يمكن إضافة عناصر مرتبطة متداخلة. | لا يمكن أن يكون العنصر الأساسي عنصرًا مرتبطًا بحد ذاته. |
لا يمكن إضافة المزيد من العناصر المرتبطة، تم تجاوز الحد الأقصى. | تم بلوغ الحد الأقصى المسموح به وهو 50 بطاقة مرتبطة بالبطاقة الأساسية. |