https://github.com/geut/hypercore-promise
  
  
    An async/await based wrapper for hypercore 
    https://github.com/geut/hypercore-promise
  
async-await dat hypercore promises
        Last synced: 6 months ago 
        JSON representation
    
An async/await based wrapper for hypercore
- Host: GitHub
- URL: https://github.com/geut/hypercore-promise
- Owner: geut
- License: mit
- Created: 2020-02-07T18:50:53.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2020-07-24T19:07:37.000Z (over 5 years ago)
- Last Synced: 2025-03-30T09:41:17.284Z (7 months ago)
- Topics: async-await, dat, hypercore, promises
- Language: JavaScript
- Homepage:
- Size: 40 KB
- Stars: 9
- Watchers: 3
- Forks: 4
- Open Issues: 2
- 
            Metadata Files:
            - Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
 
Awesome Lists containing this project
README
          # hypercore-promise
[](https://travis-ci.com/geut/hypercore-promise)
[](https://standardjs.com)
[](https://github.com/RichardLitt/standard-readme)
> An async/await based wrapper for [hypercore](https://github.com/hypercore-protocol/hypercore) (v9+)
```
$ npm install @geut/hypercore-promise
```
```javascript
const hypercore = require('@geut/hypercore-promise')
;(async () => {
  const feed = hypercore('./my-first-dataset', {valueEncoding: 'utf-8'})
  await feed.append('hello')
  await feed.append('world')
  console.log(await feed.get(0)) // prints hello
  console.log(await feed.get(1)) // prints world
})
```
### Differences with Hypercore
Some methods like `get` and `download` not only use callbacks but also returns a value directly.
```javascript
const id = feed.get(0, (err, data) => {
  console.log(data)
})
```
Since our methods return promises what you need to do to get the internal value is to use our function helper `getValue`.
```javascript
const { getValue } = require('hypercore-promise')
const promise = feed.get(0)
const id = getValue(promise)
promise.then(data => console.log(data))
```
`hypercore-promise` already detects the internal value so you don't need to use `getValue` in that case.
```javascript
const promise = feed.get(0)
feed.cancel(promise)
promise.catch(err => {
  console.log('was canceled')
})
```
:bug: If you found an issue we encourage you to report it on [github](https://github.com/geut/hypercore-promise/issues). Please specify your OS and the actions to reproduce it.
:busts_in_silhouette: Ideas and contributions to the project are welcome. You must follow this [guideline](https://github.com/geut/hypercore-promise/blob/master/CONTRIBUTING.md).
## License
MIT © A [**GEUT**](http://geutstudio.com/) project