البطاقات المرتبطة تلقائيًا

الخلفية

تتيح لك ميزة "البطاقات المرتبطة تلقائيًا" إرسال بطاقات إضافية إلى مستخدم لديه بطاقتك الحالية في "محفظة Google". يمكنك أيضًا ربط البطاقات مسبقًا ببطاقة أساسية عندما يحفظ المستخدم البطاقة الأساسية (الرئيسية). يتم تجميع البطاقة المرتبطة تلقائيًا مع البطاقة الأساسية مع إشارة توضيحية فوق البطاقة الأساسية لإعلام المستخدم بأنّه تمت ربط بطاقة جديدة. يمكن استخدام أنواع البطاقات التالية كبطاقات أساسية أو مرتبطة:

  • بطاقة الحدث
  • جواز مرور على متن طائرة
  • بطاقة النقل العام
  • عرض
  • بطاقة هدايا
  • بطاقة الولاء
  • بطاقة عامة
المثال الأساسي للبطاقة المرتبطة تلقائيًا مثال ثانوي على البطاقة المرتبطة تلقائيًا
بطاقة أساسية مع وسيلة شرح تشير إلى إضافة بطاقة جديدة بطاقة جديدة مرتبطة بالبطاقة الأساسية

حالات الاستخدام

قد تكون لديك حالات استخدام مختلفة لربط البطاقات ببطاقة حالية. تشمل بعض الأمثلة ما يلي:

  • ربط عرض بطاقة ولاء حالية
  • يمكنك ربط قسيمة وجبة ببطاقة صعود الطائرة أو تذكرة حضور الفعاليات.
  • ربط بطاقة وقوف السيارات بتذكرة حضور حدث

بعض الاعتبارات عند استخدام البطاقات المرتبطة تلقائيًا

  • يجب أن يستخدم كلّ من العنصر الأساسي والعنصر المرتبط معًا معرّف المُصدر نفسه.
  • هناك حدّ أقصى يبلغ 50 عنصرًا مرتبطًا لكلّ عنصر أساسي.
  • لا يمكن ضمان إرسال البطاقات المرتبطة تلقائيًا، بل يُعد أفضل جهد ممكن. يمكن للمستخدمين إيقاف تلقّي البطاقات المرتبطة التلقائية. إذا كانت حالة الاستخدام حرجة ويجب أن يتلقّى المستخدم البطاقة المرتبطة، ننصحك بالتواصل من خلال قناة أخرى لضمان إضافة المستخدم للبطاقة.
  • تشمل التعديلات المُدخلة على سياسة الاستخدام المقبول في "محفظة Google" إرشادات حول استخدام البطاقات المرتبطة تلقائيًا والتي يجب الالتزام بها.

خطوات الدمج

إذا سبق لك إنشاء عنصر أساسي، يمكنك تخطّي الخطوة 1.

  1. أنشئ عنصرًا من أي نوع بطاقة مُدرَج مع المَعلمات المطلوبة. هذا هو الكائن الأساسي.
  2. أنشئ عنصرًا آخر من أي نوع من أنواع البطاقات المدرَجة. سيكون هذا هو العنصر المرتبط.
  3. قبل حفظ الكائن الأساسي أو بعده، عدِّل الكائن الأساسي باستخدام رقم تعريف الكائن المرتبط في المَعلمة linkedObjectIds .

هناك حدّ أدنى للحمولة المطلوبة لضبط ‎linkedObjectIds في ملف ‎primary pass. تشمل المَعلمات الثلاث المطلوبة ما يلي:

  1. ISSUERID.PRIMARY_OBJECT_ID
  2. ISSUERID.PRIMARY_CLASS_ID
  3. 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 بطاقة مرتبطة بالبطاقة الأساسية.