Skip to content
This repository has been archived by the owner on Jun 27, 2023. It is now read-only.

Commit

Permalink
refactor: switch to async iterators (#88)
Browse files Browse the repository at this point in the history
BREAKING CHANGE: Switch to using async/await and async iterators.
  • Loading branch information
vasco-santos authored Nov 14, 2019
1 parent 253f63a commit 2c32d25
Show file tree
Hide file tree
Showing 17 changed files with 767 additions and 1,240 deletions.
71 changes: 0 additions & 71 deletions .aegir.js

This file was deleted.

12 changes: 6 additions & 6 deletions LICENSE
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
MIT License
The MIT License (MIT)

Copyright (c) 2016 libp2p
Copyright (c) 2019 Protocol Labs, Inc.

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
Expand All @@ -9,13 +9,13 @@ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
58 changes: 28 additions & 30 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ js-libp2p-floodsub
- [Install](#install)
- [Usage](#usage)
- [API](#api)
- [Events](#events)
- [Contribute](#contribute)
- [License](#license)

Expand All @@ -31,26 +32,39 @@ js-libp2p-floodsub
> npm install libp2p-floodsub
```

## Examples
## Usage

```JavaScript
const FloodSub = require('libp2p-floodsub')

const fsub = new FloodSub(node)
// registrar is provided by libp2p
const fsub = new FloodSub(peerInfo, registrar, options)

fsub.start((err) => {
if (err) {
console.log('Upsy', err)
}
fsub.on('fruit', (data) => {
console.log(data)
})
fsub.subscribe('fruit')
await fsub.start()

fsub.publish('fruit', new Buffer('banana'))
fsub.on('fruit', (data) => {
console.log(data)
})
fsub.subscribe('fruit')

fsub.publish('fruit', new Buffer('banana'))
```

## API

### Create a floodsub implementation

```js
const options = {…}
const floodsub = new Floodsub(peerInfo, registrar, options)
```

Options is an optional object with the following key-value pairs:

* **`emitSelf`**: boolean identifying whether the node should emit to self on publish, in the event of the topic being subscribed (defaults to **false**).

For the remaining API, see https://github.com/libp2p/js-libp2p-pubsub

## Events

Floodsub emits two kinds of events:
Expand All @@ -68,28 +82,12 @@ Floodsub emits two kinds of events:
- `changes`: an array of `{ topicID: <topic>, subscribe: <boolean> }`
eg `[ { topicID: 'fruit', subscribe: true }, { topicID: 'vegetables': false } ]`


## API

### Create a floodsub implementation

```js
const options = {…}
const floodsub = new Floodsub(libp2pNode, options)
```

Options is an optional object with the following key-value pairs:

* **`emitSelf`**: boolean identifying whether the node should emit to self on publish, in the event of the topic being subscribed (defaults to **false**).

For more, see https://libp2p.github.io/js-libp2p-floodsub

## Contribute

PRs are welcome!
Feel free to join in. All welcome. Open an [issue](https://github.com/libp2p/js-libp2p-pubsub/issues)!

Small note: If editing the Readme, please conform to the [standard-readme](https://github.com/RichardLitt/standard-readme) specification.
This repository falls under the IPFS [Code of Conduct](https://github.com/ipfs/community/blob/master/code-of-conduct.md).

## License

MIT © David Dias
Copyright (c) Protocol Labs, Inc. under the **MIT License**. See [LICENSE file](./LICENSE) for details.
119 changes: 58 additions & 61 deletions benchmarks/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,81 +2,78 @@

const Benchmark = require('benchmark')
const crypto = require('crypto')
const map = require('async/map')
const parallel = require('async/parallel')
const series = require('async/series')

const PSG = require('../src')
const utils = require('../test/utils')
const DuplexPair = require('it-pair/duplex')

const Floodsub = require('../src')
const { multicodec } = require('../src')
const { createPeerInfo } = require('../test/utils')

const suite = new Benchmark.Suite('pubsub')

// Simple benchmark, how many messages can we send from
// one node to another.

map([0, 1], (i, cb) => {
utils.createNode((err, node) => {
if (err) {
return cb(err)
;(async () => {
const registrarRecordA = {}
const registrarRecordB = {}

const registrar = (registrarRecord) => ({
register: (multicodec, handlers) => {
registrarRecord[multicodec] = handlers
},
unregister: (multicodec) => {
delete registrarRecord[multicodec]
}
})

const ps = new PSG(node)
const [peerInfoA, peerInfoB] = await Promise.all([
createPeerInfo(),
createPeerInfo()
])

series([
(cb) => node.start(cb),
(cb) => ps.start(cb)
], (err) => {
if (err) {
return cb(err)
}
const fsA = new Floodsub(peerInfoA, registrar(registrarRecordA))
const fsB = new Floodsub(peerInfoB, registrar(registrarRecordB))

cb(null, {
libp2p: node,
ps
})
})
})
}, (err, peers) => {
if (err) {
throw err
}

parallel([
(cb) => peers[0].libp2p.dial(peers[1].libp2p.peerInfo, cb),
(cb) => setTimeout(() => {
peers[0].ps.subscribe('Z', () => {}, () => {})
peers[1].ps.subscribe('Z', () => {}, () => {})
cb(null, peers)
}, 200)
], (err, res) => {
if (err) {
throw err
}
// Start pubsub
await Promise.all([
fsA.start(),
fsB.start()
])

const peers = res[1]
// Connect floodsub nodes
const onConnectA = registrarRecordA[multicodec].onConnect
const onConnectB = registrarRecordB[multicodec].onConnect

suite.add('publish and receive', (deferred) => {
const onMsg = (msg) => {
deferred.resolve()
peers[1].ps.removeListener('Z', onMsg)
}
// Notice peers of connection
const [d0, d1] = DuplexPair()
onConnectA(peerInfoB, d0)
onConnectB(peerInfoA, d1)

peers[1].ps.on('Z', onMsg)
fsA.subscribe('Z')
fsB.subscribe('Z')

peers[0].ps.publish('Z', crypto.randomBytes(1024))
}, {
defer: true
})
suite.add('publish and receive', (deferred) => {
const onMsg = (msg) => {
deferred.resolve()
fsB.removeListener('Z', onMsg)
}

fsB.on('Z', onMsg)

suite
.on('cycle', (event) => {
console.log(String(event.target)) // eslint-disable-line
})
.on('complete', () => {
process.exit()
})
.run({
async: true
})
fsA.publish('Z', crypto.randomBytes(1024))
}, {
defer: true
})
})

suite
.on('cycle', (event) => {
console.log(String(event.target)) // eslint-disable-line
})
.on('complete', () => {
process.exit()
})
.run({
async: true
})
})()
54 changes: 0 additions & 54 deletions examples/pub-sub-1-topic/publisher.js

This file was deleted.

1 change: 0 additions & 1 deletion examples/pub-sub-1-topic/subscriber.js

This file was deleted.

Loading

0 comments on commit 2c32d25

Please sign in to comment.