chrome.vpnProvider

الوصف

استخدِم واجهة برمجة التطبيقات chrome.vpnProvider لتنفيذ برنامج شبكة VPN.

الأذونات

vpnProvider

مدى التوفّر

الإصدار 43 من Chrome أو إصدار أحدث نظام التشغيل ChromeOS فقط

الاستخدام

في ما يلي الاستخدامات النموذجية لـ vpnProvider:

  • أنشئ إعدادات شبكة VPN باستخدام طريقة createConfig. إعدادات الشبكة الافتراضية الخاصة (VPN) هي إدخال دائم يظهر للمستخدم في واجهة مستخدم ChromeOS أصلية. يمكن للمستخدم اختيار إعدادات شبكة VPN من قائمة والاتصال بها أو قطع الاتصال بها.

  • أضِف أدوات معالجة الأحداث onPlatformMessage وonPacketReceived وonConfigRemoved.

  • عندما يتصل المستخدم بإعدادات شبكة VPN، سيتم تلقّي onPlatformMessage مع الرسالة "connected". نشير إلى الفترة بين الرسالتين "connected" و"disconnected" على أنّها جلسة شبكة VPN. خلال هذه الفترة الزمنية، يُقال إنّ الإضافة التي تتلقّى الرسالة هي التي تملك جلسة شبكة VPN.

  • ابدأ الاتصال بخادم VPN وشغِّل برنامج VPN.

  • اضبط مَعلمات الاتصال باستخدام setParameters.

  • إرسال إشعار بحالة الاتصال على النحو "connected" باستخدام notifyConnectionStateChanged

  • عند إكمال الخطوات أعلاه بدون أخطاء، يتم إنشاء نفق افتراضي لمجموعة بروتوكولات الشبكة في ChromeOS. يمكن إرسال حِزم بروتوكول الإنترنت من خلال النفق باستخدام sendPacket وسيتم تلقّي أي حِزم مصدرها جهاز ChromeOS باستخدام الحدث onPacketReceived.

  • عندما يقطع المستخدم الاتصال بإعدادات الشبكة الافتراضية الخاصة، سيتم إطلاق الحدث onPlatformMessage مع الرسالة "disconnected".

  • إذا لم يعُد إعداد الشبكة الافتراضية الخاصة ضروريًا، يمكن إيقافه باستخدام destroyConfig.

الأنواع

Parameters

الخصائص

  • معالجة

    سلسلة

    عنوان IP لواجهة شبكة VPN بتدوين CIDR إنّ IPv4 هو الوضع الوحيد المتوافق حاليًا.

  • broadcastAddress

    سلسلة اختيارية

    عنوان البث العام لواجهة شبكة VPN (القيمة التلقائية: يتم استنتاجها من عنوان IP والقناع)

  • dnsServers

    string[]

    قائمة بعناوين IP لخوادم نظام أسماء النطاقات

  • domainSearch

    string[] اختياري

    قائمة بنطاقات البحث (القيمة التلقائية: ما مِن نطاق بحث)

  • exclusionList

    string[]

    استبعاد زيارات الشبكة إلى قائمة حظر عناوين IP في تدوين CIDR من النفق ويمكن استخدام ذلك لتجاوز عدد الزيارات من خادم VPN وإليه. عندما تتطابق العديد من القواعد مع وجهة، تفوز القاعدة التي تتضمّن أطول بادئة متطابقة. يتم التعامل مع الإدخالات التي تتوافق مع حزمة CIDR نفسها على أنّها مكرّرة. يتم استبعاد هذه التكرارات في القائمة المجمّعة (exclusionList + inclusionList)، ولا يمكن تحديد الإدخال المكرّر الذي سيتم استبعاده.

  • inclusionList

    string[]

    أدرِج حركة بيانات الشبكة في قائمة مجموعات عناوين IP بتدوين CIDR إلى النفق. يمكن استخدام هذه المَعلمة لإعداد نفق مقسَّم. لا يتم توجيه أي زيارات إلى النفق تلقائيًا. تؤدي إضافة الإدخال "0.0.0.0/0" إلى هذه القائمة إلى إعادة توجيه جميع حركة بيانات المستخدمين إلى النفق. عندما تتطابق العديد من القواعد مع وجهة، تفوز القاعدة التي تتضمّن أطول بادئة متطابقة. يتم التعامل مع الإدخالات التي تتوافق مع حزمة CIDR نفسها على أنّها مكرّرة. يتم استبعاد هذه التكرارات في القائمة المجمّعة (exclusionList + inclusionList)، ولا يمكن تحديد الإدخال المكرّر الذي سيتم استبعاده.

  • mtu

    سلسلة اختيارية

    إعداد MTU لواجهة شبكة VPN (القيمة التلقائية: 1500 بايت)

  • إعادة الاتصال

    سلسلة اختيارية

    Chrome 51 والإصدارات الأحدث

    تحديد ما إذا كانت إضافة VPN تنفّذ عملية إعادة الاتصال تلقائيًا

    في حال ضبط القيمة على "صحيح"، سيتم استخدام رسائل المنصة linkDown وlinkUp وlinkChanged وsuspend وresume للإشارة إلى الأحداث المعنية. في حال ضبطها على "خطأ"، سيقطع النظام الاتصال بشبكة VPN بالقوة إذا تغيّرت بنية الشبكة، وسيحتاج المستخدم إلى إعادة الاتصال يدويًا. (القيمة التلقائية: false)

    هذه السمة جديدة في الإصدار 51 من Chrome، وسيتم إنشاء استثناء في الإصدارات السابقة. يمكن استخدام try/catch لتفعيل الميزة بشكل مشروط استنادًا إلى توافق المتصفّح.

