datastore-s3
Version:
IPFS datastore implementation backed by s3
96 lines (61 loc) • 3.44 kB
Markdown
//img.shields.io/badge/project-IPFS-blue.svg?style=flat-square)](https://ipfs.tech)
[](https://discuss.ipfs.tech)
[](https://codecov.io/gh/ipfs/js-stores)
[](https://github.com/ipfs/js-stores/actions/workflows/js-test-and-release.yml?query=branch%3Amain)
> IPFS datastore implementation backed by s3
<!--
!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.
-->
A Datastore implementation that stores data on Amazon S3.
If the flag `createIfMissing` is not set or is false, then the bucket must be created prior to using datastore-s3. Please see the AWS docs for information on how to configure the S3 instance. A bucket name is required to be set at the s3 instance level, see the below example.
```js
import { S3 } from '@aws-sdk/client-s3'
import { S3Datastore } from 'datastore-s3'
const s3 = new S3({
region: 'region',
credentials: {
accessKeyId: 'myaccesskey',
secretAccessKey: 'mysecretkey'
}
})
const store = new S3Datastore(
s3,
'my-bucket',
{ path: '.ipfs/datastore', createIfMissing: false }
)
```
```ts
Using with Helia
See [examples/helia](./examples/helia) for a full example of how to use Helia with an S3 backed datastore.
```
```console
$ npm i datastore-s3
```
Loading this module through a script tag will make its exports available as `DatastoreS3` in the global namespace.
```html
<script src="https://unpkg.com/datastore-s3/dist/index.min.js"></script>
```
- <https://ipfs.github.io/js-stores/modules/datastore_s3.html>
Licensed under either of
- Apache 2.0, ([LICENSE-APACHE](https://github.com/ipfs/js-stores/blob/main/packages/datastore-s3/LICENSE-APACHE) / <http://www.apache.org/licenses/LICENSE-2.0>)
- MIT ([LICENSE-MIT](https://github.com/ipfs/js-stores/blob/main/packages/datastore-s3/LICENSE-MIT) / <http://opensource.org/licenses/MIT>)
Contributions welcome! Please check out [the issues](https://github.com/ipfs/js-stores/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)
[![ipfs.tech](https: