diff --git a/compat/db.js b/compat/db.js index 78b3e9ac..64d07c34 100644 --- a/compat/db.js +++ b/compat/db.js @@ -3,6 +3,7 @@ // SPDX-License-Identifier: LGPL-3.0-only const pull = require('pull-stream') +const Hookable = require('hoox') // exports.name is blank to merge into global namespace @@ -13,8 +14,8 @@ exports.manifest = { } exports.init = function (sbot, config) { - sbot.add = sbot.db.add - sbot.get = function get(idOrObject, cb) { + sbot.add = Hookable(sbot.db.add) + sbot.get = Hookable(function get(idOrObject, cb) { if (typeof idOrObject === 'object' && idOrObject.meta) { sbot.db.getMsg(idOrObject.id, cb) } else if (typeof idOrObject === 'object') { @@ -22,12 +23,13 @@ exports.init = function (sbot, config) { } else { sbot.db.get(idOrObject, cb) } - } + }) + // already hooked in the publish compat plugin (if loaded) sbot.publish = sbot.db.publish - sbot.whoami = () => ({ id: sbot.id }) - sbot.ready = () => true + sbot.whoami = Hookable(() => ({ id: sbot.id })) + sbot.ready = Hookable(() => true) sbot.keys = config.keys - sbot.createWriteStream = function createWriteStream(cb) { + sbot.createWriteStream = Hookable(function createWriteStream(cb) { return pull( pull.asyncMap(sbot.db.add), pull.drain( @@ -36,5 +38,5 @@ exports.init = function (sbot, config) { cb || ((err) => console.error(new Error('ssb-db2 createWriteStream failed to add messages'), {cause: err})) ) ) - } + }) } diff --git a/compat/log-stream.js b/compat/log-stream.js index 908e3b0f..7fbe4757 100644 --- a/compat/log-stream.js +++ b/compat/log-stream.js @@ -4,6 +4,7 @@ const pull = require('pull-stream') const cat = require('pull-cat') +const Hookable = require('hoox') const { descending, live, toPullStream } = require('../operators') // exports.name is blank to merge into global namespace @@ -13,7 +14,7 @@ exports.manifest = { } exports.init = function (sbot) { - sbot.createLogStream = function createLogStream(opts) { + sbot.createLogStream = Hookable(function createLogStream(opts) { // Apply default values opts = opts || {} const optsKeys = opts.keys === false ? false : true @@ -48,5 +49,5 @@ exports.init = function (sbot) { if (optsOld && !optsSync) return applyLimit(cat([old$, live$])) if (!optsOld && optsSync) return applyLimit(cat([sync$, live$])) if (!optsOld && !optsSync) return applyLimit(live$) - } + }) } diff --git a/compat/publish.js b/compat/publish.js index bfdc71f5..d674d13e 100644 --- a/compat/publish.js +++ b/compat/publish.js @@ -2,6 +2,8 @@ // // SPDX-License-Identifier: LGPL-3.0-only +const Hookable = require('hoox') + exports.init = function (sbot, config) { function publish(content, cb) { publishAs(config.keys, content, cb) @@ -19,6 +21,6 @@ exports.init = function (sbot, config) { ) } - sbot.db.publish = publish - sbot.db.publishAs = publishAs + sbot.db.publish = Hookable(publish) + sbot.db.publishAs = Hookable(publishAs) }