PlatformMessage

يستخدم النظام الأساسي التعداد لإعلام العميل بحالة جلسة VPN.

Enum

"متصل"
يشير إلى أنّ إعدادات شبكة VPN متصلة.

"غير متصل"
تشير إلى أنّ إعدادات شبكة VPN غير متصلة.

"error"
يشير إلى حدوث خطأ في الاتصال عبر شبكة VPN، مثل انتهاء المهلة. يتم تقديم وصف للخطأ كوسيط خطأ إلى onPlatformMessage.

‫"linkDown"
تشير إلى أنّ الاتصال التلقائي بالشبكة الفعلية غير متاح.

‫"linkUp"
يشير إلى أنّ الاتصال التلقائي بالشبكة الفعلية قد عاد.

linkChanged
يشير إلى أنّه تم تغيير الاتصال التلقائي بالشبكة الفعلية، مثلاً من شبكة Wi-Fi إلى شبكة الجوّال.

"تعليق"
يشير إلى أنّ نظام التشغيل يستعد للتعليق، لذا يجب أن توقف شبكة VPN اتصالها. لا يُضمَن تلقّي الإضافة لهذا الحدث قبل التعليق.

"resume"
يشير إلى أنّ نظام التشغيل قد استأنف نشاطه وأنّ المستخدم قد سجّل الدخول مرة أخرى، لذا يجب أن تحاول شبكة VPN إعادة الاتصال.

UIEvent

تستخدم المنصة التعداد لتحديد الحدث الذي أدّى إلى تشغيل onUIEvent.

Enum

"showAddDialog"
يطلب من عميل شبكة VPN عرض مربّع حوار إضافة الإعدادات للمستخدم.

‫"showConfigureDialog"
يطلب هذا الأمر من عميل شبكة VPN عرض مربّع حوار إعدادات الضبط للمستخدم.

VpnConnectionState

يستخدم برنامج VPN هذا التعداد لإبلاغ النظام الأساسي بحالته الحالية. يساعد ذلك في تقديم رسائل مفيدة للمستخدم.

Enum

"متصل"
تحدّد هذه الحالة أنّه تم ربط شبكة VPN بنجاح.

"failure"
تحدّد هذه السمة أنّ الاتصال بشبكة VPN قد تعذّر.

الطُرق

createConfig()

الوعد
chrome.vpnProvider.createConfig(
  name: string,
  callback?: function,
)
: Promise<string>

تنشئ هذه السياسة إعدادات جديدة لشبكة VPN تظل سارية على مستوى جلسات تسجيل الدخول المتعددة للمستخدم.

المعلمات

  • الاسم

    سلسلة

    اسم إعداد شبكة VPN

  • callback

    الدالة اختيارية

    تظهر المَعلمة callback على النحو التالي:

    (id: string) => void

    • id

      سلسلة

      معرّف فريد للإعدادات التي تم إنشاؤها، أو undefined في حال حدوث خطأ.

المرتجعات

  • Promise<string>

    الإصدار 96 من Chrome والإصدارات الأحدث

    لا تتوافق الوعود إلا مع الإصدار Manifest V3 والإصدارات الأحدث، ويجب أن تستخدم المنصات الأخرى عمليات رد الاتصال.

destroyConfig()

الوعد
chrome.vpnProvider.destroyConfig(
  id: string,
  callback?: function,
)
: Promise<void>

تدمّر هذه الطريقة إعدادات شبكة VPN التي أنشأتها الإضافة.

المعلمات

  • id

    سلسلة

    معرّف إعدادات شبكة VPN التي سيتم إيقافها

  • callback

    الدالة اختيارية

    تظهر المَعلمة callback على النحو التالي:

    () => void

المرتجعات

  • Promise<void>

    الإصدار 96 من Chrome والإصدارات الأحدث

    لا تتوافق الوعود إلا مع الإصدار Manifest V3 والإصدارات الأحدث، ويجب أن تستخدم المنصات الأخرى عمليات رد الاتصال.

notifyConnectionStateChanged()

