chrome.sockets.tcpServer

Descripción

Usa la API de chrome.sockets.tcpServer para crear aplicaciones de servidor con conexiones TCP. Esta API reemplaza la funcionalidad de TCP que se encontraba antes en la API de chrome.socket.

Manifest

Para usar esta API, se deben declarar las siguientes claves en el manifiesto.

"sockets"

Tipos

AcceptErrorInfo

Propiedades

  • resultCode

    número

    El código de resultado que muestra la llamada de red subyacente.

  • socketId

    número

    Es el identificador de socket de servidor.

AcceptInfo

Propiedades

  • clientSocketId

    número

    El identificador de socket de cliente, es decir, el identificador de socket de la conexión recién establecida. Este identificador de socket solo debe usarse con funciones del espacio de nombres chrome.sockets.tcp. Ten en cuenta que el socket del cliente está pausado en un principio y la aplicación debe reactivarlo explícitamente para comenzar a recibir datos.

  • socketId

    número

    Es el identificador de socket de servidor.

CreateInfo

Propiedades

  • socketId

    número

    El ID del socket de servidor recién creado. Ten en cuenta que los IDs de socket creados a partir de esta API no son compatibles con los de otras APIs, como la API de [socket](../socket/) obsoleta.

SocketInfo

Propiedades

  • localAddress

    cadena opcional

    Si el socket está escuchando, contiene su dirección IPv4/6 local.

  • localPort

    número opcional

    Si el socket está escuchando, contiene su puerto local.

  • name

    cadena opcional

    Es la cadena definida por la aplicación asociada con el socket.

  • detenido

    boolean

    Marca que indica si las solicitudes de conexión en un socket de escucha se envían a través del evento onAccept o se agregan a una cola en el trabajo pendiente de la cola de escucha. Consulta los setPaused. El valor predeterminado es "false".

  • persistentes

    boolean

    Marca que indica si el socket permanece abierto cuando se descarga la página de eventos de la aplicación (consulta SocketProperties.persistent). El valor predeterminado es "false".

  • socketId

    número

    Es el identificador del socket.

SocketProperties

Propiedades

  • name

    cadena opcional

    Una cadena definida por la aplicación asociada con el socket.

  • persistentes

    booleano opcional

    Marca que indica si el socket permanece abierto cuando se descarga la página del evento de la aplicación (consulta Administrar el ciclo de vida de la app). El valor predeterminado es "false". Cuando la aplicación se carga, cualquier socket que se abrió antes con Persistent=true se puede recuperar con getSockets.

Métodos

close()

Promesa
chrome.sockets.tcpServer.close(
  socketId: number,
  callback?: function,
)

Desconecta y destruye el socket. Cada socket creado debe cerrarse después de su uso. El ID del socket deja de ser válido apenas se llama a la función. Sin embargo, se garantiza que el socket solo se cerrará cuando se invoque la devolución de llamada.

Parámetros

  • socketId

    número

    Es el identificador del socket.

  • callback

    Función opcional

    El parámetro callback se ve de la siguiente manera:

    ()=>void

Devuelve

  • Promise<void>

    Chrome 121 y versiones posteriores

    Las promesas solo son compatibles con Manifest V3 y versiones posteriores; otras plataformas deben usar devoluciones de llamada.

create()

Promesa
chrome.sockets.tcpServer.create(
  properties?: SocketProperties,
  callback?: function,
)

Crea un socket de servidor TCP.

Parámetros

  • properties

    Las propiedades del socket (opcional).

  • callback

    Función opcional

    El parámetro callback se ve de la siguiente manera:

    (createInfo: CreateInfo)=>void

    • createInfo

      El resultado de la creación del socket.

Devuelve

  • Promise<CreateInfo>

    Chrome 121 y versiones posteriores

    Las promesas solo son compatibles con Manifest V3 y versiones posteriores; otras plataformas deben usar devoluciones de llamada.

disconnect()

Promesa
chrome.sockets.tcpServer.disconnect(
  socketId: number,
  callback?: function,
)

Desconecta el socket de escucha, es decir, deja de aceptar conexiones nuevas y libera la dirección o el puerto al que está vinculado el socket. El identificador de socket sigue siendo válido, p.ej., se puede usar con listen para aceptar conexiones en un puerto y una dirección nuevos.

Parámetros

  • socketId

    número

    Es el identificador del socket.

  • callback

    Función opcional

    El parámetro callback se ve de la siguiente manera:

    ()=>void

Devuelve

  • Promise<void>

    Chrome 121 y versiones posteriores

    Las promesas solo son compatibles con Manifest V3 y versiones posteriores; otras plataformas deben usar devoluciones de llamada.

