mirror of
https://github.com/amark/gun.git
synced 2025-09-13 13:00:11 +00:00

* Thank you Murage Martin @murageyun for donating!!! * Fix opt.s3.fakes3 parsing issue (#1318) * Fix opt.s3.fakes3 parsing issue * Fix second typo within if block * Support variable number of auth retry attempts through opt.retries (#1325) Maintain default to 9 to ensure backwards compatibility * Thanks Jason Stallings @octalmage !!! * Remove unused imports (#1337) * Update README.md * yay format change * encode objects * WS ws.path fix (#1343) * Update wire.js * Update wire.js * Update wire.js * add one click deploy to readme (#1342) * update src/index (#1254) * update src/index * update * src/index fix * added src/core * is ??? this a MVP of book & rad ???? thanks to @rogowski * book & rad APIs stabilizing * RAD & Book promoted! + buggy example: test/rad/book.html * bump path * cleaned up Book results & sorting & caching * sea blobs! (#1353) * sea blobs! * and null origins * null fix * null check is last * add a way to select stats file from url (#1351) * react-native detection, and load needed shims (#1349) * react-native detection * added lib mobile * changed back to gun. for another solution * have unbuild function wrap to prevent scope leaks & allow RETURN hehehe so I can reject @bmatusiak 's lS change O:) O:) I love you you're a hero! later with @bmatusiak check sea.then for '../gun.js' vs '../' vs ... note: src/index -> core.js TODO: something about WebRTC candidates hitting ack decrement limits? * quick-fix (#1355) * Fix SEA certificate verification, allow multiple pubs (#1358) * Create SECURITY.md (#1364) * ... works (#1357) * Loading fix (#1356) * does this load better * check window.Gun too in rfs * update SECURITY.md file and change the versions to 0.2020.x (#1365) * webrtc accept getUserMedia streams as peer * Check atom exists in graph when deciding to read from disk (#1371) * fix: ERROR: Radisk needs `store.put` interface (#1374) * Update STUN servers (#1381) Commented out sipgate.net STUN server. Added Cloudflare STUN server. * universal notification system --------- Co-authored-by: ritchia1 <andrew.ritchie@estimateone.com> Co-authored-by: Anton <dev@atjn.dk> Co-authored-by: Bradley Matusiak <bmatusiak@gmail.com> Co-authored-by: Jay Byoun <jay8061@pm.me> Co-authored-by: mimiza <dev@mimiza.com> Co-authored-by: Simardeep Singh <1003simar@gmail.com> Co-authored-by: Malcolm Blaney <mblaney@gmail.com> Co-authored-by: Andreas Heissenberger <andreas@heissenberger.at> Co-authored-by: carlin978 <120719190+carlin978@users.noreply.github.com>
135 lines
5.4 KiB
JavaScript
135 lines
5.4 KiB
JavaScript
;(function(){
|
|
var GUN = (typeof window !== "undefined")? window.Gun : require('../gun');
|
|
GUN.on('opt', function(root){
|
|
this.to.next(root);
|
|
var opt = root.opt;
|
|
if(root.once){ return }
|
|
if(!GUN.Mesh){ return }
|
|
if(false === opt.RTCPeerConnection){ return }
|
|
|
|
var env;
|
|
if(typeof window !== "undefined"){ env = window }
|
|
if(typeof global !== "undefined"){ env = global }
|
|
env = env || {};
|
|
|
|
var rtcpc = opt.RTCPeerConnection || env.RTCPeerConnection || env.webkitRTCPeerConnection || env.mozRTCPeerConnection;
|
|
var rtcsd = opt.RTCSessionDescription || env.RTCSessionDescription || env.webkitRTCSessionDescription || env.mozRTCSessionDescription;
|
|
var rtcic = opt.RTCIceCandidate || env.RTCIceCandidate || env.webkitRTCIceCandidate || env.mozRTCIceCandidate;
|
|
if(!rtcpc || !rtcsd || !rtcic){ return }
|
|
opt.RTCPeerConnection = rtcpc;
|
|
opt.RTCSessionDescription = rtcsd;
|
|
opt.RTCIceCandidate = rtcic;
|
|
opt.rtc = opt.rtc || {'iceServers': [
|
|
{urls: 'stun:stun.l.google.com:19302'},
|
|
{urls: 'stun:stun.cloudflare.com:3478'}/*,
|
|
{urls: "stun:stun.sipgate.net:3478"},
|
|
{urls: "stun:stun.stunprotocol.org"},
|
|
{urls: "stun:stun.sipgate.net:10000"},
|
|
{urls: "stun:217.10.68.152:10000"},
|
|
{urls: 'stun:stun.services.mozilla.com'}*/
|
|
]};
|
|
// TODO: Select the most appropriate stuns.
|
|
// FIXME: Find the wire throwing ICE Failed
|
|
// The above change corrects at least firefox RTC Peer handler where it **throws** on over 6 ice servers, and updates url: to urls: removing deprecation warning
|
|
opt.rtc.dataChannel = opt.rtc.dataChannel || {ordered: false, maxRetransmits: 2};
|
|
opt.rtc.sdp = opt.rtc.sdp || {mandatory: {OfferToReceiveAudio: false, OfferToReceiveVideo: false}};
|
|
opt.rtc.max = opt.rtc.max || 55; // is this a magic number? // For Future WebRTC notes: Chrome 500 max limit, however 256 likely - FF "none", webtorrent does 55 per torrent.
|
|
opt.rtc.room = opt.rtc.room || GUN.window && (location.hash.slice(1) || location.pathname.slice(1));
|
|
opt.announce = function(to){
|
|
opt.rtc.start = +new Date; // handle room logic:
|
|
root.$.get('/RTC/'+opt.rtc.room+'<?99').get('+').put(opt.pid, function(ack){
|
|
if(!ack.ok || !ack.ok.rtc){ return }
|
|
plan(ack);
|
|
}, {acks: opt.rtc.max}).on(function(last,key, msg){
|
|
if(last === opt.pid || opt.rtc.start > msg.put['>']){ return }
|
|
plan({'#': ''+msg['#'], ok: {rtc: {id: last}}});
|
|
});
|
|
};
|
|
|
|
var mesh = opt.mesh = opt.mesh || GUN.Mesh(root), wired = mesh.wire;
|
|
mesh.hear['rtc'] = plan;
|
|
mesh.wire = function(media){ try{ wired && wired(media);
|
|
if(!(media instanceof MediaStream)){ return }
|
|
(open.media = open.media||{})[media.id] = media;
|
|
for(var p in opt.peers){ p = opt.peers[p]||'';
|
|
p.addTrack && media.getTracks().forEach(track => {
|
|
p.addTrack(track, media);
|
|
});
|
|
p.createOffer && p.createOffer(function(offer){
|
|
p.setLocalDescription(offer);
|
|
mesh.say({'#': root.ask(plan), dam: 'rtc', ok: {rtc: {offer: offer, id: opt.pid}}}, p);
|
|
}, function(){}, opt.rtc.sdp);
|
|
}
|
|
} catch(e){console.log(e)} }
|
|
root.on('create', function(at){
|
|
this.to.next(at);
|
|
setTimeout(opt.announce, 1);
|
|
});
|
|
|
|
function plan(msg){
|
|
if(!msg.ok){ return }
|
|
var rtc = msg.ok.rtc, peer, tmp;
|
|
if(!rtc || !rtc.id || rtc.id === opt.pid){ return }
|
|
peer = open(msg, rtc);
|
|
if(tmp = rtc.candidate){
|
|
return peer.addIceCandidate(new opt.RTCIceCandidate(tmp));
|
|
}
|
|
if(tmp = rtc.answer){
|
|
tmp.sdp = tmp.sdp.replace(/\\r\\n/g, '\r\n');
|
|
return peer.setRemoteDescription(peer.remoteSet = new opt.RTCSessionDescription(tmp));
|
|
}
|
|
if(tmp = rtc.offer){
|
|
rtc.offer.sdp = rtc.offer.sdp.replace(/\\r\\n/g, '\r\n');
|
|
peer.setRemoteDescription(new opt.RTCSessionDescription(tmp));
|
|
return peer.createAnswer(function(answer){
|
|
peer.setLocalDescription(answer);
|
|
root.on('out', {'@': msg['#'], ok: {rtc: {answer: answer, id: opt.pid}}});
|
|
}, function(){}, opt.rtc.sdp);
|
|
}
|
|
}
|
|
function open(msg, rtc, peer){
|
|
if(peer = opt.peers[rtc.id] || open[rtc.id]){ return peer }
|
|
(peer = new opt.RTCPeerConnection(opt.rtc)).id = rtc.id;
|
|
var wire = peer.wire = peer.createDataChannel('dc', opt.rtc.dataChannel);
|
|
function rtceve(eve){ eve.peer = peer; gun.on('rtc', eve) }
|
|
peer.$ = gun;
|
|
open[rtc.id] = peer;
|
|
peer.ontrack = rtceve;
|
|
peer.onremovetrack = rtceve;
|
|
peer.onconnectionstatechange = rtceve;
|
|
wire.to = setTimeout(function(){delete open[rtc.id]},1000*60);
|
|
wire.onclose = function(){ mesh.bye(peer) };
|
|
wire.onerror = function(err){ };
|
|
wire.onopen = function(e){
|
|
delete open[rtc.id];
|
|
mesh.hi(peer);
|
|
}
|
|
wire.onmessage = function(msg){
|
|
if(!msg){ return }
|
|
mesh.hear(msg.data || msg, peer);
|
|
};
|
|
peer.onicecandidate = function(e){ rtceve(e);
|
|
if(!e.candidate){ return }
|
|
root.on('out', {'@': (msg||'')['#'], '#': root.ask(plan), ok: {rtc: {candidate: e.candidate, id: opt.pid}}});
|
|
}
|
|
peer.ondatachannel = function(e){ rtceve(e);
|
|
var rc = e.channel;
|
|
rc.onmessage = wire.onmessage;
|
|
rc.onopen = wire.onopen;
|
|
rc.onclose = wire.onclose;
|
|
}
|
|
if(rtc.offer){ return peer }
|
|
for(var m in open.media){ m = open.media[m];
|
|
m.getTracks().forEach(track => {
|
|
peer.addTrack(track, m);
|
|
});
|
|
}
|
|
peer.createOffer(function(offer){
|
|
peer.setLocalDescription(offer);
|
|
root.on('out', {'@': (msg||'')['#'], '#': root.ask(plan), ok: {rtc: {offer: offer, id: opt.pid}}});
|
|
}, function(){}, opt.rtc.sdp);
|
|
return peer;
|
|
}
|
|
});
|
|
}());
|