Une couche réseau abstraite sur plusieurs transports, indépendante du client/serveur avec prise en charge d'E2EE
Il s'agit d'un travail en cours et l'API est susceptible de changer.
AnySocket.Packer
)/dist/anysocket.browser.js
)** Le transport http est expérimental
Info : les arguments et réponses binaires RPC sont automatiquement compressés/décompressés ( AnySocket.Packer.pack
/ AnySocket.Packer.unpack
).
Voir les benchmarks
npm install -- save anysocket
ou
< script src =" /dist/anysocket.browser.js " > </ script >
ou (si vous utilisez AnySocketHTTP)
< script src =" @anysocket " > </ script >
L'exemple suivant démarre un serveur Websocket sur le port 3000.
const AnySocket = require ( "anysocket" ) ;
const server = new AnySocket ( ) ;
const PORT = 3000 ;
server . listen ( "ws" , PORT )
. then ( ( ) => {
console . log ( "Listening on port:" , PORT ) ;
} )
. catch ( ( err ) => {
console . error ( "Failed to start server:" , err ) ;
} ) ;
server . on ( "connected" , async ( peer ) => {
console . log ( "Connected" , peer . id ) ;
console . log ( await peer . getSyncedTime ( ) ) // { time: 1674671482107, rtt: 2, offset: 0 }
peer . send ( {
hello : "world"
} ) ;
} ) ;
server . on ( "message" , ( packet ) => {
console . log ( "From:" , packet . peer . id , "Message:" , packet . msg ) ;
} ) ;
server . on ( "disconnected" , ( peer , reason ) => {
console . log ( "Disconnected" , peer . id , "Reason:" , reason ) ;
} ) ;
L'exemple suivant se connecte à un websocket sur le port 3000
const AnySocket = require ( "anysocket" ) ;
const client = new AnySocket ( ) ;
const PORT = 3000 ;
client . connect ( "ws" , "127.0.0.1" , PORT )
. then ( ( ) => {
console . log ( "Connected to server" ) ;
} )
. catch ( ( err ) => {
console . error ( "Failed to connect to server:" , err ) ;
} ) ;
// after negotiating the AUTH packet, it will trigger the connect event
client . on ( "connected" , async ( peer ) => {
console . log ( "Connected" , peer . id ) ;
console . log ( await peer . getSyncedTime ( ) ) // { time: 1674671482107, rtt: 2, offset: 0 }
peer . send ( {
hello : "world"
} ) ;
} ) ;
client . on ( "message" , ( packet ) => {
console . log ( "From:" , packet . peer . id , "Message:" , packet . msg ) ;
} ) ;
client . on ( "disconnected" , ( peer , reason ) => {
console . log ( "Disconnected" , peer . id , "Reason:" , reason ) ;
} ) ;
Plus d'informations dans le dossier examples
.
Voir le dossier documentation et exemples
* cela nécessitera un changement dans le protocole, car celui-ci suppose que les paquets sont envoyés à l'aide d'une connexion fiable et ordonnée.
MIT