chrome.vpnProvider

Opis

Użyj interfejsu chrome.vpnProvider API, aby wdrożyć klienta VPN.

Uprawnienia

vpnProvider

Dostępność

Chrome 43 lub nowszy Tylko ChromeOS

Pojęcia i zastosowanie

Typowe zastosowanie parametru chrome.vpnProvider jest następujące:

  • Twórz konfiguracje sieci VPN, wywołując funkcję createConfig(). Konfiguracja sieci VPN to trwały wpis wyświetlany użytkownikowi w interfejsie ChromeOS. Użytkownik może wybrać konfigurację VPN z listy i połączyć się z nią lub rozłączyć się z nią.

  • Dodaj detektory do zdarzeń onPlatformMessage, onPacketReceivedonConfigRemoved.

  • Gdy użytkownik połączy się z konfiguracją sieci VPN, otrzyma kod onPlatformMessage z komunikatem "connected". Okres między wiadomościami "connected""disconnected" nazywa się „sesją VPN”. W tym okresie rozszerzenie, które otrzyma wiadomość, jest właścicielem sesji VPN.

  • Zainicjuj połączenie z serwerem VPN i uruchom klienta VPN.

  • Ustaw parametry połączenia, wywołując setParameters().

  • Powiadom o stanie połączenia jako "connected", wywołując notifyConnectionStateChanged().

  • Jeśli poprzednie kroki zostaną wykonane bez błędów, zostanie utworzony wirtualny tunel do stosu sieciowego ChromeOS. Pakiety IP można wysyłać przez tunel, wywołując sendPacket(), a wszystkie pakiety pochodzące z urządzenia z ChromeOS będą odbierane za pomocą procedury obsługi zdarzeń onPacketReceived.

  • Gdy użytkownik rozłączy się z konfiguracją sieci VPN, zostanie wywołane zdarzenie onPlatformMessage z komunikatem "disconnected".

  • Jeśli konfiguracja sieci VPN nie jest już potrzebna, można ją usunąć, wywołując funkcję destroyConfig().

Typy

Parameters

Właściwości

  • adres

    ciąg znaków

    Adres IP interfejsu VPN w notacji CIDR. Obecnie obsługiwany jest tylko tryb IPv4.

  • broadcastAddress

    string opcjonalny

    Adres rozgłoszeniowy interfejsu VPN. (domyślnie: wywnioskowany na podstawie adresu IP i maski)

  • dnsServers

    string[]

    Lista adresów IP serwerów DNS.

  • domainSearch

    string[] opcjonalne

    Lista domen wyszukiwania. (domyślnie: brak domeny wyszukiwania)

  • exclusionList

    string[]

    Wyklucz z tunelu ruch sieciowy do listy bloków adresów IP w notacji CIDR. Można go używać do pomijania ruchu do i z serwera VPN. Gdy do miejsca docelowego pasuje wiele reguł, wygrywa reguła z najdłuższym pasującym prefiksem. Wpisy odpowiadające temu samemu blokowi CIDR są traktowane jako duplikaty. Takie duplikaty na połączonej liście (exclusionList + inclusionList) są usuwane, ale nie wiadomo, który z nich zostanie usunięty.

  • inclusionList

    string[]

    Dodaj ruch sieciowy do listy bloków adresów IP w notacji CIDR do tunelu. Ten parametr może służyć do konfigurowania tunelu dzielonego. Domyślnie do tunelu nie jest kierowany żaden ruch. Dodanie do tej listy wpisu „0.0.0.0/0” spowoduje przekierowanie całego ruchu użytkowników do tunelu. Gdy do miejsca docelowego pasuje wiele reguł, wygrywa reguła z najdłuższym pasującym prefiksem. Wpisy odpowiadające temu samemu blokowi CIDR są traktowane jako duplikaty. Takie duplikaty na połączonej liście (exclusionList + inclusionList) są usuwane, ale nie wiadomo, który z nich zostanie usunięty.

  • mtu

    string opcjonalny

    Ustawienie MTU dla interfejsu VPN. (domyślnie: 1500 bajtów)

  • połączyć ponownie,

    string opcjonalny

    Chrome 51 lub nowsza

    Określa, czy rozszerzenie VPN implementuje automatyczne ponowne łączenie.

    Jeśli wartość jest prawdziwa, do sygnalizowania odpowiednich zdarzeń będą używane komunikaty platform linkDown, linkUp, linkChanged, suspendresume. Jeśli wartość to fałsz, system wymusi rozłączenie sieci VPN w przypadku zmiany topologii sieci, a użytkownik będzie musiał ponownie połączyć się z siecią ręcznie. (domyślnie: false)

    Ta właściwość jest nowa w Chrome 51. W starszych wersjach będzie generować wyjątek. Instrukcji try/catch można użyć do warunkowego włączania funkcji na podstawie obsługi przeglądarki.

PlatformMessage

Wyliczenie jest używane przez platformę do powiadamiania klienta o stanie sesji VPN.

Typ wyliczeniowy

„connected”
Oznacza, że konfiguracja sieci VPN została połączona.

„disconnected”
Oznacza, że konfiguracja sieci VPN została rozłączona.

„error”
Wskazuje, że w połączeniu VPN wystąpił błąd, np. przekroczenie limitu czasu. Opis błędu jest podawany jako argument błędu w funkcji onPlatformMessage.

„linkDown”
Oznacza, że domyślne fizyczne połączenie sieciowe jest niedostępne.

„linkUp”
Wskazuje, że domyślne fizyczne połączenie sieciowe zostało przywrócone.

„linkChanged”
Wskazuje, że domyślne połączenie z siecią fizyczną uległo zmianie, np. z Wi-Fi na sieć komórkową.

„suspend”
Oznacza, że system operacyjny przygotowuje się do wstrzymania, więc sieć VPN powinna przerwać połączenie. Nie ma gwarancji, że rozszerzenie otrzyma to zdarzenie przed zawieszeniem.

„resume”
Oznacza, że system operacyjny został wznowiony, a użytkownik ponownie się zalogował, więc sieć VPN powinna spróbować się połączyć.

UIEvent

Wyliczenie jest używane przez platformę do wskazywania zdarzenia, które wywołało onUIEvent.

Typ wyliczeniowy

„showAddDialog”
Wysyła do klienta VPN prośbę o wyświetlenie użytkownikowi okna dialogowego dodawania konfiguracji.

„showConfigureDialog”
Wysyła do klienta VPN żądanie wyświetlenia użytkownikowi okna dialogowego ustawień konfiguracji.

VpnConnectionState

Wyliczenie jest używane przez klienta VPN do informowania platformy o jego bieżącym stanie. Dzięki temu możesz przekazywać użytkownikom istotne wiadomości.

Typ wyliczeniowy

„connected”
Określa, że połączenie VPN zostało nawiązane.

„failure”
Określa, że połączenie VPN nie powiodło się.

Metody

createConfig()

chrome.vpnProvider.createConfig(
  name: string,
)
: Promise<string>

Tworzy nową konfigurację VPN, która jest zachowywana w wielu sesjach logowania użytkownika.

Parametry

  • nazwa

    ciąg znaków

    Nazwa konfiguracji sieci VPN.

Zwroty

  • Promise<string>

    Chrome w wersji 96 lub nowszej

destroyConfig()

chrome.vpnProvider.destroyConfig(
  id: string,
)
: Promise<void>

Usuwa konfigurację sieci VPN utworzoną przez rozszerzenie.

Parametry

  • id

    ciąg znaków

    Identyfikator konfiguracji sieci VPN do usunięcia.

Zwroty

  • Promise<void>

    Chrome w wersji 96 lub nowszej

notifyConnectionStateChanged()

chrome.vpnProvider.notifyConnectionStateChanged(
  state: VpnConnectionState,
)
: Promise<void>

Informuje platformę o stanie sesji VPN. Ta operacja zakończy się powodzeniem tylko wtedy, gdy sesja VPN należy do rozszerzenia.

Parametry

Zwroty

  • Promise<void>

    Chrome w wersji 96 lub nowszej

sendPacket()

chrome.vpnProvider.sendPacket(
  data: ArrayBuffer,
)
: Promise<void>

Wysyła pakiet IP przez tunel utworzony na potrzeby sesji VPN. Ta operacja zakończy się powodzeniem tylko wtedy, gdy sesja VPN należy do rozszerzenia.

Parametry

  • dane

    ArrayBuffer

    Pakiet IP, który ma zostać wysłany na platformę.

Zwroty

  • Promise<void>

    Chrome w wersji 96 lub nowszej

setParameters()

chrome.vpnProvider.setParameters(
  parameters: Parameters,
)
: Promise<void>

Ustawia parametry sesji VPN. Tę funkcję należy wywołać natychmiast po otrzymaniu z platformy wartości "connected". Ta operacja zakończy się powodzeniem tylko wtedy, gdy sesja VPN należy do rozszerzenia.

Parametry

Zwroty

  • Promise<void>

    Chrome w wersji 96 lub nowszej

Wydarzenia

onConfigCreated

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

Wywoływane, gdy platforma tworzy konfigurację rozszerzenia.

Parametry

  • callback

    funkcja

    Parametr callback wygląda tak:

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

    • id

      ciąg znaków

    • nazwa

      ciąg znaków

    • dane

      obiekt

onConfigRemoved

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

Wywoływane, gdy platforma usunie konfigurację utworzoną przez rozszerzenie.

Parametry

  • callback

    funkcja

    Parametr callback wygląda tak:

    (id: string) => void

    • id

      ciąg znaków

onPacketReceived

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

Wywoływane, gdy pakiet IP jest odbierany przez tunel w sesji VPN należącej do rozszerzenia.

Parametry

  • callback

    funkcja

    Parametr callback wygląda tak:

    (data: ArrayBuffer) => void

    • dane

      ArrayBuffer

onPlatformMessage

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

Wywoływane, gdy platforma wyśle wiadomość dotyczącą konfiguracji sieci VPN należącej do rozszerzenia.

Parametry

  • callback

    funkcja

    Parametr callback wygląda tak:

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

onUIEvent

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

Wywoływane, gdy w rozszerzeniu wystąpi zdarzenie interfejsu. Zdarzenia interfejsu to sygnały z platformy, które informują aplikację, że użytkownikowi należy wyświetlić okno dialogowe interfejsu.

Parametry

  • callback

    funkcja

    Parametr callback wygląda tak:

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

    • event
    • id

      string opcjonalny