الوعد
chrome.vpnProvider.notifyConnectionStateChanged(
  state: VpnConnectionState,
  callback?: function,
)
: Promise<void>

يُعلم هذا الإجراء النظام الأساسي بحالة جلسة الشبكة الافتراضية الخاصة. ولن ينجح ذلك إلا عندما تكون الإضافة هي مالكة جلسة شبكة VPN.

المعلمات

  • الولاية

    حالة جلسة شبكة VPN الخاصة بعميل شبكة VPN

  • callback

    الدالة اختيارية

    تظهر المَعلمة callback على النحو التالي:

    () => void

المرتجعات

  • Promise<void>

    الإصدار 96 من Chrome والإصدارات الأحدث

    لا تتوافق الوعود إلا مع الإصدار Manifest V3 والإصدارات الأحدث، ويجب أن تستخدم المنصات الأخرى عمليات رد الاتصال.

sendPacket()

الوعد
chrome.vpnProvider.sendPacket(
  data: ArrayBuffer,
  callback?: function,
)
: Promise<void>

إرسال حزمة IP عبر النفق الذي تم إنشاؤه لجلسة VPN ولن ينجح ذلك إلا عندما تكون الإضافة هي مالكة جلسة شبكة VPN.

المعلمات

  • البيانات

    ArrayBuffer

    حزمة بروتوكول الإنترنت التي سيتم إرسالها إلى المنصة

  • callback

    الدالة اختيارية

    تظهر المَعلمة callback على النحو التالي:

    () => void

المرتجعات

  • Promise<void>

    الإصدار 96 من Chrome والإصدارات الأحدث

    لا تتوافق الوعود إلا مع الإصدار Manifest V3 والإصدارات الأحدث، ويجب أن تستخدم المنصات الأخرى عمليات رد الاتصال.

setParameters()

الوعد
chrome.vpnProvider.setParameters(
  parameters: Parameters,
  callback?: function,
)
: Promise<void>

تضبط هذه السياسة مَعلمات جلسة شبكة VPN. يجب طلب هذا الإذن فور تلقّي "connected" من المنصة. ولن ينجح ذلك إلا عندما تكون الإضافة هي مالكة جلسة شبكة VPN.

المعلمات

  • المعلمات

    مَعلمات جلسة شبكة VPN

  • callback

    الدالة اختيارية

    تظهر المَعلمة callback على النحو التالي:

    () => void

المرتجعات

  • Promise<void>

    الإصدار 96 من Chrome والإصدارات الأحدث

    لا تتوافق الوعود إلا مع الإصدار Manifest V3 والإصدارات الأحدث، ويجب أن تستخدم المنصات الأخرى عمليات رد الاتصال.

الفعاليات

onConfigCreated

chrome.vpnProvider.onConfigCreated.addListener(
  callback: function,
)

يتم تشغيله عندما ينشئ النظام الأساسي إعدادًا للإضافة.

المعلمات

  • callback

    دالة

    تظهر المَعلمة callback على النحو التالي:

    (id: string, name: string, data: object) => void

    • id

      سلسلة

    • الاسم

      سلسلة

    • البيانات

      عنصر

onConfigRemoved

chrome.vpnProvider.onConfigRemoved.addListener(
  callback: function,
)

يتم تشغيله عندما يزيل النظام الأساسي إعدادًا أنشأته الإضافة.

المعلمات

  • callback

    دالة

    تظهر المَعلمة callback على النحو التالي:

    (id: string) => void

    • id

      سلسلة

onPacketReceived

chrome.vpnProvider.onPacketReceived.addListener(
  callback: function,
)

يتم تشغيله عند تلقّي حزمة بروتوكول إنترنت عبر النفق لجلسة شبكة VPN التي يملكها الامتداد.

المعلمات

  • callback

    دالة

    تظهر المَعلمة callback على النحو التالي:

    (data: ArrayBuffer) => void

    • البيانات

      ArrayBuffer

onPlatformMessage

chrome.vpnProvider.onPlatformMessage.addListener(
  callback: function,
)

يتم تشغيله عند تلقّي رسالة من النظام الأساسي بشأن إعدادات شبكة VPN تملكها الإضافة.

المعلمات

  • callback

    دالة

    تظهر المَعلمة callback على النحو التالي:

    (id: string, message: PlatformMessage, error: string) => void

onUIEvent

chrome.vpnProvider.onUIEvent.addListener(
  callback: function,
)

يتم تشغيله عند حدوث حدث في واجهة المستخدم للإضافة. أحداث واجهة المستخدِم هي إشارات من النظام الأساسي تشير إلى التطبيق بأنّه يجب عرض مربّع حوار خاص بواجهة المستخدِم للمستخدم.

المعلمات

  • callback

    دالة

    تظهر المَعلمة callback على النحو التالي:

    (event: UIEvent, id?: string) => void

    • حدث
    • id

      سلسلة اختيارية