@helia/http
Version:
A lightweight implementation of IPFS over HTTP in JavaScript
117 lines (78 loc) • 4.17 kB
Markdown
<p align="center">
<a href="https://github.com/ipfs/helia-http" title="helia-http">
<img src="https://raw.githubusercontent.com/ipfs/helia/main/assets/helia.png" alt="Helia logo" width="300" />
</a>
</p>
[](https://ipfs.tech)
[](https://discuss.ipfs.tech)
[](https://codecov.io/gh/ipfs/helia)
[](https://github.com/ipfs/helia/actions/workflows/main.yml?query=branch%3Amain)
> A lightweight implementation of IPFS over HTTP in JavaScript
<!--
!IMPORTANT!
Everything in this README between "# About" and "# Install" is automatically
generated and will be overwritten the next time the doc generator is run.
To make changes to this section, please update the @packageDocumentation section
of src/index.js or src/index.ts
To experiment with formatting, please run "npm run docs" from the root of this
repo and examine the changes made.
-->
Exports a `createHeliaHTTP` function that returns an object that implements a lightweight version of the Helia API that functions only over HTTP.
By default, content and peer routing are requests are resolved using the [Delegated HTTP Routing API](https://specs.ipfs.tech/routing/http-routing-v1/) and blocks are fetched from [Trustless Gateways](https://specs.ipfs.tech/http-gateways/trustless-gateway/).
Pass it to other modules like @helia/unixfs to fetch files from the distributed web.
```typescript
import { createHeliaHTTP } from '@helia/http'
import { unixfs } from '@helia/unixfs'
import { CID } from 'multiformats/cid'
const helia = await createHeliaHTTP()
const fs = unixfs(helia)
fs.cat(CID.parse('bafyFoo'))
```
```typescript
import { createHeliaHTTP } from '@helia/http'
import { trustlessGateway } from '@helia/block-brokers'
import { delegatedHTTPRouting, httpGatewayRouting } from '@helia/routers'
import { unixfs } from '@helia/unixfs'
import { CID } from 'multiformats/cid'
const helia = await createHeliaHTTP({
blockBrokers: [
trustlessGateway()
],
routers: [
delegatedHTTPRouting({
url: 'https://delegated-ipfs.dev'
}),
httpGatewayRouting({
gateways: ['https://cloudflare-ipfs.com', 'https://ipfs.io']
})
]
})
const fs = unixfs(helia)
fs.cat(CID.parse('bafyFoo'))
```
```console
$ npm i @helia/http
```
Loading this module through a script tag will make its exports available as `HeliaHttp` in the global namespace.
```html
<script src="https://unpkg.com/@helia/http/dist/index.min.js"></script>
```
- <https://ipfs.github.io/helia/modules/_helia_http.html>
Licensed under either of
- Apache 2.0, ([LICENSE-APACHE](https://github.com/ipfs/helia/blob/main/packages/http/LICENSE-APACHE) / <http://www.apache.org/licenses/LICENSE-2.0>)
- MIT ([LICENSE-MIT](https://github.com/ipfs/helia/blob/main/packages/http/LICENSE-MIT) / <http://opensource.org/licenses/MIT>)
Contributions welcome! Please check out [the issues](https://github.com/ipfs/helia/issues).
Also see our [contributing document](https://github.com/ipfs/community/blob/master/CONTRIBUTING_JS.md) for more information on how we work, and about contributing in general.
Please be aware that all interactions related to this repo are subject to the IPFS [Code of Conduct](https://github.com/ipfs/community/blob/master/code-of-conduct.md).
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
[](https://github.com/ipfs/community/blob/master/CONTRIBUTING.md)