getInfo()

Promesa
chrome.sockets.tcpServer.getInfo(
  socketId: number,
  callback?: function,
)

Recupera el estado del socket determinado.

Parámetros

  • socketId

    número

    Es el identificador del socket.

  • callback

    Función opcional

    El parámetro callback se ve de la siguiente manera:

    (socketInfo: SocketInfo)=>void

    • socketInfo

      Objeto que contiene la información del socket.

Devuelve

  • Promise<SocketInfo>

    Chrome 121 y versiones posteriores

    Las promesas solo son compatibles con Manifest V3 y versiones posteriores; otras plataformas deben usar devoluciones de llamada.

getSockets()

Promesa
chrome.sockets.tcpServer.getSockets(
  callback?: function,
)

Recupera la lista de sockets actualmente abiertos que son propiedad de la aplicación.

Parámetros

  • callback

    Función opcional

    El parámetro callback se ve de la siguiente manera:

    (socketInfos: SocketInfo[])=>void

    • socketInfos

      Arreglo de objetos que contiene información del socket.

Devuelve

  • Promise<SocketInfo[]>

    Chrome 121 y versiones posteriores

    Las promesas solo son compatibles con Manifest V3 y versiones posteriores; otras plataformas deben usar devoluciones de llamada.

listen()

chrome.sockets.tcpServer.listen(
  socketId: number,
  address: string,
  port: number,
  backlog?: number,
  callback: function,
)

Detecta conexiones en la dirección y el puerto especificados. Si el puerto o la dirección están en uso, la devolución de llamada indica un error.

Parámetros

  • socketId

    número

    Es el identificador del socket.

  • de la página web.

    cadena

    Es la dirección de la máquina local.

  • puerto

    número

    Es el puerto de la máquina local. Cuando se establece en 0, se elige un puerto libre de forma dinámica. El puerto asignado de forma dinámica se puede encontrar llamando a getInfo.

  • trabajo pendiente

    número opcional

    Longitud de la cola de escucha del socket. El valor predeterminado depende del sistema operativo (SOMAXCONN), que garantiza una longitud de cola razonable para la mayoría de las aplicaciones.

  • callback

    la función

    El parámetro callback se ve de la siguiente manera:

    (result: number)=>void

    • resultado

      número

      El código de resultado que muestra la llamada de red subyacente. Un valor negativo indica un error.

setPaused()

Promesa
chrome.sockets.tcpServer.setPaused(
  socketId: number,
  paused: boolean,
  callback?: function,
)

Habilita o inhabilita que un socket de escucha acepte conexiones nuevas. Cuando se pausa, un socket de escucha acepta conexiones nuevas hasta que su trabajo pendiente (consulta la función listen) está completo y, luego, rechaza solicitudes de conexión adicionales. Los eventos onAccept solo se generan cuando el socket se reanuda.

Parámetros

  • socketId

    número

  • detenido

    boolean

  • callback

    Función opcional

    El parámetro callback se ve de la siguiente manera:

    ()=>void

Devuelve

  • Promise<void>

    Chrome 121 y versiones posteriores

    Las promesas solo son compatibles con Manifest V3 y versiones posteriores; otras plataformas deben usar devoluciones de llamada.

update()

Promesa
chrome.sockets.tcpServer.update(
  socketId: number,
  properties: SocketProperties,
  callback?: function,
)

Actualiza las propiedades del socket.

Parámetros

  • socketId

    número

    Es el identificador del socket.

  • properties

    Las propiedades que se actualizarán.

  • callback

    Función opcional

    El parámetro callback se ve de la siguiente manera:

    ()=>void

Devuelve

  • Promise<void>

    Chrome 121 y versiones posteriores

    Las promesas solo son compatibles con Manifest V3 y versiones posteriores; otras plataformas deben usar devoluciones de llamada.

Eventos

onAccept

chrome.sockets.tcpServer.onAccept.addListener(
  callback: function,
)

Evento que se generó cuando se estableció una conexión con el socket del servidor.

Parámetros

  • callback

    la función

    El parámetro callback se ve de la siguiente manera:

    (info: AcceptInfo)=>void

onAcceptError

chrome.sockets.tcpServer.onAcceptError.addListener(
  callback: function,
)

Evento que se generó cuando se produjo un error de red mientras el entorno de ejecución estaba esperando nuevas conexiones en la dirección del socket y el puerto. Una vez que se genera este evento, el socket se establece en paused y no se generan más eventos onAccept para este socket hasta que se reanude.

Parámetros