Няма описание

afrokick 8f3cdaec75 add info about account on docker hub преди 5 години
.github 279d43f49b Create dockerimage.yml преди 5 години
bin dd0b60416e ref преди 6 години
dist a956168f55 fix issue with expire messages преди 5 години
src a956168f55 fix issue with expire messages преди 5 години
test f2bb45b926 fix test преди 5 години
.eslintignore 42a626629b add eslint for ts преди 6 години
.eslintrc.json c4f04b2ff8 add tests for WebSocketServer преди 5 години
.gitignore dd0b60416e ref преди 6 години
.gitpod.yml 8c48d6092a Update .gitpod.yml преди 5 години
.travis.yml 1e09fcfb64 ref преди 6 години
Dockerfile 2ee176e690 fix Dockerfile преди 5 години
LICENSE b8dbd1f249 license and updated package json преди 12 години
README.md 8f3cdaec75 add info about account on docker hub преди 5 години
app.json bd101ab44f enable "Deploy to Heroku" Button преди 10 години
changelog.md 5e8d824ee4 fix npm audit преди 5 години
package-lock.json 5e8d824ee4 fix npm audit преди 5 години
package.json f8720f3ee3 fix main field in package.json преди 5 години
tsconfig.json 7c23ed8351 fix warnings преди 5 години

README.md

Build Status npm version Downloads Docker Image Size (latest semver)

PeerServer: A server for PeerJS

PeerServer helps broker connections between PeerJS clients. Data is not proxied through the server.

Run your own server on Gitpod!

Open in Gitpod

https://peerjs.com

Run PeerServer

  1. Install PeerServer from npm or github:

NPM

npm install peer

github

git clone https://github.com/peers/peerjs-server.git#master
npm install
  1. Run the server:

    $> peerjs --port 9000 --key peerjs --path /myapp
    

Or, create a custom server:

const { PeerServer } = require('peer');
const server = PeerServer({port: 9000, path: '/myapp'});
  1. Check that server works: open browser with http://localhost:9000/myapp It should returns JSON with name, description and website fields.

Connecting to the server from PeerJS:

<script>
    const peer = new Peer('someid', {host: 'localhost', port: 9000, path: '/myapp'});
</script>

Using HTTPS: Simply pass in PEM-encoded certificate and key.

const fs = require('fs');
const { PeerServer } = require('peer');

const server = PeerServer({
  port: 9000,
  ssl: {
    key: fs.readFileSync('/path/to/your/ssl/key/here.key'),
    cert: fs.readFileSync('/path/to/your/ssl/certificate/here.crt')
  }
});

Running PeerServer behind a reverse proxy

Make sure to set the proxied option, otherwise IP based limiting will fail. The option is passed verbatim to the expressjs trust proxy setting if it is truthy.

const { PeerServer } = require('peer');
const server = PeerServer({port: 9000, path: '/myapp', proxied: true});

Combining with existing express app

const express = require('express');
const app = express();
const { ExpressPeerServer } = require('peer');

app.get('/', (req, res, next) => { res.send('Hello world!'); });

// =======

const server = app.listen(9000);

const options = {
    debug: true,
    path: '/peerjs'
}

const peerserver = ExpressPeerServer(server, options);

app.use(options.path, peerserver);

// == OR ==

const server = require('http').createServer(app);
const peerserver = ExpressPeerServer(server, options);

app.use(options.path, peerserver);

server.listen(9000);

// ========

Events

The 'connection' event is emitted when a peer connects to the server.

peerserver.on('connection', (client) => { ... });

The 'disconnect' event is emitted when a peer disconnects from the server or when the peer can no longer be reached.

peerserver.on('disconnect', (client) => { ... });

Running tests

npm test

Docker

We have 'ready to use' images on docker hub: https://hub.docker.com/r/peerjs/peerjs-server

To run the latest image:

docker run -p 9000:9000 -d peerjs/peerjs-server

You can build a new image simply by calling:

docker build -t myimage https://github.com/peers/peerjs-server.git

To run the image execute this:

docker run -p 9000:9000 -d myimage

This will start a peerjs server on port 9000 exposed on port 9000 with key peerjs on path /myapp.

Open browser with http://localhost:9000/myapp It should returns JSON with name, description and website fields.

Problems?

Discuss PeerJS on our Telegram chat: https://t.me/joinchat/ENhPuhTvhm8WlIxTjQf7Og

Please post any bugs as a Github issue.