
Product
Introducing Webhook Events for Alert Changes
Add real-time Socket webhook events to your workflows to automatically receive software supply chain alert changes in real time.
ssb-links
Advanced tools
an ssb-plugin that indexes all the links!
This plugin can perform queries about messages that refer to other messages or feeds.
if you have a handle on the sbot server:
sbot.use(require('ssb-links')
sbot.links2.read({query: [{$filter: {rel: ['mentions', {$prefix: '@d'}]}}]})
OR if sbot is a client...
links2 = require('ssb-links').init(sbot, {path: '~/.ssb'})
links2.read({query: [{$filter: {rel: ['mentions', {$prefix: '@d'}]}}]})
Most clients will install ssb-links for you, check if the ssb-server links2.read --help command works
If not, to install it manually. Since ssb-links has the same name as a core feature, it actually exposes
it's api as sbot.links2 it was originally intended to replace ssb-db.links
but that didn't end up happening. So after installing it you need to configure a different name.
see the configuration for renaming a plugin.
This is not necessary if you are loading ssb-links directly in javascript code (as in the examples below).
to install ssb-server plugins.install ssb-links then to configure
{"plugins":{"ssb-links": "links2"}}``` to your ~/.ssb/config`.
A leveldb instance will be created in your ssb directory ~/.ssb/flume/links.
Because of the size of a message id, this will be quite a large index.
If there is no query provided, a full scan of the links database will be performed. this will return a stream of data that looks like
{
source: @{author_of_link},
rel: [{rel}, {rel_data}...],
dest: @/%/&{link} //the dest can be any type of ssb object.
ts: {local_timestamp}
}
this format will be the input to the query.
this module introduces the concept of "rel data", the rel is now stored as an array, and the data associated with the rel stored with it. by indexing it as an array, it becomes easy to query it when that data is a sortable range (for example, mention names, which may be aphabetically sorted)
see ./links.js to see how data is mapped.
TODO: map all markdown links, including http links.
the query must be a valid map-filter-reduce
these queries are in JSON format so you can use them via the cli,
ssb-server links2.read --query '{QUERY}'
be sure to use single quotes around the query so that the json is property
escaped. otherwise, run these queries by passing them to sbot.links2.read({query: QUERY})
and taking the output as a pull-stream.
counts the number of times each name is used by which feed.
returns a stream all {name, feed, uses}
[
{"$filter": {
"rel": ["mentions", {"$prefix": "@"}]
}},
{"$reduce":{
"name": ["rel", 1], "feed": "dest", "uses": {"$count": true}
}}
]
returns feeds in each thread, and how many posts they have made.
return object in form of {[thread_id]:{[poster]:count}}
[
{"$filter": {
"rel": ["root"]
}},
{"$reduce":{
"thread": "dest", "participant": "source", "posts": {"$count": true}
}}
]
[
{"$filter": {
"rel": ["mentions", {"$prefix": "@"}],
"dest": "@EMovhfIrFk4NihAKnRNhrfRaqIhBv1Wj8pTxJNgvCCY=.ed25519"
}},
{"$reduce": {
"name": ["rel", 1], "by": "source", "uses": {"$count": true}
}}
]
MIT
FAQs
index links in ssb messages
The npm package ssb-links receives a total of 110 weekly downloads. As such, ssb-links popularity was classified as not popular.
We found that ssb-links demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 19 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.

Product
Add real-time Socket webhook events to your workflows to automatically receive software supply chain alert changes in real time.

Security News
ENISA has become a CVE Program Root, giving the EU a central authority for coordinating vulnerability reporting, disclosure, and cross-border response.

Product
Socket now scans OpenVSX extensions, giving teams early detection of risky behaviors, hidden capabilities, and supply chain threats in developer tools.