Satisfactory working prototype

This commit is contained in:
Carlos 2016-10-17 16:44:33 +03:00
parent 4c050b0cab
commit 9e39231650
2 changed files with 88 additions and 44 deletions

66
cachep2p.min.js vendored
View file

@ -20334,15 +20334,21 @@ var EventEmitter = require('events').EventEmitter
var inherits = require('inherits') var inherits = require('inherits')
var link_lists = {} var link_lists = {}
var history_initialized = false var history_initialized = false
inherits(CacheP2P, EventEmitter) inherits(CacheP2P, EventEmitter)
function CacheP2P(opts){ var cached_mark
function CacheP2P(opts, callback){
if(typeof(opts)==='function'){
callback = opts
}
if(document.security_sha2){
self.security_sha1 = document.security_sha1
}
var self = this var self = this
cached_mark = opts && opts.cached_mark ? opts.cached_mark : "* ";
if (!(self instanceof CacheP2P)) return new CacheP2P(opts) if (!(self instanceof CacheP2P)) return new CacheP2P(opts)
EventEmitter.call(self) EventEmitter.call(self)
self.emit("message", "Initializing CacheP2P...") self.emit("message", "Initializing CacheP2P...")
@ -20359,6 +20365,9 @@ function CacheP2P(opts){
[ 'wss://tracker.btorrent.xyz' ], [ 'wss://tracker.btorrent.xyz' ],
[ 'wss://tracker.openwebtorrent.com' ], [ 'wss://tracker.openwebtorrent.com' ],
] ]
if(opts && opts.announceList){
self.announceList = opts.announceList
}
function onTorrent (torrent) { function onTorrent (torrent) {
torrent.files.forEach(function (file) { torrent.files.forEach(function (file) {
@ -20373,7 +20382,10 @@ function CacheP2P(opts){
link_lists[got_page.url].title = got_page.title link_lists[got_page.url].title = got_page.title
link_lists[got_page.url].url = got_page.url link_lists[got_page.url].url = got_page.url
var link_to_page = link_lists[got_page.url].orig var link_to_page = link_lists[got_page.url].orig
self.emit('success', "Got cache for '" +link_to_page.text+"', it will not be requested to the Server when clicked on it.") self.emit('alert', "Checking sha1 of content received: "+sha.sync(got_page.page)+"...")
self.emit('success', "Got this site's '" +link_to_page.text+"' from another Peer (sha1: "+got_page.page_hash+" ✔)")
self.emit('success', "The server will not be used when '"+link_to_page.text+"' is clicked.")
link_to_page.onclick = function(event){ link_to_page.onclick = function(event){
event.preventDefault(); event.preventDefault();
@ -20381,24 +20393,34 @@ function CacheP2P(opts){
window.history.pushState({page: document.documentElement.innerHTML, title: document.title},"", window.location.href); window.history.pushState({page: document.documentElement.innerHTML, title: document.title},"", window.location.href);
} }
document.documentElement.innerHTML = link_lists[event.target.href].content document.documentElement.innerHTML = link_lists[event.target.href].content
document.title = '* '+link_lists[event.target.href].title document.title = cached_mark+' '+link_lists[event.target.href].title
window.scrollTo(0, 0); // setTimeout(function(){
// window.scrollTo(0, 0);
// }, 10)
self.emit('cache', event)
self.emit('ready')
window.history.pushState({page: got_page.page, title: got_page.title},"", got_page.url); window.history.pushState({page: got_page.page, title: got_page.title},"", got_page.url);
} }
window.onpopstate = function(to) { window.onpopstate = function(to) {
document.documentElement.innerHTML = to.state.page document.documentElement.innerHTML = to.state.page
document.title = '* '+to.state.title document.title = cached_mark+" "+to.state.title
window.scrollTo(0, 0); window.scrollTo(0, 0);
self.emit('onpopstate', to)
var this_page_links = document.getElementsByTagName('a') var this_page_links = document.getElementsByTagName('a')
for(var i = 0; i < this_page_links.length ; i++){ for(var i = 0; i < this_page_links.length ; i++){
if(Object.keys(link_lists).indexOf(this_page_links[i].href) > -1){ if(Object.keys(link_lists).indexOf(this_page_links[i].href) > -1){
this_page_links[i].onclick = function(event){ this_page_links[i].onclick = function(event){
event.preventDefault(); event.preventDefault();
document.documentElement.innerHTML = link_lists[event.target.href].content document.documentElement.innerHTML = link_lists[event.target.href].content
document.title = '* '+link_lists[event.target.href].title document.title = cached_mark+' '+link_lists[event.target.href].title
window.history.pushState({page: link_lists[event.target.href].content, title: link_lists[event.target.href].title},"", event.target.href); window.history.pushState({page: link_lists[event.target.href].content, title: link_lists[event.target.href].title},"", event.target.href);
setTimeout(function(){
window.scrollTo(0, 0);
}, 10)
} }
} }
} }
@ -20410,16 +20432,16 @@ function CacheP2P(opts){
setTimeout(function(){ setTimeout(function(){
var this_page_links = document.getElementsByTagName('a') var this_page_links = document.getElementsByTagName('a')
self.emit('message', "Searching this page for links *://"+document.domain + "/* to optimize.") self.emit('message', "Initializing CacheP2P, pre-fetching all links in this website... ")
for(var i = 0; i < this_page_links.length ; i++){ for(var i = 0; i < this_page_links.length ; i++){
if(this_page_links[i].href && this_page_links[i].href.length !== window.location.href.length && this_page_links[i].href.indexOf(window.location.href+'#') == -1 && this_page_links[i].href.indexOf(window.location.href) > -1){ if(this_page_links[i].href && this_page_links[i].href.length !== window.location.href.length && this_page_links[i].href.indexOf(window.location.href+'#') == -1 && this_page_links[i].href.indexOf(document.domain) > -1){
if(!link_lists[this_page_links[i].href]){ if(!link_lists[this_page_links[i].href]){
link_lists[this_page_links[i].href] = {} link_lists[this_page_links[i].href] = {}
} }
link_lists[this_page_links[i].href].orig = this_page_links[i] link_lists[this_page_links[i].href].orig = this_page_links[i]
self.emit('message', "Found '"+this_page_links[i].text + "' link and it's in the same domain, so it can be optimized with CacheP2P.") self.emit('message', "Pre-fetching '"+this_page_links[i].text + "' page from other peers browsing this website...")
self.emit('message', "Please tell a friend to open this site's "+this_page_links[i].text+" to see CacheP2P in action.") self.emit('alert', "Please tell a friend to open this site's "+this_page_links[i].text+" to see it in action.")
sha(this_page_links[i].href, function(result){ sha(this_page_links[i].href, function(result){
@ -20432,8 +20454,7 @@ function CacheP2P(opts){
self.emit('webtorrent', 'Receiving ('+bytes+' bytes)') self.emit('webtorrent', 'Receiving ('+bytes+' bytes)')
}) })
torrent.on('wire', function (wire) { torrent.on('wire', function (wire) {
console.log('wire', wire) self.emit('webtorrent', 'Peer ('+wire.remoteAddress+') connected over '+wire.type+' (Connection ID: '+wire.peerId.substr(0,10)+').')
self.emit('webtorrent', 'Peer '+wire.peerId+' ('+wire.remoteAddress+') is connected over '+wire.type+'.')
}) })
}) })
@ -20473,7 +20494,8 @@ function CacheP2P(opts){
sha(mergedPage, function (page_hash) { sha(mergedPage, function (page_hash) {
var payload = {date: new Date(), page: mergedPage, page_hash: page_hash, url: message.location_href, title: document.title} var payload = {date: new Date(), page: mergedPage, page_hash: page_hash, url: message.location_href, title: document.title}
var buffer_payload = Buffer.from(JSON.stringify(payload), 'utf8') var buffer_payload = Buffer.from(JSON.stringify(payload), 'utf8')
debug('>> url hash:', hash, 'for', message.location_href) self.emit('ready')
console.log('[CacheP2P] this page\'s security hash:',page_hash,'('+message.location_href+')')
var torrent = client.seed(buffer_payload,{forced_id: hash, announceList: self.announceList}, function(torrent){ var torrent = client.seed(buffer_payload,{forced_id: hash, announceList: self.announceList}, function(torrent){
// add_to_list(torrent, message.location_href) // add_to_list(torrent, message.location_href)
debug(torrent.magnetURI) debug(torrent.magnetURI)
@ -20481,8 +20503,8 @@ function CacheP2P(opts){
self.emit('webtorrent', 'Sending this page to peer ('+bytes+' bytes)') self.emit('webtorrent', 'Sending this page to peer ('+bytes+' bytes)')
}) })
torrent.on('wire', function (wire) { torrent.on('wire', function (wire) {
console.log('wire', wire) console.log('wire2', wire)
self.emit('webtorrent', 'Peer '+wire.peerId+' connected ('+wire.remoteAddress+') over '+wire.type+'.') self.emit('webtorrent', 'Peer ('+wire.remoteAddress+') connected over '+wire.type+' (Connection ID: '+wire.peerId.substr(0,10)+').')
}) })
// document.title = document.title // document.title = document.title
}); });
@ -20493,9 +20515,9 @@ function CacheP2P(opts){
} }
document.CacheP2P = new CacheP2P() // document.CacheP2P = new CacheP2P()
client.on('error', function(err){ // client.on('error', function(err){
document.CacheP2P.emit('webtorrent', err) // document.CacheP2P.emit('webtorrent', err)
}) // })
},{"debug":56,"events":8,"inherits":65,"safe-buffer":104,"simple-sha1":108,"webtorrent":128}]},{},[140])(140) },{"debug":56,"events":8,"inherits":65,"safe-buffer":104,"simple-sha1":108,"webtorrent":128}]},{},[140])(140)
}); });

View file

@ -10,15 +10,21 @@ var EventEmitter = require('events').EventEmitter
var inherits = require('inherits') var inherits = require('inherits')
var link_lists = {} var link_lists = {}
var history_initialized = false var history_initialized = false
inherits(CacheP2P, EventEmitter) inherits(CacheP2P, EventEmitter)
function CacheP2P(opts){ var cached_mark
function CacheP2P(opts, callback){
if(typeof(opts)==='function'){
callback = opts
}
if(document.security_sha2){
self.security_sha1 = document.security_sha1
}
var self = this var self = this
cached_mark = opts && opts.cached_mark ? opts.cached_mark : "* ";
if (!(self instanceof CacheP2P)) return new CacheP2P(opts) if (!(self instanceof CacheP2P)) return new CacheP2P(opts)
EventEmitter.call(self) EventEmitter.call(self)
self.emit("message", "Initializing CacheP2P...") self.emit("message", "Initializing CacheP2P...")
@ -35,6 +41,9 @@ function CacheP2P(opts){
[ 'wss://tracker.btorrent.xyz' ], [ 'wss://tracker.btorrent.xyz' ],
[ 'wss://tracker.openwebtorrent.com' ], [ 'wss://tracker.openwebtorrent.com' ],
] ]
if(opts && opts.announceList){
self.announceList = opts.announceList
}
function onTorrent (torrent) { function onTorrent (torrent) {
torrent.files.forEach(function (file) { torrent.files.forEach(function (file) {
@ -49,7 +58,10 @@ function CacheP2P(opts){
link_lists[got_page.url].title = got_page.title link_lists[got_page.url].title = got_page.title
link_lists[got_page.url].url = got_page.url link_lists[got_page.url].url = got_page.url
var link_to_page = link_lists[got_page.url].orig var link_to_page = link_lists[got_page.url].orig
self.emit('success', "Got cache for '" +link_to_page.text+"', it will not be requested to the Server when clicked on it.") self.emit('alert', "Checking sha1 of content received: "+sha.sync(got_page.page)+"...")
self.emit('success', "Got this site's '" +link_to_page.text+"' from another Peer (sha1: "+got_page.page_hash+" ✔)")
self.emit('success', "The server will not be used when '"+link_to_page.text+"' is clicked.")
link_to_page.onclick = function(event){ link_to_page.onclick = function(event){
event.preventDefault(); event.preventDefault();
@ -57,24 +69,34 @@ function CacheP2P(opts){
window.history.pushState({page: document.documentElement.innerHTML, title: document.title},"", window.location.href); window.history.pushState({page: document.documentElement.innerHTML, title: document.title},"", window.location.href);
} }
document.documentElement.innerHTML = link_lists[event.target.href].content document.documentElement.innerHTML = link_lists[event.target.href].content
document.title = '* '+link_lists[event.target.href].title document.title = cached_mark+' '+link_lists[event.target.href].title
window.scrollTo(0, 0); // setTimeout(function(){
// window.scrollTo(0, 0);
// }, 10)
self.emit('cache', event)
self.emit('ready')
window.history.pushState({page: got_page.page, title: got_page.title},"", got_page.url); window.history.pushState({page: got_page.page, title: got_page.title},"", got_page.url);
} }
window.onpopstate = function(to) { window.onpopstate = function(to) {
document.documentElement.innerHTML = to.state.page document.documentElement.innerHTML = to.state.page
document.title = '* '+to.state.title document.title = cached_mark+" "+to.state.title
window.scrollTo(0, 0); window.scrollTo(0, 0);
self.emit('onpopstate', to)
var this_page_links = document.getElementsByTagName('a') var this_page_links = document.getElementsByTagName('a')
for(var i = 0; i < this_page_links.length ; i++){ for(var i = 0; i < this_page_links.length ; i++){
if(Object.keys(link_lists).indexOf(this_page_links[i].href) > -1){ if(Object.keys(link_lists).indexOf(this_page_links[i].href) > -1){
this_page_links[i].onclick = function(event){ this_page_links[i].onclick = function(event){
event.preventDefault(); event.preventDefault();
document.documentElement.innerHTML = link_lists[event.target.href].content document.documentElement.innerHTML = link_lists[event.target.href].content
document.title = '* '+link_lists[event.target.href].title document.title = cached_mark+' '+link_lists[event.target.href].title
window.history.pushState({page: link_lists[event.target.href].content, title: link_lists[event.target.href].title},"", event.target.href); window.history.pushState({page: link_lists[event.target.href].content, title: link_lists[event.target.href].title},"", event.target.href);
setTimeout(function(){
window.scrollTo(0, 0);
}, 10)
} }
} }
} }
@ -86,16 +108,16 @@ function CacheP2P(opts){
setTimeout(function(){ setTimeout(function(){
var this_page_links = document.getElementsByTagName('a') var this_page_links = document.getElementsByTagName('a')
self.emit('message', "Searching this page for links *://"+document.domain + "/* to optimize.") self.emit('message', "Initializing CacheP2P, pre-fetching all links in this website... ")
for(var i = 0; i < this_page_links.length ; i++){ for(var i = 0; i < this_page_links.length ; i++){
if(this_page_links[i].href && this_page_links[i].href.length !== window.location.href.length && this_page_links[i].href.indexOf(window.location.href+'#') == -1 && this_page_links[i].href.indexOf(window.location.href) > -1){ if(this_page_links[i].href && this_page_links[i].href.length !== window.location.href.length && this_page_links[i].href.indexOf(window.location.href+'#') == -1 && this_page_links[i].href.indexOf(document.domain) > -1){
if(!link_lists[this_page_links[i].href]){ if(!link_lists[this_page_links[i].href]){
link_lists[this_page_links[i].href] = {} link_lists[this_page_links[i].href] = {}
} }
link_lists[this_page_links[i].href].orig = this_page_links[i] link_lists[this_page_links[i].href].orig = this_page_links[i]
self.emit('message', "Found '"+this_page_links[i].text + "' link and it's in the same domain, so it can be optimized with CacheP2P.") self.emit('message', "Pre-fetching '"+this_page_links[i].text + "' page from other peers browsing this website...")
self.emit('message', "Please tell a friend to open this site's "+this_page_links[i].text+" to see CacheP2P in action.") self.emit('alert', "Please tell a friend to open this site's "+this_page_links[i].text+" to see it in action.")
sha(this_page_links[i].href, function(result){ sha(this_page_links[i].href, function(result){
@ -108,8 +130,7 @@ function CacheP2P(opts){
self.emit('webtorrent', 'Receiving ('+bytes+' bytes)') self.emit('webtorrent', 'Receiving ('+bytes+' bytes)')
}) })
torrent.on('wire', function (wire) { torrent.on('wire', function (wire) {
console.log('wire', wire) self.emit('webtorrent', 'Peer ('+wire.remoteAddress+') connected over '+wire.type+' (Connection ID: '+wire.peerId.substr(0,10)+').')
self.emit('webtorrent', 'Peer '+wire.peerId+' ('+wire.remoteAddress+') is connected over '+wire.type+'.')
}) })
}) })
@ -149,7 +170,8 @@ function CacheP2P(opts){
sha(mergedPage, function (page_hash) { sha(mergedPage, function (page_hash) {
var payload = {date: new Date(), page: mergedPage, page_hash: page_hash, url: message.location_href, title: document.title} var payload = {date: new Date(), page: mergedPage, page_hash: page_hash, url: message.location_href, title: document.title}
var buffer_payload = Buffer.from(JSON.stringify(payload), 'utf8') var buffer_payload = Buffer.from(JSON.stringify(payload), 'utf8')
debug('>> url hash:', hash, 'for', message.location_href) self.emit('ready')
console.log('[CacheP2P] this page\'s security hash:',page_hash,'('+message.location_href+')')
var torrent = client.seed(buffer_payload,{forced_id: hash, announceList: self.announceList}, function(torrent){ var torrent = client.seed(buffer_payload,{forced_id: hash, announceList: self.announceList}, function(torrent){
// add_to_list(torrent, message.location_href) // add_to_list(torrent, message.location_href)
debug(torrent.magnetURI) debug(torrent.magnetURI)
@ -157,8 +179,8 @@ function CacheP2P(opts){
self.emit('webtorrent', 'Sending this page to peer ('+bytes+' bytes)') self.emit('webtorrent', 'Sending this page to peer ('+bytes+' bytes)')
}) })
torrent.on('wire', function (wire) { torrent.on('wire', function (wire) {
console.log('wire', wire) console.log('wire2', wire)
self.emit('webtorrent', 'Peer '+wire.peerId+' connected ('+wire.remoteAddress+') over '+wire.type+'.') self.emit('webtorrent', 'Peer ('+wire.remoteAddress+') connected over '+wire.type+' (Connection ID: '+wire.peerId.substr(0,10)+').')
}) })
// document.title = document.title // document.title = document.title
}); });
@ -169,7 +191,7 @@ function CacheP2P(opts){
} }
document.CacheP2P = new CacheP2P() // document.CacheP2P = new CacheP2P()
client.on('error', function(err){ // client.on('error', function(err){
document.CacheP2P.emit('webtorrent', err) // document.CacheP2P.emit('webtorrent', err)
}) // })