|
5 years ago | |
---|---|---|
.github | 5 years ago | |
bin | 5 years ago | |
dist | 5 years ago | |
src | 5 years ago | |
test | 5 years ago | |
.eslintignore | 5 years ago | |
.eslintrc.json | 5 years ago | |
.gitignore | 5 years ago | |
.gitpod.yml | 5 years ago | |
.travis.yml | 6 years ago | |
Dockerfile | 5 years ago | |
LICENSE | 12 years ago | |
README.md | 5 years ago | |
app.json | 10 years ago | |
changelog.md | 5 years ago | |
package-lock.json | 5 years ago | |
package.json | 5 years ago | |
tsconfig.json | 5 years ago |
PeerServer helps broker connections between PeerJS clients. Data is not proxied through the server.
Run your own server on Gitpod!
npm install peer
git clone https://github.com/peers/peerjs-server.git#master
npm install
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'});
<script>
const peer = new Peer('someid', {host: 'localhost', port: 9000, path: '/myapp'});
</script>
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')
}
});
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});
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);
// ========
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) => { ... });
npm test
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.
Discuss PeerJS on our Telegram chat: https://t.me/joinchat/ENhPuhTvhm8WlIxTjQf7Og
Please post any bugs as a Github issue.