Research
Security News
Quasar RAT Disguised as an npm Package for Detecting Vulnerabilities in Ethereum Smart Contracts
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
hyperdrive-http
Advanced tools
Serve a hyperdrive archive or hypercore feed over HTTP. For an example of use, see dat.haus.
Hyperdrive-http returns a function to call when you receive a http request:
var server = http.createServer()
server.on('request', hyperdriveHttp(archive))
To use hyperdrive-http you will need to:
Hyperdrive works with many archives/feeds or a single archive.
If you have multiple archives, you will need to look the archive to return using the key.
Initiate with an archive lookup function:
var onrequest = hyperdriveHttp(getArchive)
The archive lookup function may look like this:
var getArchive = function (datInfo, cb) {
// datInfo = {
// key: archive.key,
// filename: filename.txt // If file is requested in URL
// op: 'get' or 'changes'
// }
// Find the archive to return:
var archive = cache.get(datInfo.key)
if (!archive) {
archive = drive.createArchive(datInfo.key)
// Make sure you join the swarm before callback
sw.join(archive.discoveryKey)
}
cb(null, archive) // callback with your found archive
}
Hyperdrive-http works great with a single archive too. It exposes the metadata at the root path and files are available without using the key.
Pass a single archive on initiation:
var onrequest = hyperdriveHttp(archive)
Now your archive metadata will be available at http://example.com/
You can also use a hypercore feed: hyperdriveHttp(feed)
(or using a similar getArchive function)
Hyperdrive-http responds to any URL with a specific format. If the URL does cannot be parsed, it will return a 404.
http://dat.haus/c5dbfe5521d8dddba683544ee4b1c7f6ce1c7b23bd387bd850397e4aaf9afbd9/
http://dat.haus/c5dbfe5521d8dddba683544ee4b1c7f6ce1c7b23bd387bd850397e4aaf9afbd9/filename.pdf
POST http://archive-example.com/
or POST http://archive-example.com/c5dbfe5521d8dddba683544ee4b1c7f6ce1c7b23bd387bd850397e4aaf9afbd9
http://archive-example.com/
http://archive-example.com/filename.pdf
POST http://archive-example.com/
For hypercore feeds, the data is available with the same logic as above for a single or multiple feeds.
var hyperdriveHttp = require('hyperdrive-http')
var getArchive = function (datInfo, cb) {
// find the archive to serve
var discoveryKey = crypto.createHmac('sha256', Buffer(datInfo.key, 'hex')).update('hypercore').digest('hex')
var archive = cache.get(discoveryKey)
if (!archive) {
archive = drive.createArchive(datInfo.key)
// connect to swarm, if necessary
sw.join(archive.discoveryKey)
}
cb(null, archive) // callback with your found archive
}
var onrequest = hyperdriveHttp(getArchive)
var server = http.createServer()
server.listen(8000)
server.on('request', onrequest)
Pass an archive lookup function for the first argument of hyperdriveHttp
. The function is called with datInfo
and a callback.
datInfo = {
key: archive.key,
filename: someFile.txt,
op: 'get' // or 'changes'
}
FAQs
Handle Hyper[drive|core] HTTP Requests
The npm package hyperdrive-http receives a total of 33 weekly downloads. As such, hyperdrive-http popularity was classified as not popular.
We found that hyperdrive-http demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 15 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Security News
Research
A supply chain attack on Rspack's npm packages injected cryptomining malware, potentially impacting thousands of developers.
Research
Security News
Socket researchers discovered a malware campaign on npm delivering the Skuld infostealer via typosquatted packages, exposing sensitive data.